但是在A类中定义对B类对象的引用似乎不是什么好的方式,因为如果B类对象的生命周期比A类对象要短的话,那么B类对象中的引用成员就失效了,有点类似于野指针的效果。
比如
class A
{
public:
int i
}
class B
{
public:
A&ref_a
B(A&a) : ref_a(a){} //这里lkjhggv的定义有一个问题,不能用const A&来初始化非const的引用成员
}
A * pa = new A
B b(*pa)
delete pa//后面b.ref_a已经失效
C语言中,这种需求实际上是通过指针现实的,C++中这样的需求最完美的解决方案还是智能指针,比如STL的 std::shared_ptr
C语言是没有引用这个定义的,c++里面才有,它主要是带回作用,不过指针也可以起到带回作用,带回的是指针所指向的值而不是指针本身。像这种如果是保证F指向的值带回的话,可以不用引用。
就像C语言介绍的真交换一样,用指针就可以带回。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)