C2x:如果 _Alignof(array type) 产生元素类型的对齐,那么允许 _Alignof(incomplete array type) 有用吗?
此代码无效:
int x = _Alignof(int[]);
注意:GCC 生成:
error: invalid application of '__alignof__' to incomplete type 'int[]'
而 Clang 生成:
<nothing>
Per Semantics(添加强调):
当应用于数组类型时,结果是元素类型的对齐要求。
然而,为了满足元素类型的对齐要求,不需要大小。
因此,通过更改约束来使上面的代码有效是否有用
:
_Alignof
运算符不得应用于函数类型或不完整类型。
至(强调):
_Alignof
运算符不得应用于函数类型或不完整的非数组类型。
This code is invalid:
int x = _Alignof(int[]);
Note: GCC produces:
error: invalid application of '__alignof__' to incomplete type 'int[]'
while Clang produces:
<nothing>
Per Semantics (emphasis added):
When applied to an array type, the result is the alignment requirement of the element type.
However, in order to yield the alignment requirement of the element type, the size is not needed.
Hence, will it be useful to make the code above valid by changing the constraint
from:
The
_Alignof
operator shall not be applied to a function type or an incomplete type.
to (emphasis added):
The
_Alignof
operator shall not be applied to a function type or an incomplete non-array type.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
正如您所观察到的,语言规范明确禁止将 _Alignof 运算符应用于不完整类型的表达式或此类类型的括号名称。这是一种语言约束,因此实现诊断违规是一种一致性要求,从这个意义上说,Clang 的行为是不合格的。
另一方面,当所讨论的类型是具有完整元素类型但未指定元素数量的数组类型时,您有机会实现完全一致的 _Alignof 行为,这是正确的。数组中元素的数量并不是其对齐要求的一个因素,因此只要规范允许,这个操作就可以根据普通的_Alignof语义来解决。
它有用吗?有用吗?我确信这取决于人们考虑的可能用途范围。我不认为
_Alignof
总体上非常有用,尽管它确实有它的时刻。而且由于您可以直接从数组类型的元素类型获取数组类型的对齐方式,因此您不需要对数组类型使用_Alignof
,无论完整与否,除非在您不知道什么的地方类型将被操作。这并没有排除所有可能的用途,但它留下的窗口足够小,我认为规范表达它所执行的更简单的约束而不是更复杂的约束并不是不合理的。需要允许_Alignof
处理这一特殊的不完整类型。As you observe, the language spec explicitly forbids applying the
_Alignof
operator to an expression of incomplete type or to the parenthesized name of such a type. This is a language constraint, so it is a conformance requirement that implementations diagnose violations, and in this sense, Clang's behavior is non-conforming.On the other hand, you're right that there is an opportunity for fully consistent
_Alignof
behavior when the type in question is an array type with complete element type but unspecified number of elements. The number of elements in an array is not a factor in its alignment requirement, so this operation could be resolved according to ordinary_Alignof
semantics, provided only that the spec allowed it.Would it be useful? I'm sure that depends on what range of possible uses one considers. I don't find
_Alignof
very useful in general, though it does have its moments. And since you can get the alignment of an array type directly from its element type, you don't need_Alignof
for array types -- complete or not -- except in places where you don't know what type will be operated upon. That doesn't cut out all possible uses, but the window it leaves is small enough that I don't think it unreasonable for the spec to express the simpler constraint it does instead of the more complicated one that would be required to allow_Alignof
on this one special class of incomplete types.