草庐IT

spe_context_ptr_t

全部标签

c++ - shared_ptr 不能为空?

使用std::shared_ptr表示共享所有权和可选性(可能为空)。我发现自己处于这样一种情况,我只想在我的代码中表达共享所有权,而没有任何选择权。当使用shared_ptr作为函数参数时,我必须让函数检查它是否不为null以保持一致/安全。在许多情况下,传递引用而不是当然是一种选择,但有时我也想转让所有权,因为可以使用shared_ptr。是否有一个类可以替换shared_ptr而不可能为空,是否有一些约定来处理这个问题,或者我的问题没有多大意义? 最佳答案 您正在请求not_null包装器类。幸运的是,C++专家已经解决了您的

c++ - 使用静态常量初始化 unique_ptr 时出现 undefined reference 错误

当我尝试使用staticconst来初始化unique_ptr时,我收到“undefinedreference”错误。然而,当我新建一个使用相同常量的指针时,符号似乎被神奇地定义了。这是一个重现错误的简单程序:Outside_library.hclassOutside_library{public:staticconstintmy_const=100;};main.cpp#include"Outside_library.h"#include#includeclassMy_class{public:My_class(intnum){m_num=num;};virtual~My_class

c++ - 在基于范围的 for 循环中使用 shared_ptr 到 std::vector

我编写了一个c++函数,它组装一些数据,然后将std::shared_ptr返回到新分配的包含数据的std::vector。类似于此的内容:std::shared_ptr>shared_ptr_to_std_vector_of_ints(){autov=std::make_shared>();for(inti=0;ipush_back(i);returnv;}我尝试使用基于范围的for循环遍历vector的内容,但它表现得好像vector是空的。在摆弄之后,我发现我可以通过将从函数返回的值分配给局部变量,然后在循环中引用它来让它按照我的预期运行://Executesloopzeroti

go 上下文:context.Context

Go语言中的上下文(Context)是一种用于在Goroutines之间传递取消信号、截止时间和其他请求范围值的标准方式。context包提供了Context类型和一些相关的函数,用于在并发程序中有效地传递上下文信息。在Go语言中,上下文通常用于以下场景:请求的传递:当一个请求从客户端发送到服务器时,可以使用上下文来携带与该请求相关的数据。这些数据可以是用户的身份信息、请求的元数据或其他与请求相关的信息。通过将上下文传递给处理该请求的goroutine,可以确保在整个处理过程中访问这些数据。取消操作:上下文可以用于取消正在进行的操作。当用户或其他代码发送取消信号时,可以将该信号传递给正在执行操

c++ - 未定义对 avcodec_alloc_context 的引用但 ffmpeg 链接器顺序正确吗?

我想构建静态链接到libavcodec和libavformat的静态链接可执行文件。静态ffmpeg库是用以下方法构建的:./configure--enable-static--enable-gpl--enable-nonfree--disable-vaapi--disable-libopus--prefix=myBuild--disable-swresample链接器设置如下:g++-O2-static-omyBinmyBin-myBin.osomeotherlibraries.a-L/ffmpeg/myBuild/lib-lavformat-lavcodec-lavutil-lrt

c++ - 如何统一初始化 unique_ptr 的映射?

我有这段代码可以将映射从into初始化为unique_ptr。autoa=unique_ptr(newA());map>m;m[1]=move(a);我可以使用统一初始化吗?我试过了map>m{{1,unique_ptr(newA())}};但是我得到了一个错误。错误信息的一部分是Ininstantiationof'std::_Rb_tree_node::_Rb_tree_node(_Args&&...)[with_Args={conststd::pair>>&};_Val=std::pair>]':...Infileincludedfrom/opt/local/include/gcc

c++ - std::function 和 shared_ptr

我使用Loki的Functor有一段时间了,最​​近我问了一个question关于它(仍然没有答案......)有人告诉我使用std::function,但我更喜欢Loki的Functor实现,因为它也可以使用各种指针作为参数(例如std::shared_ptr)。structToto{voidfoo(intparam){std::coutptr=std::make_shared();Loki::Functorfunc(ptr,&Toto::foo);func(1);}有没有办法用std::function做到这一点? 最佳答案 使

c++ - 为什么我不能从一对中返回一个 unique_ptr?

为什么我不能从一对中返回一个unique_ptr?#include#include#includeusingnamespacestd;unique_ptrget_value(){pair,int>p(unique_ptr(newint(3)),4);returnp.first;}intmain(void){cout当我尝试使用g++4.6编译它时,我得到:../main.cpp:Infunction‘std::unique_ptrget_value()’:../main.cpp:9:11:error:useofdeletedfunction‘std::unique_ptr::uniqu

c++ - std::bind std::shared_ptr 参数不会增加 use_count

以下代码:#include#include#includestructFoo{Foo():m_p(std::make_shared()){}Foo(constFoo&foo){printf("copy\n");}std::shared_ptrm_p;};voidfunc(Foofoo){}intmain(){Foofoo;std::functionf=std::bind(func,foo);printf("usecount:%ld\n",foo.m_p.use_count());f();}得到结果:copycopyusecount:1copy由于复制了Foo,所以我认为m_p的use_

c++ - 在 std::set 或 std::map 的键中使用 weak_ptr 是否安全

今天有很多关于std::weak_ptr和std::owner_less以及它们在关联容器std::set和std::map。有许多帖子指出在std::set中使用weak_ptr是不正确的,因为如果弱指针过期,它将是未定义的行为。这是正确的吗? 最佳答案 原因之一std::owner_lessexists是为了提供这种排序,并在存在过期弱指针的情况下保证其安全。我的逻辑是一、std::owner_less的定义operator()definesastrictweakorderingasdefinedin25.4undertheeq