C++11 std::shared_ptr<std::ostream> from std::cout
C++11 std::shared_ptr<std::ostream> from std::cout
我在std::shared_ptr<std::ostream>
中存储std::cout
时遇到问题。
既然这显然不应该这样做:
std::shared_ptr<std::ostream> p_cout(&std::cout);
这是不可能的,因为不可能复制std::ostream:
std::shared_ptr<std::ostream> p_cout = std::make_shared<std::ostream>(std::cout);
有人知道法律上的变通办法吗?
您的要求很奇怪,但您当然可以将指向std::ostream
的指针存储在shared_ptr<std::ostream>
中。如果您提供了适当的处理器操作:例如:std::shared_ptr<std::ostream>(&std::cout, [](void*) {});
这显然是不应该做的:
std::shared_ptr<std::ostream> p_cout(&std::cout);
事实上,永远不应该这样做。原因是你没有std::cout
的所有权,因此当你的最后一个shared_ptr
超出范围时,它会试图删除std::cout
(这显然是邪恶的)。但你已经知道了。
如果您必须绝对使用shared_ptr
(我认为这是API兼容性的问题),那么解决方案是使用一个什么都不做的自定义deleter:
shared_ptr<std::ostream> p_cout(&std::cout, [](std::ostream*){});
shared_ptr将获得您给它的指针的所有权。这意味着您的程序最终将尝试删除std::cout(当初始shared_ptr的最后一个副本超出范围时)。这不是你想做的事。
由于您不需要控制std::cout的生存期,因此可以简单地传递std::ostream原始指针或引用。
相关文章:
- 使用std::multimap迭代器创建std::list
- C++中std::resize(n)和std::shrink_to_fit之间的区别
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 如何导出包含具有"std::unique_ptr"值的"std::map"属性的
- 从持续时间构造std::chrono::system_clock::time_point
- std::具有相同基类的类的变体
- std::向量与传递值的动态数组
- 使用std::vector的OpenCL矩阵乘法
- std::map<struct,struct>::find 找不到匹配项,但是如果我循环通过 begin() 到 end(),我在那里看到匹配项
- std::condition_variable::wait()如何评估给定的谓词
- 如何获取std::result_of函数的返回类型
- std::原子加载和存储都需要吗
- 将对象移动到std::shared_ptr
- std::vector<;uint8_t>;当C++11/14启用时,手动复制而不是调用memcpy
- 是std :: set&lt; std :: future&gt;不可能存在
- 在修改列表后,std :: list&lt; t&gt; :: end()的值是否会更改
- 使用 std::vector<boost::shared_ptr<Base_Class>> 或 boost::p tr_vector 的性能注意事项是什么<Base>
- std::map<std::set, double> AND std:<long>map< std::p air<long, long>, double>
- 如何获取std::vector<DMatch>