std::shared_ptr
调查围绕着 std::shared_ptr
<code class="cpp">#include <memory> #include <iostream> #include <vector> int main() { std::cout << "At begin of main.\ncreating std::vector<std::shared_ptr<void>>" << std::endl; std::vector<std::shared_ptr<void>> v; { std::cout << "Creating test" << std::endl; v.push_back(std::shared_ptr<test>(new test())); std::cout << "Leaving scope" << std::endl; } std::cout << "Leaving main" << std::endl; return 0; }
代码显示以下输出:
At begin of main. creating std::vector<std::shared_ptr<void>> Creating test Test created Leaving scope Leaving main Test destroyed</code>
理解类型擦除
此行为的关键在于 std::shared_ptr 执行的类型擦除。当初始化一个新实例时,std::shared_ptr 存储一个内部删除器函数。默认情况下,该函数在销毁shared_ptr 时调用delete 运算符。此机制可确保在适当的时间调用所指向对象的析构函数,无论shared_ptr 的类型如何。
强制转换的结果
强制转换 std ::shared_ptr;到 std::shared_ptr
标准合规性和未来影响
关于此技术的保证行为,至关重要请注意,std::shared_ptr 的内部实现可能因不同的编译器和平台而异。虽然类型擦除一直是shared_ptrs的一个基本方面,但未来对其实现的更改可能会影响所描述的功能。
因此,不建议仅依赖此行为,并且应在生产代码中避免这种做法。相反,替代方法(例如使用 std::function 或自定义删除器类)更加健壮,并且将在各种实现中提供一致的行为。
以上是尽管类型擦除,“std::shared_ptr”如何保留对象销毁行为?的详细内容。更多信息请关注PHP中文网其他相关文章!