打印指针指向的地址值

本文通过错误代码示例解释了在C/C++中如何正确打印指针指向的内存地址,而非指针变量自身的地址。错误代码显示每次输出的地址相同,实际上是因为输出的是指针变量的地址。修正后的代码直接打印指针变量即可得到指向的内存地址。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

废话不多说,直接上错误代码:

static void print_cpu_src(uint8_t * src,int stride){
    int i,j;
    printf("Magnum  cpu src addr == %p, stride ==%d:\n
### C语言打印指针指向 在C语言中,要打印指针指向的内容,可以使用解引用操作符`*`来获取指针指向的数据。下面是一个简单的例子展示如何实现这一点。 ```c #include <stdio.h> int main() { int value = 42; int *ptr_value = &value; printf("The address of 'value' is %p\n", (void*)&value); printf("Value stored at ptr_value's location: %d\n", *ptr_value); return 0; } ``` 上述代码创建了一个整型变量`value`并初始化为42,接着声明了一个指向该整数的指针`ptr_value`[^1]。通过将地址传递给`printf()`函数中的格式说明符`%p`,可以显示内存位置;而为了输出实际数,则需利用星号(`*`)执行间接寻址或称为解除引用(de-referencing),从而获得存储于指定地址处的具体数据[^4]。 对于字符类型或其他复杂结构体成员来说,过程相似: ```c char ch = 'A'; char *pch = &ch; printf("Character pointed by pch: %c\n", *pch); ``` 这里展示了如何处理单个字符的情况。当涉及到更复杂的场景比如字符串或者多维数组时,逻辑依然保持一致——总是先取得目标对象的地址存入相应类型的指针内,再借助解引用来访问其内容[^2]。 另外需要注意的是,在某些情况下可能还需要考虑数据类型的转换问题。例如从一种特定长度的整形到另一种不同大小的整形之间的转变可能会引起意想不到的结果,因此应当谨慎对待这类情况下的强制转型操作[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值