阅读引用链接后:Must provide destructor in the PIMPL ,我按照示例进行操作,但是 g++(4.6.1) 没有按照我的预期生成编译错误
源代码为:
// Predeclare.h
#include <vector>
#include <boost/scoped_ptr.hpp>
#include <iostream>
struct A;
class Predeclare
{
std::vector<A> alist_;
boost::scoped_ptr<A> pa_;
//A a;
public:
Predeclare();
//~Predeclare();
void print();
void set(int i);
};
// Predeclare.cpp
#include "Predeclare.h"
struct A
{
int a;
};
Predeclare::Predeclare(): pa_(new A)
{}
/*
Predeclare::~Predeclare()
{}
*/
void Predeclare::print()
{
std::cout << pa_->a << '\n';
}
void Predeclare::set(int i)
{
pa_->a = i;
}
int main()
{
Predeclare c1;
c1.set(10);
c1.print();
return 0;
}
然后,编译程序
g++ Predeclare.cpp
一切正常,为什么g++(4.6.1)没有生成编译错误?
最佳答案
在您的示例中,编译器只需要 Predeclare
的析构函数。当到达 c1
的声明时在main()
。到那时,A
已经在 Predeclare.cpp 的前面部分定义了。
如果您尝试实例化Predeclare
在不同的源文件中,您可能会遇到问题。
请注意,实例化 std::vector<A>
哪里A
不完整会产生未定义的行为。实例化容器时,值类型必须是 Destructible,并且只有完整类型才是 Destructible。
关于c++ - 从不在 PIMPL 中提供析构函数(使用 boost scoped_ptr),g++(4.6.1) 不会生成编译错误,为什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17204244/