草庐IT

ofstream_ptr

全部标签

c++ - 关于 boost::shared_ptr 赋值的问题(相对于 reset() 函数)

很抱歉,如果这在某个地方得到了明确的回答,但我对我在网上阅读的boost文档和文章感到有些困惑。我看到我可以使用reset()函数释放shared_ptr中的内存(假设引用计数变为零),例如,shared_ptrx(newint(0));x.reset(newint(1));我相信这会导致创建两个整数对象,并且在这两行的末尾,等于零的整数将从内存中删除。但是,如果我使用以下代码块会怎样:shared_ptrx(newint(0));x=shared_ptr(newint(1));显然,现在*x==1是真的,但是原始整数对象(等于零)会从内存中删除还是我泄漏了内存?在我看来,这可能是赋值

c++ - 如何使用以 std::weak_ptr 为键的 std::map?

如何使用std::weak_ptr作为std::map的关键如下代码所示?#include#includeintmain(){std::map,bool>myMap;std::shared_ptrsharedptr(newint(5));std::weak_ptrweakptr=sharedptr;myMap[weakptr]=true;return0;}上面的程序没有构建,尝试编译它会给出许多错误消息,例如:1>C:\ProgramFiles(x86)\MicrosoftVisualStudio10.0\VC\include\xfunctional(125):errorC2784:'

c++ - 我是否必须使用 weak_ptr.lock() 来测试它是否指向有效对象?

创建一个临时的shared_ptr只是为了查看weak_ptr是否指向一个有效的对象似乎有点低效。我什至不想访问该对象。这是因为我有一个从shared_ptrvector返回weak_ptr的函数,如果它返回一个空的weak_ptr那么这意味着该对象不存在该GUID。所以我只是在测试一个对象是否存在。有没有另一种方法可以在不创建shared_ptr的情况下检查weak_ptr是否为空? 最佳答案 您可以使用expired()成员函数。 关于c++-我是否必须使用weak_ptr.lock

c++ - 在没有 std::move 的情况下如何按值返回 unique_ptr?

这个问题在这里已经有了答案:Returningunique_ptrfromfunctions(7个答案)关闭8年前。std::unique_ptrptr(){std::unique_ptrp(newint(3));returnp;//Whydoesn'tthisrequireexplicitmoveusingstd::move?}//Whydidn'tthedatapointedtoby'p'isnotdestroyedherethoughpisnotmoved?intmain(){std::unique_ptra=ptr();//Whydoesn'tthisrequirestd::m

c++ - 为什么将 'ifstream' 和 'ofstream' 添加到 "std"中,而 'fstream' 可以同时满足这两个目的?

使用std::fstream可以声明ifstream和ofstream两种类型的对象。唯一的区别是,对于fstream,我们需要提供in、out、app作为参数,这可能并不总是需要其他两个。ifstream,ofstream有什么特别之处是fstream无法实现的,或者只是为了方便编码? 最佳答案 这有点像问为什么我们想要const无论如何你都可以从变量中读取和写入。它允许编译时检查,这是减少错误的一项非常宝贵的功能。它也更加self记录,因为在没有调用构造函数的情况下查看声明时,您可以看到它是输入、输出还是两者兼而有之:您提到的参

c++ - shared_ptr 和循环引用

我尝试使用boost::shared_ptr的循环引用,并设计了以下示例:classA{//Trivialclasspublic:i32i;A(){}A(i32a):i(a){}~A(){coutchangeI(shared_ptrs){s->i++;coutp1=make_shared(3);shared_ptrp2=p1;shared_ptrp3=p2;shared_ptrp4=p3;p1=p4;//1)1stcyclicref.cout哪些输出454~A:4是不是我误解了boost::shared_ptr中提到的循环引用?因为,在注释1)和2)之后,我期望对p1的间接引用的不同输

c++ - boost 序列化 std::unique_ptr 支持

boost序列化库支持std::unique_ptr的序列化吗?我试图编译下面的代码,但如果我包含boost::archive::text_oarchiveoa(ofs);oa行,编译器(顺便说一句,带有-std=c++11标志的gcc4.7)抛出一个错误/usr/include/boost/serialization/access.hpp:118:9:错误:‘classstd::unique_ptr’没有名为‘serialize’的成员#include#include#include#include#includeclassMyDegrees{public:voidsetDeg(in

c++ - 使用 boost shared_ptr

我必须使用智能指针,我发现来自boost的“shared_ptr”看起来不错。我下载了boost库,在那里我可以看到很多文件和库。有没有办法只使用shared_ptr? 最佳答案 boostbcp是你的friend。它允许从它的树中提取单独的boost库。我过去成功地使用了它。shared_ptr仅包含header,因此这对您特别有用。 关于c++-使用boostshared_ptr,我们在StackOverflow上找到一个类似的问题: https://st

c++ - shared_ptr 到数组

如何动态分配shared_ptr将指向的“n个元素”?我能够创建一个共享指针将指向的静态数组,但我希望用户输入一个数字,然后分配n个元素。shared_ptrp=make_shared(); 最佳答案 你应该像那样创建那个shared_ptrstd::shared_ptrsp(newint[10],std::default_delete());你必须给其他删除器shared_ptr您不能使用std::make_shared,因为该函数只提供1个参数,要在数组上创建指针,您还必须创建删除器。或者你也可以使用(比如在注释中,使用数组或v

c++ - std::tr1 中的 shared_ptr

我正在使用gcc编译器的平台上工作,但是boost无法在其上编译。我想知道在gcc的std:tr1中包含shared_ptr的正确方法是什么?我查看的文件说不直接包含它,据我所知没有其他文件包含它:| 最佳答案 在G++4.3中,#include应该可以解决问题。您将在std::tr1::shared_ptr找到shared_ptr。 关于c++-std::tr1中的shared_ptr,我们在StackOverflow上找到一个类似的问题: https://