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

为什么在c中使用未初始化变量的地址而不是未初始化的指针是安全的?

正如我从这个答案中了解到的,在C中使用未初始化变量的地址并不是未定义的行为。例如,我可以写:#include<stdio.h>intm

正如我从这个答案中了解到的,在 C 中使用未初始化变量的地址并不是未定义的行为。例如,我可以写:

#include
int main(void) { char letter;
printf("%pn", &letter); //prints '0061ff1f'
return 0;
}

但是,如果我编写以下代码:

#include
int main(void) { char *letter1;
printf("%pn", letter1); //gcc issues warning
return 0;
}

gcc 给了我以下错误:

C:...>gcc -Wall -Wextra -pedantic -std=c11 test.c -o main
test.c: In function 'main':
test.c:12:2: warning: 'letter1' is used uninitialized in this function [-Wuninitialized]
printf("%pn", letter1);

如果我理解正确,未初始化的指针可能指向任何内存地址,这就是为什么使用它通常是一个坏主意。但是为什么同样的事情对未初始化的变量起作用,即为什么未初始化的变量不指向任何内存地址,而是指向我们可以安全使用的位置?为什么语言在这方面对待指针变量和普通变量的方式如此不同?

回答

当你写

char letter;
printf("%pn", &letter);

您声明了一个名为letter. 它有一个明确定义的位置(或地址)。我们唯一不知道的是其中的char值是不确定的或未定义的,这取决于您问的是谁。因此,如果您尝试这样做printf("%cn", letter),那可能会给您带来麻烦,因为这会尝试打印未定义/不确定的值。

但是当你写

char *letter1;
printf("%pn", letter1); //program crashes

那是完全不同的。 letter1是指针类型的变量char。和以前一样,它有一个明确定义的位置和一个不确定的初始值。但这里令人困惑的是,它没有的值也是(或将是)地址。

如果你写

printf("%pn", &letter1);

你打印地址 letter1,正如我说,这是明确的。但你试图打印

printf("%pn", letter1);

在那里你尝试打印的地址 letter1,这是一个更大的问题。

(不过,我不希望发生真正的崩溃——实际上,我只期望一个“随机值”。除非您尝试这样做,否则我不希望发生崩溃printf("%cn", *letter1)。)

还有一件事:获取未初始化变量的地址不能是未定义的,因为很多定义良好的程序就是这样做的!获取未初始化变量的地址并将其传递给函数是为变量赋值的好方法。如果您有一个“通过引用”返回值的函数,您可能会将变量的地址传递给它,并且它通常是未初始化的,如下所示:

char *p;
int n = strtol("23skidoo", &p, 10);
printf("%d %sn", n, p);


脚注:我写道初始值是“不确定或未定义,取决于你问谁”,这暗示了我几天前才了解到的一个巨大的微妙之处,即初始值的不确定性/不确定性像这样的局部变量的值显然取决于它们是否会或可能会被占用。这里有一种海森堡——或者也许是薛定谔——不确定性原理,行为取决于你试图观察它的密切程度。如果您的程序在尝试打印 的值时确实发生了崩溃letter1,那么如果您将其更改为,它可能不会崩溃printf("%p %pn", &letter1, letter1);






推荐阅读
  • 本文介绍了PE文件结构中的导出表的解析方法,包括获取区段头表、遍历查找所在的区段等步骤。通过该方法可以准确地解析PE文件中的导出表信息。 ... [详细]
  • Linux环境变量函数getenv、putenv、setenv和unsetenv详解
    本文详细解释了Linux中的环境变量函数getenv、putenv、setenv和unsetenv的用法和功能。通过使用这些函数,可以获取、设置和删除环境变量的值。同时给出了相应的函数原型、参数说明和返回值。通过示例代码演示了如何使用getenv函数获取环境变量的值,并打印出来。 ... [详细]
  • 本文介绍了一种划分和计数油田地块的方法。根据给定的条件,通过遍历和DFS算法,将符合条件的地块标记为不符合条件的地块,并进行计数。同时,还介绍了如何判断点是否在给定范围内的方法。 ... [详细]
  • c语言\n不换行,c语言printf不换行
    本文目录一览:1、C语言不换行输入2、c语言的 ... [详细]
  • 本文介绍了解决二叉树层序创建问题的方法。通过使用队列结构体和二叉树结构体,实现了入队和出队操作,并提供了判断队列是否为空的函数。详细介绍了解决该问题的步骤和流程。 ... [详细]
  • 本文介绍了C函数ispunct()的用法及示例代码。ispunct()函数用于检查传递的字符是否是标点符号,如果是标点符号则返回非零值,否则返回零。示例代码演示了如何使用ispunct()函数来判断字符是否为标点符号。 ... [详细]
  • C++中的三角函数计算及其应用
    本文介绍了C++中的三角函数的计算方法和应用,包括计算余弦、正弦、正切值以及反三角函数求对应的弧度制角度的示例代码。代码中使用了C++的数学库和命名空间,通过赋值和输出语句实现了三角函数的计算和结果显示。通过学习本文,读者可以了解到C++中三角函数的基本用法和应用场景。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • 本文介绍了九度OnlineJudge中的1002题目“Grading”的解决方法。该题目要求设计一个公平的评分过程,将每个考题分配给3个独立的专家,如果他们的评分不一致,则需要请一位裁判做出最终决定。文章详细描述了评分规则,并给出了解决该问题的程序。 ... [详细]
  • 本文介绍了C++中省略号类型和参数个数不确定函数参数的使用方法,并提供了一个范例。通过宏定义的方式,可以方便地处理不定参数的情况。文章中给出了具体的代码实现,并对代码进行了解释和说明。这对于需要处理不定参数的情况的程序员来说,是一个很有用的参考资料。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • 本文介绍了P1651题目的描述和要求,以及计算能搭建的塔的最大高度的方法。通过动态规划和状压技术,将问题转化为求解差值的问题,并定义了相应的状态。最终得出了计算最大高度的解法。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
author-avatar
rz白雪
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有