【问题标题】:Is it safe to pass pointers to data members to base class constructor?将指向数据成员的指针传递给基类构造函数是否安全?
【发布时间】:2018-09-20 07:11:09
【问题描述】:

将指向数据成员的指针传递给基类构造函数是否安全?即,派生类数据成员的内存布局是否至少在调用基类构造函数之前已经设置,即使数据成员尚未初始化?

显然,只有在构造完成并且指向的对象已经有效之后才能取消引用指针。但问题是,一旦派生对象的构造完成,是否可以保证基类构造函数接收到的指针实际上仍然指向它们的对象。

动机是在基类中提供一些功能,例如迭代构造时提供的指向对象的指针,并在以后为每个对象做一些事情。

可以只提供派生类可访问的setter,但我很好奇在构造时提供指针是否也安全。

例子:

#include <iostream>
#include <utility>
#include <vector>

struct Base {
   Base(std::initializer_list<int*> ptrs = {}) : ptrs_(ptrs) {}
   std::vector<int*> ptrs_;
};

struct Derived : public Base {
    Derived() : Base{{&a_,&b_,&c_}} {}
    int a_=1, b_=2, c_=3;
};

int main()
{
    Derived obj;
    for (auto* ptr : obj.ptrs_) { std::cout << *ptr << '\n'; }
}

https://wandbox.org/permlink/rDJw0UU8KcWckLlo

【问题讨论】:

  • 注意:请使用括号初始化ptrs_。当您没有专门使用该功能时,使用 {} 来初始化具有 initializer_list 构造函数的类型是一个非常好的优势。
  • @Barry 完成,谢谢!

标签: c++ inheritance constructor language-lawyer


【解决方案1】:

您的代码很好。但请注意,取消引用基类构造函数中的指针的行为将是未定义的。

您可以将指针引用 传递给基类构造函数的成员变量,但不能实际访问该基类构造函数中的对象。

【讨论】:

  • 嗯,我的脑海里还有第一个版本,我想通过编辑,答案很好:)
  • 我在问题中添加了一个更明确的澄清段落。
  • 任何相关的标准参考?
  • @Danra - 只要您保证指针仅在成员初始化后被取消引用,您就已经准备就绪。在对象那里之前“作弊”并获得对对象的引用并不少见。这是使其成为犹太教的标准参考:eel.is/c++draft/basic.life#6
  • 我已经精疲力竭了 :) 此外,你说得更好,因为我现在喝咖啡的头脑有能力;)
猜你喜欢
  • 1970-01-01
  • 2023-03-22
  • 2017-01-19
  • 2022-01-21
  • 2013-07-21
  • 2011-03-06
  • 2018-12-07
  • 1970-01-01
  • 2017-05-16
相关资源
最近更新 更多