static_cast的奇怪用法

Strange usage of static_cast

本文关键字:用法 cast static      更新时间:2023-10-16

我在我们的生产环境中浏览了以下代码结构(但经过了大量简化)。

#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

- 完结]