草庐IT

shared-libraries

全部标签

c++ - 我可以在不更改 use_count 的情况下将 shared_ptr<T> & 转换为 shared_ptr<T const> & 吗?

我有一个使用boost::shared_ptr的程序s,特别是依赖于use_count的准确性执行优化。例如,假设一个加法运算有两个参数指针lhs和rhs。假设他们都有类型shared_ptr.当需要执行加法时,我会检查use_count,并且如果我发现其中一个参数的引用计数恰好为1,那么我将重新使用它来就地执行操作。如果两个参数都不能重用,我必须分配一个新的数据缓冲区并执行异地操作。我正在处理庞大的数据结构,因此就地优化非常有用。因此,我永远无法复制shared_ptr没有理由,即每个函数都采用shared_ptrs通过引用或const引用以避免扭曲use_count.我的问题是:我

c++ - 从 C++ 拦截 Fortran STOP

我准备了一个旧版Fortran库的C++接口(interface)。遗留库中的一些子例程遵循丑陋但可用的状态代码约定来报告错误,我使用此类状态代码从我的C++代码中抛出一个可读的异常:它工作得很好。另一方面,有时遗留库调用STOP(终止程序)。即使病情是可以恢复的,它也经常这样做。我想从C++中捕获这个STOP,到目前为止我还没有成功。下面的代码很简单,但恰好代表了手头的问题:Fortran遗留库fmodule.f90:modulefmoduleuseiso_c_bindingcontainssubroutinefsub(x)bind(c,name="fsub")real(c_doub

c++ - std::static_pointer_cast 与 static_cast<std::shared_ptr<A>>

我有一个类层次结构,其中B源自A像这样:classA:publicstd::enable_shared_from_this{};classB:publicA{voidf(){//thecodebelowcompilesstd::shared_ptrcopyOfThis=std::static_pointer_cast(shared_from_this());//thecodebelowdoesnotstd::shared_ptrcopyOfThis=static_cast>(std::make_shared(shared_from_this()));}};所以实际上我想了解为什么我不能

深入浅出 testing-library

我们是袋鼠云数栈UED团队,致力于打造优秀的一站式数据中台产品。我们始终保持工匠精神,探索前端道路,为社区积累并传播经验价值。本文作者:佳岚Themoreyourtestsresemblethewayyoursoftwareisused,themoreconfidencetheycangiveyou.您的测试越接近软件的使用方式,它们就越能给您带来信心。什么是testing-library?在了解testing-library前,我们可以看看使用原生方法是如何进行React组件测试的。importHeaderfrom".."importclientfrom'react-dom/client'i

c++ - shared_ptr 会自动释放内存吗?

我需要在这里使用shared_ptr,因为我无法更改API。Foo1*foo1=newFoo1(...);shared_ptrfoo2(foo1);这里的shared_ptr是否要处理释放foo1使用的内存?如果我理解正确,我不应该在foo1上调用delete,对吗? 最佳答案 是的。你是对的,但是初始化的正确方法foo2是:std::shared_ptrfoo2=std::make_shared();HerbSutter讨论了您应该使用std::make_shared()的原因这里:https://herbsutter.com/2

c++ - std::shared_ptr 的唯一拷贝

我有一个对象(我们称它为X),其他对象可以通过std::shared_ptr访问它。然而,在某些时候,这些对象需要创建一个唯一的、非共享的X拷贝,因为它想要修改它。这在某种程度上类似于写时复制,但由于一些其他细节而不完全相同。基本上我想要这样的语义:structFoo{std::shared_ptrbar;voidgo(){//bar.use_count()>=1bar.make_this_object_unique();//bar.use_count()==1}} 最佳答案 如果你只是想复制对象,并得到一个指向新对象的共享指针,那

c++ - 如何在编译时检测类型是否为 shared_ptr

我想获得一种模板化的方法来查找类型是否为shared_ptr,并基于此我想对函数进行新的特化。示例主要功能是,templateinlinevoidCEREAL_LOAD_FUNCTION_NAME(RelaxedJSONInputArchive&ar,NameValuePair&t){std::cout如果t.value是shared_ptr那么我想要一个不同的函数特化。我已经在下面尝试过,templateinlinetypenamestd::enable_if::value,void>::typeCEREAL_LOAD_FUNCTION_NAME(RelaxedJSONInputAr

c++ - shared_ptr<T[]> 包装动态数组的问题

我想用std::shared_ptr替换我类(class)中的一些原始指针这样我在创建该类的拷贝时就不必担心了。但是原始指针指向一个动态数组。当你给它一个自定义删除器时,使用带有动态数组的shared_ptr是可能的,例如。G。default_delete.但是当我尝试为该字段分配一个新值时,我会得到一个很大的错误列表,即使是在构建时也是如此。这是一个最小的代码示例:#include#includeusingnamespacestd;templateshared_ptrmake_shared_array(size_tsize){returnshared_ptr(newT[size],d

c++ - 即使正确使用 make_shared,shared_from_this() 也会导致 std::bad_weak_ptr

我正在使用独立的Asio和C++11创建一个C++服务器应用程序,但遇到错误,这就是我寻求帮助的原因。错误在类里面worker_thread,在通话期间shared_from_this(),一个bad_weak_ptr引发异常,导致程序崩溃。布局类(class)connection_manager创建并存储std::shared_ptr类型的对象在std::vector里面容器类(class)worker_thread继承自std::enable_shared_from_this.类(class)worker_thread创建std::shared_ptr类型的对象.类(class)c

c++ - 如何在 Unix TeamCity 构建代理上设置环境变量 PATH 和 LD_LIBRARY_PATH?

我使用TeamCity在Unix(Solaris)上构建C++。TeamCity调用make,在我的makefile中我需要调用svn。为此,我需要修改PATH和LD_LIBRARY_PATH。我可以在makefile中设置这些,但位置因服务器而异。有谁知道为每个TeamCity构建代理设置这些的方法,例如通过编辑conf/buildAgent.properties?我可以在~/.login等中为TeamCity构建帐户设置它们,但我不希望这样做,因为它是一个共享帐户。-谢谢,巴尼 最佳答案 如您所料,您可以在conf/buildA