草庐IT

auto_ptr_ref

全部标签

c++ - 你能初始化 unique_ptr 的 "static const vectors"吗? (C++17 与 GCC 7.3)

我正在尝试创建一个staticconst默认对象(规则)的列表太大而不能经常复制,因此我想将它们存储在vector中的unique_ptr.我注意到类似的问题已经进行了几次,但我不清楚这是否真的可行(我倾向于不可行)。即你不能使用initializer_list与unique_ptr因为对成员的访问是const导致复制操作。您不能通过引用传递临时变量,从而导致复制操作。因此两者:staticconststd::vector>kStrings={std::unique_ptr(newstd::string("String1")),std::unique_ptr(newstd::strin

c++ - std::unique_ptr 取得所有权前的测试

我有一个类,它基本上是一个队列,用于在2个线程之间传输动态分配的对象。第一个线程创建对象,第二个线程使用它们。我使用std::unique_ptr将对象所有权从线程1传递到线程2。实际上调用将对象放入队列的方法是这样的:queue.put(std::move(unique_ptr_to_my_object));和签名:boolQueue::put(std::unique_ptrp);问题是put()方法必须检查一些条件来决定是否可以将对象添加到队列中。如果条件为假,则该方法简单地返回false以指示它无法将对象添加到队列中,但该对象已被销毁,因为所有权已被put()获取。所以我想知道这

c++ - 在包含 shared_ptr 的 map 上使用 find_if 会增加引用计数

我正在创建一个程序,它有一个包含shared_ptr的映射。当我尝试使用std::find_if在其中查找元素时,shared_ptr的引用计数会增加。示例:#include#include#include#includeintmain(void){std::map>map;map[1]=std::make_shared(3);map[2]=std::make_shared(5);map[4]=std::make_shared(-2);autoit=std::find_if(map.begin(),map.end(),[](conststd::pair>&elem){std::cout

c++ - 如何在 C++11 中返回包含自定义删除器的 std::unique_ptr?

我的应用程序编译器最多只能支持c++11。下面是我的项目和函数get_conn()的片段代码返回std::unique_ptr和自定义删除器(删除器需要两个参数)。我正在使用auto关键字作为返回类型,但它给出了一个错误,就像ifiscompiledwithc++11(compilesfinewithc++14)error:‘get_conn’functionuses‘auto’typespecifierwithouttrailingreturntype演示示例代码:#include#include#includeusingnamespacestd;//Dummydefinitiono

c++ - auto_ptr 会防止这种情况发生吗?

我不太清楚auto_ptr在这种情况下是否会帮助我:classA{A(constB&member):_member(B){};...constB&_member;};AgenerateA(){auto_ptrsmart(newB());AmyA(*smart);returnmyA;}当smart离开其封闭范围时,myA._member引用是否有效?如果auto_ptr不是这里的答案,那是什么?编辑:我看到我把每个人都弄糊涂了;我必须在范围外返回myA,这就是为什么我关心_member在smart退出范围后是否有效。 最佳答案 这对你

c++ - 如何在 C++ 中将 const ref a 返回给局部变量?

我有一个无法更改函数参数的函数。我需要返回对在此函数中创建的std::string的const引用。我尝试使用boostshared_ptr,但这不起作用。为什么?我该如何进行这项工作?conststd::string&getVal(conststd::string&key){boost::shared_ptrretVal(newstd::string());...//buildretValstringwith+=operatorbasedonkeyreturn*retVal;} 最佳答案 您不能使用C++从函数返回对局部变量的引用

c++ - 在 GCC 中使用 shared_ptr 的可移植方式

GCC4.1使用header和GCC4.3使用header,我需要一种可移植的方式来使用shared_ptr使用GCC4.3.2和GCC4.2.1,有没有办法在不检查GCC版本宏或使用外部库(如Boost)的情况下做到这一点? 最佳答案 仍将与gcc4.3一起工作。如果您想同时支持这两个版本,只需使用tr1姓名。 关于c++-在GCC中使用shared_ptr的可移植方式,我们在StackOverflow上找到一个类似的问题: https://stackove

c++ - weak_ptr 和父子循环依赖

我目前有类似以下内容:classParent{//justasinglechild...forsakeofsimplicity//nootherclassholdsashared_ptrreferencetochildshared_ptr_child;System*getSystem(){...}}classChild{weak_ptr_parent;~Child{_parent.lock()->getSystem()->blah();}}Child析构函数总是崩溃,因为当~Child()运行时_parent总是过期。是否有针对这种怪现象的典型解决方案?简而言之,有没有办法在~Chil

c++ - boost::ref 和 boost::asio 完成处理程序,按引用传递

m_io_service.post(boost::ref(i));我在一段代码中有这个调用,底层类型i绝对是一个可调用的(因为删除boost::ref导致按值传递,这工作正常),但是clang告诉我:/opt/dev_64_swat/proto-rpc2/dependencies/boost/include/boost/asio/handler_invoke_hook.hpp:64:3:error:type'boost::reference_wrapper'doesnotprovideacalloperator我如何通过引用传递,我有比异步调用生命周期更长的对象,如果我可以通过引用传递

【C++】基础知识讲解(引用、内联、auto,基于范围for循环)

 🌈个人主页:秦jh__https://blog.csdn.net/qinjh_?spm=1010.2135.3001.5343🔥 系列专栏:http://t.csdnimg.cn/eCa5z目录引用概念特性使用场景作参数作返回值传值、传引用效率比较引用和指针的区别内联函数概念查看方式特性 宏的优缺点 C++代替宏的技术前言    💬hello!各位铁子们大家好哇。       今日更新了引用、内联、auto,基于范围for循环的内容    🎉欢迎大家关注🔍点赞👍收藏⭐️留言📝引用概念引用不是新定义一个变量,而是给已存在变量取了一个别名,编译器不会为引用变量开辟内存空间,它和它引用的变量共用同