草庐IT

shared-hosting

全部标签

c++ - 如何为 std::vector 创建一个 shared_ptr?

我需要为std::vector创建一个shared_ptr,正确的语法是什么?std::vectormVector;shared_ptr>mSharedPtr=&mVector;上面的代码无法编译。谢谢。 最佳答案 你要做的是让一个智能指针管理一个栈对象。这是行不通的,因为堆栈对象在超出范围时会自行终止。智能指针无法阻止它这样做。std::shared_ptr>sp;{std::vectormVector;sp=std::shared_ptr>(&mVector);}sp->empty();//danglingreference,a

c++ - 将 'this' 转换为 std::shared_ptr

我在类上有一个方法可以使特定实例成为“事件”实例:voidmakeActive(){activeInstance=this;}但是自activeInstance起它就不起作用了。类型为std::shared_ptr.我怎么投this至std::shared_ptr? 最佳答案 如果您的对象已经被一个shared_ptr拥有,您可以通过让您的对象继承自std::enable_shared_from_this来生成另一个shared_ptr此代码将起作用:voidmakeActive(){activeInstance=shared_fr

修改hosts文件,提高访问github的速度(github外网的登录问题)

修改hosts文件,提高访问github的速度1,查询github的ip(网址ip、域名、静态ip)●github的网址ip查询:网站:GitHub.com-GitHub:Let'sbuildfromhere·GitHub●github域名查询:网站:在Fastly.net-Theedgecloudplatformbehindthebestoftheweb|Fastly●github静态ip查询:网站:https://github.com.ipaddress.com/assets-cdn.github.com我查询的结果是: 2,修改host文件:路径:C:\Windows\System32\

解决requests.exceptions.ProxyError: HTTPSConnectionPool(host=‘api.github.com‘, port=443): Max retries

一般来说,出现这种错误的原因可能是以下之一:代理设置错误:你的计算机或网络环境可能配置了代理服务器,但代理服务器设置可能不正确。你需要检查你的代理设置是否正确,并确保它们与你的网络环境相匹配。代理服务器不可用:如果代理服务器无法访问或不可用,你可能会遇到这个问题。确保代理服务器正常运行,并且你可以连接到它。网络连接问题:如果你的计算机或网络连接存在问题,可能会导致这个错误。确保你的网络连接正常,没有任何问题。解决办法:控制面板->Internet选项->连接->局域网设置->代理服务器取消勾选

c++ - 如何将 Boost::shared_ptr<T> 暴露给 Tcl + SWIG 接口(interface)文件?

我想使用SWIG将boost::shared_Ptr暴露给Tcl层。但目前我不知道我可以公开这个。我发现SWIG/Lib文件夹包含shared_ptr.i的接口(interface)文件。但是在内容中我发现不能直接使用。它必须包含在“boost_shared_ptr.i”之后。但是在“SWIG/Lib/tcl”文件夹中没有像boost_shared_ptr.i这样的东西,但我们有类似的接口(interface),我可以将其包含在Java中。 最佳答案 当我上次尝试时,所有SWIG都没有对boost/shared_ptr提供很好的支持

c++ - 模板 shared_ptr 参数

我收到此代码的编译器错误:#include#includestructName{};typedefboost::shared_ptrNamePtr;structFoo{NamePtrname;};typedefboost::shared_ptrFooPtr;templatevoidsetName(Titem,NamePtrname=boost::make_shared()){item->name=name;}intmain(){FooPtrfoo=boost::make_shared();setName(foo);return0;}如下:main.cpp:errorC2780:'boo

c++ - LLVM 即时编译 : pass C++ exception through JIT code back to host application

我正在开发一个项目,我使用clang生成一些LLVMIR,然后在我的主机应用程序中进行JIT编译和运行。JIT代码调用宿主应用程序中的某些函数可能会引发异常。我希望通过JIT代码抛出异常并在主机应用程序中捕获。据我所知,这应该与LLVM一起使用,但不幸的是,我的测试应用程序总是因“在抛出‘int’实例后调用终止”而崩溃。让我举个简单的例子。我使用clang3.5将以下简单程序编译成LLVMIR:externvoidtest();extern"C"voidexec(void*){test();}与./clang-O0-S-emit-llvmtest.cpp-c结果为test.ll;Mod

c++ - shared_ptr 的静态成员函数 make_shared

使用libc++我在公共(public)部分找到了std::shared_ptr::make_shared()静态成员函数。当我已经为std::shared_ptr的特化定义了类型别名时,这非常方便:usingT=int;usingP=std::shared_ptr;autop=P::make_shared(123);//std::make_shared(123)static_assert(std::is_same::value);我担心标准合规性,因为来自可信来源的文章(1,2)没有提到std::shared_ptr的静态成员函数make_shared>.目前使用该功能是否不好?为什

c++ - enable_shared_from_this 和 make_shared 是否提供相同的优化

据我了解make_shared(...)可以提供一些内存分配优化(它可以在与类T的实例相同的内存块内分配引用计数器)。enable_shared_from_this是否提供相同的优化?所以:classT:std::enable_shared_from_this{};...autot=std::shared_ptr(newT);等同于:classT{};...autot=std::make_shared();如果不考虑sizeof(T)。 最佳答案 Doenable_shared_from_thisprovidesthesameopt

C++ 使用 C++11 (std::shared_ptr) 分配 shared_ptr:将 shared_ptr 初始化为临时变量是否仍然不好?

我正在阅读thisanswer作者指的是boostbestpractices其中说:Avoidusingunnamedshared_ptrtemporariestosavetyping;toseewhythisisdangerous,considerthisexample:voidf(shared_ptr,int);intg();voidok(){shared_ptrp(newint(2));f(p,g());}voidbad(){f(shared_ptr(newint(2)),g());}Thefunctionokfollowstheguidelinetotheletter,wher