- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
代码示例:
struct name
{
int a, b;
};
int main()
{
&(((struct name *)NULL)->b);
}
这会导致未定义的行为吗?我们可以争论它是否“取消引用 null”,但是 C11 没有定义术语“取消引用”。
6.5.3.2/4 明确指出在空指针上使用 *
会导致未定义的行为;但是它对 ->
的说法不一样,也没有将 a -> b
定义为 (*a).b
;它对每个运算符都有单独的定义。
6.5.2.3/4 中 ->
的语义说:
A postfix expression followed by the -> operator and an identifier designates a member of a structure or union object. The value is that of the named member of the object to which the first expression points, and is an lvalue.
但是,NULL
没有指向对象,因此第二句似乎未指定。
同样相关的可能是 6.5.3.2/1:
Constraints:
The operand of the unary
&
operator shall be either a function designator, the result of a[]
or unary*
operator, or an lvalue that designates an object that is not a bit-field and is not declared with the register storage-class specifier.
但是我觉得粗体文本有缺陷,应该阅读 lvalue that potentially designates an object ,按照 6.3.2.1/1(lvalue 的定义)—— C99 搞乱了左值的定义,所以 C11 不得不重写它,也许这部分被遗漏了。
6.3.2.1/1 确实说:
An lvalue is an expression (with an object type other than void) that potentially designates an object; if an lvalue does not designate an object when it is evaluated, the behavior is undefined
然而,&
运算符确实 计算其操作数。 (它不访问存储的值,但这是不同的)。
这一长串推理似乎表明该代码会导致 UB,但它相当脆弱,我不清楚标准编写者的意图。如果他们实际上有任何意图,而不是留给我们辩论:)
最佳答案
从律师的角度来看,表达式 &(((struct name *)NULL)->b);
应该导致 UB,因为你找不到一条路径没有UB。恕我直言,根本原因是您在不指向对象的表达式上应用 ->
运算符。
从编译器的角度来看,假设编译器程序员没有过于复杂,很明显表达式返回与 offsetof(name, b)
相同的值,我很确定如果编译没有错误任何现有的编译器都会给出该结果。
正如所写,我们不能责怪编译器会注意到在内部部分你使用运算符 ->
一个表达式而不是指向一个对象(因为它是空的)并发出一个警告或错误。
我的结论是,除非有一个特殊的段落说只要它只是取它的地址,它是合法的解引用一个空指针,这个表达式是不合法的 C。
关于c - &((struct name *)NULL -> b) 会导致 C11 中的未定义行为吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47637755/
我有一个数组 items[] items[] 中的每一项都是一个结构体。 item 有键 id、date、value(即 item.id、item.date、item.value) 我想使用 Stru
我想存储 100 名员工。 RollNo,姓名,工资,时间(各种数据,我无法在这里解释,但你可以看下面的代码片段来理解 main() { struct day { int hour
这个问题在这里已经有了答案: storage size of ‘names’ isn’t known (3 个答案) 关闭 5 年前。 我正在尝试蓝牙编程,遇到了这个我不明白的问题。基本上,当我使用
这是一个奇怪的事情: 我有一个结构,它包含指向相同类型结构的指针和指向其他类型结构的指针,以及一些其他值。 struct animal { struct animal * father;
我有一个结构定义如下(名称不同) struct str1 { int field1; struct str2; } 我在一个函数中有一个*str1。我想要一个指向 str2 的指针。 所以
DISK_DETECTION_INFO is defined as有什么原因吗? typedef struct _DISK_DETECTION_INFO { DWORD Size
我正在尝试打包一个字符串和一个字符串的长度。 fmt = '
我在创建结构时遇到问题。 我的结构: public struct Device: Codable { let data: DeviceData let meta: Meta? } pu
struct Item { var name:String? var type:String? var value:Int? var tag:Int? } ... ..
// NewReaderSize returns a new Reader whose buffer has at least the specified 43 // size. If the ar
这个问题在这里已经有了答案: Sorting a vector of custom objects (14 个答案) 关闭 3 年前。 在下面的 C++ 片段中, 如何基于 TwoInts 结构中的
#include struct Header { unsigned long long int alignment; }; int main(void) { struct Heade
我有一个目前看起来像这样的结构(缩写为仅显示基本部分): typedef struct { uint32_t baudrate; ... some other internally u
对此没有太多解释,这就是我所拥有的: public struct PACKET_HEADER { public string computerIp; publi
我有以下代码: struct MyStruct{ data: &'a str, } fn get(S: &'a MyStruct) -> &'a str{ S.data } fn se
struct S1 { char c; int i; }; struct S3 { char c1; struct S1 s; double c2; }; 我正
我有一个名为 Parameter 的协议(protocol): protocol Parameter { var name: String { get } var unit: Unit
有 2 个 struct 定义 A 和 A。我知道 struct A 可以包含指向 struct A 的 POINTER 但我不明白为什么 struct A 不能包含struct A(不是指针) 最佳
我有以下代码: struct MyStruct{ data: &'a str, } fn get(S: &'a MyStruct) -> &'a str{ S.data } fn se
为了说明这一点,这里有一个小的不可变结构和一个更新它的函数: (struct timeseries (variable observations) #:transparent) (define (ad
我是一名优秀的程序员,十分优秀!