- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我刚刚在博客中看到了一些代码。它使用了
scanf("%s",&T);
但正如我们所知,我们不应该在字符串中使用 & 符号,因为它会自动分配该字符串的首地址。我确实运行了该代码,令人惊讶的是它可以正常工作,所以我想知道当我在字符串中使用 &
时会发生什么?
#include <stdio.h>
int main()
{
char T[2];
scanf("%s", &T);
printf("You entered %s\n", T);
}
最佳答案
代码片段的相关部分是:
char T[2];
scanf("%s", &T);
&T
是指向两个字符数组的指针 (char (*)[2]
)。这不是 scanf
需要的 %s
说明符类型:它需要一个指向字符的指针 (char *
)。所以程序的行为是未定义的。
如您所知,编写此程序的正确方法是
char T[2];
scanf("%s", T);
由于 T
是一个数组,当它在大多数上下文中使用时,它“衰减”为指向第一个字符的指针:T
等同于 &(T[0])
类型为 char *
。当您获取数组的地址 (&T
) 或其大小 (sizeof(T)
) 时,不会发生这种衰减。
实际上,几乎所有平台都对指向同一地址的所有指针使用相同的表示。因此,编译器为 T
和 &T
生成完全相同的代码。有一些罕见的平台可能会生成不同的代码(我听说过它们,但我不能说出一个)。一些平台对“字节指针”和“字指针”使用不同的编码,因为它们的处理器本身处理字而不是字节。在这样的平台上,指向同一地址的 int *
和 char *
具有不同的编码。这些类型之间的转换会转换值,但在变量参数列表之类的东西中滥用会导致错误的地址。但是,我希望此类平台使用字符数组的字节地址。还有一些罕见的平台,其中指针不仅对数据地址进行编码,而且还对某些类型或大小信息进行编码。然而,在这样的平台上,类型和大小信息必须是等效的:它是一个 2 字节的 block ,从 T
的地址开始,并且可以逐字节寻址。因此,这个特定错误不太可能产生任何实际影响。
请注意,如果您首先使用指针而不是数组,情况将完全不同:
char *T; // known to point to an array of two characters
scanf("%s", &T); // bad
这里的&T
是一个指向内存中包含字符数组地址的位置的指针。所以 scanf
会将它读取的字符写入内存中指针 T
存储的位置,而不是 T
指向的位置.大多数编译器会分析 printf
和 scanf
等函数的格式字符串,因此会发出错误消息。
请注意,char T[2]
只能容纳两个字符,其中包括字符串末尾的空字节。所以 scanf("%s", T)
只能读取一个字符。如果此时输入包含多个非空白字符,程序将溢出缓冲区。要读取单个字符并使其成为单字符字符串,请使用
char T[2];
scanf("%c", T);
T[1] = 0;
与 scanf("%s", T)
不同,它可以读取任何字符,甚至是空格。要读取具有长度限制的字符串,请将限制添加到 %s
规范。你永远不应该在 scanf
中使用无限的 %s
,因为这将读取尽可能多的可用输入,无论内存中有多少空间可以存储此输入。
char T[2];
scanf("%1s", T); // one less than the array size
关于c - 如果我在 scanf 函数中将 "&"与字符串一起使用会怎样?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53332187/
我的运动需要一些帮助。 Question of exercise 这是我的代码: #include main() { int price,new_price; char code; printf(
这个问题在这里已经有了答案: scanf() leaves the newline character in the buffer (7 个答案) 关闭 5 年前。 我有这段代码(由于逻辑是家庭作业
我这里有一段代码,在输入带空格的字符串时会出现一些不需要的行为。例如 print illegal_argument。当输入包含多个单词时,我希望它只注册第一个单词。 目前发生的是: christian
我的测试输入是 [1,2,3] [4,5,6] [7,8,9] [9,9] 或者它可以是单个 2d 坐标之前的任意数量的 3d 坐标,我的代码是 #include #include #includ
这个问题在这里已经有了答案: What does space in scanf mean? [duplicate] (6 个答案) 关闭 7 年前。 像这样在scanf中加一个空格的目的是什么 sc
#include int main() { int n; scanf("%d", &n); printf(n); return 0; } 这是我的代码,我很愚蠢,可能
程序要求用户输入 2 名学生的姓名、ID 等,将数据写入文件并从文件中读回数据。 #include #include #include #include #include int main(
这个问题在这里已经有了答案: abnormal behavior of scanf [duplicate] (3 个答案) 关闭 8 年前。 今天我遇到了一个问题,当我使用两次接受字符作为输入的 s
我正在用 c 编写一个程序来读取文件的内容。代码如下: #include void main() { char line[90]; while(scanf("%79[^\
main() { int d,a; printf("Enter the digit :"); scanf("%d",&d); printf("Enter another
为什么为 scanf 输入添加多个句点会跳过下一个 scanf 函数。示例输入:b. b. int main (void) { char b[7] = " "; printf("Thi
我想我已经尝试过任何方法(刷新 stdin、scanf 以使用换行符等),但没有任何效果如我所希望的那样。由于某种原因,第三个 scanf 在以下代码中修改了第二个 scanf 中的变量: #incl
这个问题在这里已经有了答案: Scanf skips every other while loop in C (10 个答案) 关闭 6 年前。 我想做一个计算器,只是一个带有循环和基本操作的简单计
如果没有初始化 ("mod=0") ,这段代码进入死循环。我不明白为什么这段代码会循环,即使我使用了 getchar();删除缓冲区。当我先输入“1”,然后再输入“a”时,就会出现无限循环。谁能帮助我
当我为 scanf() 输入一个值时 它只是跳过紧随其后的第二个、第三个和任何其他 scanf()。 这是我的代码: #define _CRT_SECURE_NO_WARNINGS #include
#include #include void sstring(); int main() { char ch1[10],ch2; printf("Ent
这是一个计算房间内人员年龄的简单程序。我正处于初始阶段,现在我看到我不知道哪些变量(我的意思是我在 scanf 之前声明的变量,然后是 scanf 中的占位符)用于 scanf;如何选择和应用正确的变
这个问题在这里已经有了答案: scanf() leaves the newline character in the buffer (7 个答案) 关闭 5 年前。 我知道 scanf() 的用法,
我已经阅读了扫描集的行为。通过研究和测试,我遇到了一个问题。 难道 scanf("%[^\n]") 的行为与 scanf("%s") 一样吗? scanf("%s") 正在消耗字符,直到在 stdin
我遇到了一个问题,当我使用 scanf 将字符串存储到 char 指针中时,我有 3 个输入 - 姓名、姓氏和年龄,姓氏的最后一个 char 值被替换为年龄输出以更好地解释。 Q-riosity v0
我是一名优秀的程序员,十分优秀!