热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

澄清C中指针的左值、右值行为

Clarificationoverlvalue,rvaluebehaviourofpointersinC


Clarification over lvalue , rvalue behaviour of pointers in C












1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17



#include

int main()
{

    int i = 10;

    int *p = &i;

    printf("
address of initialized pointer p: %u
"
, p);

    p = &(*p);

    printf("
modified address of initialized pointer p:%u value:%d valuez address: %d
"
, p, *p, &(*p));

    return 0;
}



代码输出:-

初始化指针p的地址:3221221820

初始化指针p的修改地址:3221221820 value:10 valuez地址:-1073745476

为什么是"


您在 printf 中使用了不正确的格式说明符。使用 %d 打印地址将不起作用。而是使用 %p 。 [打印地址的%u也不正确。]

这符合预期。



相关讨论




  • %p 和 %u 之间有什么区别?


  • %u 用于打印无符号整数,%p 用于指针。


  • 谢谢 Prasoon,还有一个疑问,当我使用 %p 时,我得到 0x7fbffff1bc,但是当我将 %u - 3221221820 打印的值转换为十六进制时,我只得到 bffff1bc。那么当我使用 %p 时附加的这个额外的 0x7f 是什么?


  • @Saran:在这种情况下,该值以十六进制格式表示。因此,0x。


  • @Saran,指针和 unsigned 的宽度可能不同。


  • @Prasoon,不仅 "0x" 被添加为前缀,而且 "0x7f" 被添加为前缀!这是什么7f?


  • @Jens,好的,所以未签名的宽度可能较小,因此缺少 7f 是吗?所以 %p 打印的值是正确的,对吗?


  • @Saran:地址的一部分(以十六进制格式表示)






你有

当您第二次尝试打印地址时,使用

%d 而不是 %u。

请注意以下修改后的源代码中的粗体更改:

printf("

modified address of

initialized pointer p:%u value:%d

valuez address: %u

", p, *p,

&(*p));

最值得注意的是,您应该使用 %p 来打印指针值,而不是 %u,正如在此线程的另一个答案中已经指出的那样。


指针的标准格式说明符是%p。为了安全起见,您应该始终在对 printf 的调用中明确地将指向 (void*) 的指针强制转换。不保证任何其他格式说明符都可以使用指针值。

例如










1
2



printf("p: %p; *p: %d; &(*p): %p
"
, (void*)p, *p, (void*)&(*p));


您看到的区别只是第一个格式说明符是 %u ,它将指针值打印为无符号整数,而第二次使用 %d 将其打印为有符号整数。



相关讨论





  • 如果该值已经是一个指针,那么将其转换为 void* 有什么区别?我可以看到将其保留在 C 中的问题(继承和运算符重载可能会导致问题),但是是什么使它在 C 中变得危险?


  • @cHao:虽然不常见,但指向不同类型的指针在 C 中可以有不同的表示形式。 %p 格式说明符要求相应参数的类型为 "pointer to void" 因此,如果您拥有的变量是指向别的东西那么严格你需要转换它以满足 printf 的要求。










