c++ - 指向 "inner struct"成员的指针是否被禁止?

标签 c++ pointers

我有一个嵌套结构,我想要一个指向嵌套成员之一的成员指针:

合法吗?

struct InnerStruct
{
    bool c;
};
struct MyStruct {
    bool t;
    bool b;
    InnerStruct inner;
}; 

这个:

MyStruct mystruct;
//...
bool MyStruct::* toto = &MyStruct::b;

没问题,但是:

bool MyStruct::* toto = &MyStruct::inner.c;

不是。有什么想法吗?

谢谢

这里有一些细节 是的,它是 &MyStruct::b 而不是 mystruct::b; 该代码来自自定义 RTTI/Property 系统。 对于每个指定的类,我们保留一个“属性”数组,包括一个 Ptr-to-member 它是这样使用的:

//somewhere else in code...
( myBaseClassWithCustomRTTIPointer)->* toto = true;

最佳答案

是的,这是被禁止的。你不是第一个提出这个完全合乎逻辑的想法的人。在我看来,这是 C++ 中成员指针规范中明显的“错误”/“遗漏”之一,但显然委员会对进一步开发成员指针规范没有兴趣(因为大多数“低级”语言功能的情况)。

请注意,在语言中实现该功能所需的一切。指向成员数据成员的指针与指向直接数据成员的指针没有任何不同。唯一缺少的是初始化这样一个指针的语法。然而,委员会显然对引入这样的语法不感兴趣。

从纯形式逻辑的角度来看,这在 C++ 中应该是允许的

struct Inner {
  int i;
  int j[10];
};

struct Outer {
  int i;
  int j[10];
  Inner inner;
};

Outer o;
int Outer::*p;

p = &Outer::i; // OK
o.*p = 0; // sets `o.i` to 0

p = &Outer::inner.i; // ERROR, but should have been supported
o.*p = 0; // sets `o.inner.i` to 0

p = &Outer::j[0]; // ERROR, but should have been supported
o.*p = 0; // sets `o.j[0]` to 0
// This could have been used to implement something akin to "array type decay" 
// for member pointers

p = &Outer::j[3]; // ERROR, but should have been supported
o.*p = 0; // sets `o.j[3]` to 0

p = &Outer::inner.j[5]; // ERROR, but should have been supported
o.*p = 0; // sets `o.inner.j[5]` to 0

pointer-to-data-member 的典型实现只不过是成员从封闭对象开始的字节偏移量。由于所有成员(立即数和成员的成员)最终在内存中都是按顺序排列的,因此成员的成员也可以通过特定的偏移值来标识。这就是我说这个功能的内部工作已经完全实现的意思,所需要的只是初始化语法。

在 C 语言中,此功能由通过标准 offsetof 宏获得的显式偏移来模拟。在 C 语言中,我可以获得 offsetof(Outer, inner.i)offsetof(Outer, j[2])。不幸的是,这种能力没有反射(reflect)在 C++ 指向数据成员的指针中。

关于c++ - 指向 "inner struct"成员的指针是否被禁止?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1929887/

相关文章:

c - 如何处理结构数组?

c++ - C++ 中返回 *ptr 和 &x 的区别

java - 尝试在java中返回HashMap值时出现空指针异常

c++ - 这种情况是否需要删除或创建新变量?

c++ - SQLite。在 C++Builder 6 CodeGuard 中的 sqlite3.c 中有许多 'access overrun' 'arithmetic overrun' 'resource leak'

c++ - 为什么不能简单初始化(带大括号)2D std::array?

c++ - 使用构造函数初始化指向已定义结构的指针数组

c++ - 字符串分配期间访问冲突写入位置错误

c++ - 禁用 g++ "note candidates are.."编译器消息

c++ - ncurses 双重释放的任何可能原因?