static_cast的奇怪用法
Strange usage of static_cast
我在我们的生产环境中浏览了以下代码结构(但经过了大量简化)。
#include <iostream>
typedef struct
{
char entry[10];
}
inn_struct;
typedef struct
{
inn_struct directory;
}
out_struct;
struct test
{
static const int
ENTRY_LENGTH = (sizeof((static_cast<out_struct*>(0))->directory.entry)
/ sizeof((static_cast<out_struct*>(0))->directory.entry[0]));
};
int main()
{
test a;
std::cout << test::ENTRY_LENGTH;
}
现在不考虑它明显的混淆性质,因为它只是确定数组长度的旧 C 方法......我真的很担心0
值的static_cast
。...此代码是否可以接受?您能否将 c++ 标准中的一些段落附加到您的响应中,告诉我(如果)为什么这段代码可以?
是的,这段代码是完全可以接受的。参见§5.3.3/1(强调我的)。
sizeof 运算符在其操作数的对象表示形式中生成字节数。操作数要么是表达式,它是一个未计算的操作数(条款 5),要么是一个参数化的类型 ID。
表达式未计算,因此取消引用空指针没有问题。
另请注意,在 C++11 中,您不需要跳过该箍,只需使用 sizeof 直接引用类成员,这要归功于 §5/8(强调我的):
在某些情况下,会出现未计算的操作数(5.2.8、5.3.3、5.3.7、7.1.6.2)。不计算未计算的操作数。未计算的操作数被视为完整表达式。[注意:在未计算的操作数中,可以命名非静态类成员(5.1),并且对象或函数的命名本身不需要提供定义(3.2)。
和 §5.1.1/13:
只能使用表示类的非静态数据成员或非静态成员函数的 id 表达式:
..
如果该 id-expression 表示非静态数据成员,并且它出现在未计算的上下文中 [示例:
struct S {
int m;
};
int i = sizeof(S::m); // OK
int j = sizeof(S::m + 42); // OK
- 完结]
相关文章:
- 如何理解C++标准N3337中的expr.const.cast子句8
- C++Cast运算符过载
- 这个指针在c++中的用法
- 当C++中需要自动删除时,这是静态的正确用法吗?
- libstdc++ 文件系统中未初始化的用法?
- 复制和交换习惯用法与移动操作之间的交互
- 类作用域的类型别名"using":[何时]方法中的用法可以先于类型别名?
- 命名参数习惯用法和(抽象)基类
- 省略号在C++中的所有用法
- () 在 C++ 11 中的特殊而奇怪的用法?
- 构造函数的用法
- 模板类中自动的类用法不完整
- 这里的 = 运算符有什么用法?
- 什么模板用法在阶乘中更好
- 如果可变长度元素的constexpr用法得到<>
- 为什么 setjmp/longjmp 的这种用法是未定义的行为?
- 访问提升:shared_ptr 主范围外崩溃,断言失败:px != 0.指针的正确用法是什么?
- C++ 中函数中 Const 用法之间的差异
- 错误:"cast"未命名类型void setCastDescription(std::string
- equal_to模板类C++用法