推荐阅读
  • 经过两天的努力,终于成功解决了半平面交模板题POJ3335的问题。原来是在`OnLeft`函数中漏掉了关键的等于号。通过这次训练,不仅加深了对半平面交算法的理解,还提升了调试和代码实现的能力。未来将继续深入研究计算几何的其他核心问题,进一步巩固和拓展相关知识。 ... [详细]
  • NOIP2000的单词接龙问题与常见的成语接龙游戏有异曲同工之妙。题目要求在给定的一组单词中,从指定的起始字母开始,构建最长的“单词链”。每个单词在链中最多可出现两次。本文将详细解析该题目的解法,并分享学习过程中的心得体会。 ... [详细]
  • 本文详细介绍了在CodeUp平台中实现大数进制转换的技术方法。具体而言,该问题要求将一个最多包含30位数字的十进制非负整数转换为二进制表示。输入数据包含多行,每行包含一个不超过30位的十进制非负整数。通过高效的算法设计,确保了大数转换的准确性和性能。 ... [详细]
  • 在Linux系统中,通过使用`read`和`write`函数可以实现文件的高效复制操作。`open`函数用于打开或创建文件,其返回值为文件描述符,成功时返回一个有效的文件描述符,失败时返回-1。`path`参数指定了要操作的文件路径,而`oflag`参数则定义了文件的打开模式和属性。此外,为了确保数据的完整性和一致性,还需要合理处理文件读取和写入过程中的错误和异常情况。 ... [详细]
  • 本文深入探讨了佩尔方程 \( x^2 - dy^2 = 1 \) 的递推关系式。通过构造特定的矩阵并利用矩阵快速幂的方法,可以高效地计算出该方程的第 k 组解。此外,文章还详细分析了递推关系式的数学背景及其在数论中的应用,为相关研究提供了坚实的理论基础。 ... [详细]
  • 开发日志:201521044091 《Java编程基础》第11周学习心得与总结
    开发日志:201521044091 《Java编程基础》第11周学习心得与总结 ... [详细]
  • 数字图书馆近期展出了一批精选的Linux经典著作,这些书籍虽然部分较为陈旧,但依然具有重要的参考价值。如需转载相关内容,请务必注明来源:小文论坛(http://www.xiaowenbbs.com)。 ... [详细]
  • Codeforces 605C:Freelancer's Dreams —— 凸包算法解析与题解分析 ... [详细]
  • 在探讨P1923问题时,我们发现手写的快速排序在最后两个测试用例中出现了超时现象,这在意料之中,因为该题目实际上要求的是时间复杂度为O(n)的算法。进一步研究题解后,发现有选手使用STL中的`nth_element`函数成功通过了所有测试点。本文将详细分析这一现象,并提出相应的优化策略。 ... [详细]
  • 本文深入解析了Java面向对象编程的核心概念及其应用,重点探讨了面向对象的三大特性:封装、继承和多态。封装确保了数据的安全性和代码的可维护性;继承支持代码的重用和扩展;多态则增强了程序的灵活性和可扩展性。通过具体示例,文章详细阐述了这些特性在实际开发中的应用和优势。 ... [详细]
  • 单链表的高效遍历及性能优化策略
    本文探讨了单链表的高效遍历方法及其性能优化策略。在单链表的数据结构中,插入操作的时间复杂度为O(n),而遍历操作的时间复杂度为O(n^2)。通过在 `LinkList.h` 和 `main.cpp` 文件中对单链表进行封装,我们实现了创建和销毁功能的优化,提高了单链表的使用效率。此外,文章还介绍了几种常见的优化技术,如缓存节点指针和批量处理,以进一步提升遍历性能。 ... [详细]
  • UVa815问题“洪水来袭!”涉及洪水模拟和应对策略。在解决该问题时,需要通过直接模拟来处理洪水扩散过程,并特别关注临界情况的处理。代码实现中应包括必要的头文件,并使用标准命名空间以简化编程。此外,建议在算法设计中加入对边界条件和特殊情况的详细检查,以确保解决方案的鲁棒性和准确性。 ... [详细]
  • Java学习第10天:深入理解Map接口及其应用 ... [详细]
  • 图论入门基础教程
    图论是计算机科学和数学中的重要分支,本教程旨在为初学者提供全面的基础知识。通过实例解析,如“昂贵的聘礼”问题,讲述了一个年轻探险家在印第安部落与酋长女儿的爱情故事,展示了图论在解决实际问题中的应用。教程内容涵盖了图的基本概念、表示方法以及常见算法,适合各类读者学习。 ... [详细]
  • 在洛谷 P1344 的坏牛奶追踪问题中,第一问要求计算最小割,而第二问则需要找到割边数量最少的最小割。通过为每条边附加一个单位权值,可以在求解最小割时优先选择边数较少的方案,从而同时解决两个问题。这种策略不仅简化了问题的求解过程,还确保了结果的最优性。 ... [详细]
author-avatar
__-霖
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有