今天才知道有vtkNew的存在,。
要知道之前我都是这种:
vtkSmartPointer<vtkPolyData> polydata = vtkSmartPointer<vtkPolyData>::New();
不然就是这样的:
vtkPolyData *polydata = functionSource->GetOutput();///
以后可以试试下面这样的:
vtkNew<vtkRenderWindow> renWin;
renWin->AddRenderer(renderer0);
renWin->AddRenderer(renderer1);
renWin->SetSize(640, 480);
renWin->SetWindowName("XXXX");
PS: vtkNew和vtkSmartPointer和指针形式的区别:
vtk早期版本并没有集成C++,所以只有指针形式的创建对象,类似:
vtkPoints *points= vtkPoints::New();
没有类的概念,所以需要手动释放
points->Delete();
新版本逐渐集成了C++的智能指针,不需要手动释放。
VTK中的智能指针类为vtkSmartPointer,继承自vtkSmartPointerBase,可以看到是一个类模板。
vtkSmartPointer中定义了静态函数New(),调用构造函数生成一个智能指针对象。
vtkSmartPointer构造函数拿到对象后,用来初始化父类vtkSmartPointerBase。
可以看到vtkSmartPointerBase初始化时,用Register()来增加引用计数加1,相应的析构时再去调用unRegister进行减1,
后面又提供了vtkNew模板类,
功能和vtkSmartPointer一样,都是智能指针,不过更加轻量,推荐在局部变量使用,全局还是建议用vtkSmartPointer。
ps:
vtk的vtkSmartPointer保证你只要在各个地方都用这个智能指针创建对象,就不会有内存泄漏。
vtkSmartPointer可以理解成STL的std::shared_ptr但是又不同。
vtkSmartPointer的引用计数器变量存储在被管理的动态对象里,而std::shared_ptr所管理的动态对象不负责引用计数,引用计数是std::shared_ptr自己的责任,std::shared_ptr通过复制控制来实现引用计数。