标题:C语言中,指针相减与右移
只看楼主
八画小子
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:贵宾
威 望:37
帖 子:705
专家分:2043
注 册:2010-11-11
结帖率:96.55%
已结贴  问题点数:20 回复次数:3 
C语言中,指针相减与右移
刚刚踩了一个坑,等效代码如下:
程序代码:
#include <stdio.h>
#include <stdlib.h>

int main(void)
{
    void * start = (void *)0xc0000000;
    void * end = (void *)0x00000000;

    printf("%p - %p = %lx\n", end, start, end - start);
    printf("(%p - %p) >> 12 = %#lx\n", end, start, (end - start) >> 12);
    printf("(unsigned long)(%p - %p) >> 12 = %#lx\n", end, start, (unsigned long)(end - start) >> 12);

    return EXIT_SUCCESS;
}


结果(end - start) >> 12这一部分的计算有问题,导致了一个错误。

C语言中的右移动操作符>>视操作数是否为无符号有两种操作:如果操作数是无符号,则按逻辑右移执行;如果操作数是有符号,则按算术右移执行。
这一点是没有问题的,不过指针相减的结果却是有符号整数,故(end - start) >> 12得不到预期的结果,应该做一次类型转换。
搜索更多相关主题的帖子: 相减 end 右移 start void 
2020-07-08 23:20
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:0 
指针相减的类型是 ptrdiff_t,是有符号类型,在printf中用 %td。
可以转为 uintptr_t 等无符号类型,在printf中用 <inttypes.h> 中定义的 PRIuPTR。
2020-07-09 00:16
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:20 
你想16进制输出uintptr_t,那么应该用 PRIxPTR、PRIXPTR
2020-07-09 00:19
八画小子
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:贵宾
威 望:37
帖 子:705
专家分:2043
注 册:2010-11-11
得分:0 
以下是引用rjsp在2020-7-9 00:16:30的发言:

指针相减的类型是 ptrdiff_t,是有符号类型,在printf中用 %td。
可以转为 uintptr_t 等无符号类型,在printf中用 <inttypes.h> 中定义的 PRIuPTR。



受教了,标准库里确实有很多比较方便的东西,研读标准库是非常有必要的。👍👍👍
2020-07-09 01:08



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-502449-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.064929 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved