【发布时间】:2019-04-04 04:28:45
【问题描述】:
我打算回答某人关于 printf 接受 char * 的问题,所以我构建了一个小测试程序并提出了我自己的问题。使用 GCC 6.3 在 codechef.com/ide 上编译
Pass the char* directly to printf 我认为问题是询问“丢失的” const 限定符发生了什么,对吗? http://man7.org/linux/man-pages/man3/printf.3.html
char * str1 = "This is string 1\n";
char str2[] = "This is string 2\n";
int main(void) {
char str3[100] = "This is string 3\n";
char * str4 = "This is string 4\n";
str3[8] = 'c';
printf(str1);
printf(str2);
printf(str3);
printf(str4);
return 0;
}
输出:
这是字符串 1
这是一个字符串 2
这是 cstring 3
这是字符串 4
我正在考虑程序的内存布局,我变得更加困惑。 https://www.geeksforgeeks.org/memory-layout-of-c-program/
str1 是指向字符串文字“这是字符串 1\n”的指针。 str1 存在于数据中并指向存在于 ?? 中的字符串文字。 (我假设也初始化数据段) How is read-only memory implemented in C?
就内存布局而言,str2 类似于 str1。
str3 是有趣的地方。 str3 位于堆栈上,100 个字符宽,并通过声明/分配分配 char[0] = 'T'、char[1] = 'h' 等。这不应该是 CONST。 str3 的声明和赋值是在堆栈上声明 100 个字符并从数据(ROM 数据段或初始化的数据段或文本?)中为它们分配值。
str4 是栈上的一个指针,指向数据段内存。这就像 str1 和 str2,不太有趣。
然后分配 str3[8] = 'c' 只是为了测试/验证/证明 str3 的堆栈内存在 printfing 之前不是只读的。
我希望 1,2,4 可以工作,但为什么 3 可以工作(甚至没有编译器警告???)。我可能错误地假设 const 是“只读”的同义词,因为如果我只是写它,str3 就不可能是“只读”的。
Is there a read only memory in the stack for const variable declared in a function?
谁能向我解释为什么 str3 没有抛出警告或错误? str3 不是 const char *,要么编译器对其进行了优化(将赋值更改为“这是 ctring 3\n”),要么警告被抑制(似乎也不太可能),或者我对 cost 关键字有根本的误解.堆栈内存常量如何?也许我的一个或多个假设是错误的。
【问题讨论】:
-
你是说你希望编译器在你传递一个非 const 时发出警告吗?
-
@John3136 是的,这正是我所期望的。
标签: c stack printf constants memory-layout