【发布时间】:2013-08-02 06:24:47
【问题描述】:
const int a = 10
int *p = (int*) &a;
*p = 20;
printf("a = %d", a);
是否可以输出 10 或 20,取决于编译器?
【问题讨论】:
-
我给了你的问题一个概括其内容的标题。不要像以前那样使用通用标题,它们对任何人都没有帮助。
-
@Jens Gustedt 好的。谢谢。
const int a = 10
int *p = (int*) &a;
*p = 20;
printf("a = %d", a);
是否可以输出 10 或 20,取决于编译器?
【问题讨论】:
是否可以输出 10 或 20,取决于编译器?
是的,甚至可以出现鼻恶魔。该程序的行为未定义,代码格式错误,因为修改const 对象违反了约束。
【讨论】:
constraint violation 称为 const-constraint - 我喜欢正确的术语。
在编写时,您的代码具有未定义的行为,所以是的,您可能会得到 10 或 20 或其他任何值(例如,访问冲突)。
【讨论】:
这是未定义的行为:
C11 6.7.3 类型限定符
如果尝试通过使用来修改使用 const 限定类型定义的对象 具有非 const 限定类型的左值,行为未定义。如果尝试是 通过使用左值来引用使用 volatile 限定类型定义的对象 对于非 volatile 限定类型,行为未定义。
【讨论】:
是的,这是未定义的行为,我认为这就是它的所在。
C99 第 6.7.3 节第 5 段
如果尝试修改使用 通过使用具有非 const 限定的左值的 const 限定类型 类型,行为未定义。如果试图引用一个 通过使用左值以 volatile 限定类型定义的对象 对于非 volatile 限定类型,行为未定义。115)
【讨论】:
当您执行*p=20 时,您正在尝试更改常量的值,这是不允许的。
【讨论】: