对外部类内部类的c++引用
c++ reference to an inner class inside an outer class
只是好奇,是否可以声明对内部类的引用外部类:
class A{
private:
class B{
public:
B(double val):val_(val){}
private:
double val_;
};
public:
A(double val):b(B(val)){} /*problem*/
private:
B& b;
};
int main(){
A a(1.0);
}
从逻辑上讲,这是不可能的,因为我不知道如何分配a对临时变量的引用。但我想确认一下。)我愿意使用ref而不是指针来保证A
中存在B
当我问为什么我想做那件事时,这是我的目标。让我们想象class B
包含大量的数据,需要大量的内存。我不我要有很多B的拷贝,否则我的内存会用完的。现在我有两个了类C
和D
都继承A
。我希望它们与B
的相同实例。我可以用指针来做,但就像之前说的,我想以确保至少有一个B
存在的地方,所以我认为,通过使用我可以向你保证。我也希望B
是一个内线类,以免污染我的代码。感谢您的帮助,我现在使用右值参考和我的代码看起来像这样:
class A{
class B{
public:
B(double val):val_(val){}
private:
double val_;
};
public:
A(double val):b(B(val)){}
A(A const& a):b(a.b){}/*new problem*/
protected:
B&& b;
};
class C: public A{
public:
C(A const& a):A(a){}
};
class D: public A{
public:
D(A const& a):A(a){}
};
int main(){
A a(1.0);
C c(a);
D d(a);
}
但是不能编译
标题>No
如果使用右值引用,它将编译:
class A
{
struct B {};
B&& b;
public:
A() : b(B()) {}
};
int main()
{
A a;
}
& help;但是,令人恼火的是,这是一个悬空引用,它遵循一个特殊的规则,该规则禁止成员b
延长临时B()
的生命周期,否则它可能会:
[C++11: 12.2/5]:
[…]在构造函数的参数初始化式(12.6.2)中,到引用成员的临时绑定将一直存在,直到构造函数退出。 [. .)
现在,如果B
是public
,并且如果B
对象是从其他地方传入的,那么您就实现了您的目标:
struct A
{
struct B {};
B& b;
A(B& b) : b(b) {}
};
int main()
{
A::B b;
A a(b);
}
(现场演示)
但是,如果做不到这一点,我不知道你还能做什么来实现这个目标。
这似乎是有限的效用,虽然;只要有一个真正的B
成员!
如果你想在复制的成员之间共享一个对象,使用std::shared_ptr。这是保证B对象对于使用它的所有A对象持久存在的唯一标准方法。
相关文章:
- 将对象数组的引用传递给函数
- 什么时候在C++中返回常量引用是个好主意
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- 何时在引用或唯一指针上使用移动语义
- 如何在c++中使用引用实现类似python的行为
- 编译C++时未定义的引用
- Ctypes wstring通过引用传递
- c++r值引用应用于函数指针
- 理解c++中的引用
- C++取消引用指针.为什么会发生变化
- 如何修复此错误:未定义对"距离(浮点数,浮点数,浮点数,浮点数,浮点数)"的引用
- 我的项目不会像"undefined reference to `grpc::g_core_codegen_interface'"那样使用未定义的引用错误进行编译
- C++Boost Asio Pool线程,带有lambda函数和传递引用变量
- 强制转换为引用类型
- 引用一个已擦除类型(void*)的指针
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- 具有默认值的引用获取函数
- 如何使用基类指针引用派生类成员
- 使用取消引用的指针的多态性会产生意外的结果.为什么?
- 如何引用基类的派生类?