草庐IT

ofstream_ptr

全部标签

php - 使用 SWIG 在 PHP 中包装 boost::shared_ptr

如果我使用SWIG包装这个C++函数:boost::shared_ptrClient::create(){returnboost::shared_ptr(newClient());}然后在PHP中调用它:$client=Client::create();echogettype($client);$client的类型是resource,不是object,所以我不能调用Client方法。包装此功能的选项有哪些?我正在为其他人的C++库创建一个PHP包装器,因此重新编写代码以不使用boost::shared_ptr并不是一个真正的选择。这是迄今为止我想出的唯一解决方案:MyClientCli

c++ - std::shared_ptr 什么时候释放它的对象?

我在使用GCC4.8.4的Ubuntu14.04上,我的代码类似于以下内容:std::shared_ptrmy_shared_object=setelsewhere...MyFunction(*my_shared_object);MyFunction的签名如下所示:voidMyFunction(constMyClass&my_object)可以找到完整的代码here但是,我发现my_object实际上超出了MyFunction上下文中的范围。我的想法是my_shared_object只有在超出范围后才会释放其内容,这意味着在MyFunction返回之后。我不确定我是否误解了std::s

c++ - 将派生类的 unique_ptr 添加到基类 unique_ptr 的 vector 中

关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭6年前。Improvethisquestion我有一个std::unique_ptr我想添加到std::vector>.std::unique_ptrderivedObject;std::vector>vec;vec.push_back(derivedObject)//Invalidarguments

c++ - 这是对 unique_ptr 的误用吗?

我正在转向智能指针,并努力确保正确使用它们。有很多问题涵盖了何时使用每个问题,但我找不到专门关于getter的问题。我有一个拥有指针的类,我希望其他类能够访问该指针(逐步重构遗留代码)。我想给这个类一个unique_ptr因为它只会拥有那个对象,但它们不能被复制。我应该返回对unique_ptr的引用,还是只使用shared_ptr?classB{public:doAction(){};};classA{private:std::unqiue_ptrpointer;public:std::unique_ptr&GetPointer(){returnpointer;}};a.GetPoi

c++ - 制作 shared_ptr 的拷贝时会发生什么?

我想了解当将shared_ptr分配给另一个时,shared_ptr中托管对象的引用计数会受到怎样的影响。我在C++primer,5thedition中看到以下声明:Forexample,thecounterassociatedwithashared_ptrisincrementedwhen...weuseitastheright-handoperandofanassignment...Thecounterisdecrementedwhenweassignanewvaluetotheshared_ptr...举个例子:autop=make_shared(42);//objecttowh

c++ - 如何深度复制 unique_ptr 的 vector

我有一个带有数据成员的容器类。std::vector>Functions;我想在我的复制构造函数中做一个深拷贝,我怎样才能做一个std::unique_ptr的深拷贝。 最佳答案 std::vector>copiedFunctions;std::for_each(Functions.begin(),Functions.end(),[&](std::unique_ptrf){copiedFunctions.push_back(std::make_unique(*f));}));这意味着Sum_Function当然有一个复制构造函数。

c++ - 为什么我可以在临时 std::ofstream 对象上使用 `operator<<`?

根据C++标准,您不能将临时变量绑定(bind)到非常量引用。由于流输出操作符定义为templatestd::basic_ostream&operator&os,conststd::basic_string&str);我希望它不能在临时流对象上调用。然而,我尝试了以下并得到了意想不到的结果#includestd::ostream&print(std::ostream&stream){stream这在GCC主干、Clang主干和MSVC19上编译。我什至在前两个上尝试了-pedantic-errors。虽然从技术上讲这三者都错了,但我很可能误解了什么。有人可以在标准中找到关于这是否合法的

c++ - 分配给 shared_ptr,有没有办法做到这一点?

有没有办法首先用nullptr初始化shared_ptr并在一段时间后将指向类的指针赋值给它?//pseudocodestd::shared_ptrptr(nullptr);//andlaterptr->assign(newMyClass); 最佳答案 你在寻找ptr.reset(newMyClass)吗? 关于c++-分配给shared_ptr,有没有办法做到这一点?,我们在StackOverflow上找到一个类似的问题: https://stackover

c++ - 如何将 std::unique_ptr<> 从一个 STL 容器移动到另一个?

问题我有一个模板容器MyContainer>它有一个std::deque和一个std::vector成员(member)。内部方法,send_to_purgatory_if(predicate),我想查看m_taskdq中的所有项目并从m_taskdq移动项目至m_purgatory,如果谓词的计算结果为真。问题我有两个问题正在努力解决:我的迭代器it如果我从循环内从m_taskdq中删除项目,则会被丢弃我很担心std::unique_ptr的状态如果我分两步进行移动(问题第1行和第2行-通过第2行,我认为std::unique_ptr指向的it未定义?)我应该如何修复此代码?temp

c++ - 流畅的接口(interface)模式和 std::unique_ptr

我正在玩fluentinterface模式。首先,我写了这样的东西:classC{public:C(){}C*inParam1(intarg1){param1=arg1;returnthis;}C*inParam2(intarg2){param2=arg2;returnthis;}private:intparam1;intparam2;}然后我尝试使用std::unique_ptr,但后来我意识到我不知道如何沿着链“移动”指针(this)。我试过类似的东西:returnstd::move(this);那当然不行。我该怎么做?这样做有什么问题吗?为了回复诸如“不要使用指针”之类的评论:(