草庐IT

c++ - `weak_ptr` 和 `shared_ptr` 访问如何是原子的

std::shared_ptrint_ptr;intmain(){int_ptr=std::make_shared(1);std::threadth{[&](){std::weak_ptrint_ptr_weak=int_ptr;autoint_ptr_local=int_ptr_weak.lock();if(int_ptr_local){cout上面的代码线程安全吗?我读了这个答案Aboutthread-safetyofweak_ptr但只是想确保上面的代码是线程安全的。我问这个的原因是,如果上面的代码确实是线程安全的,我无法理解std::weak_ptr是如何实现的。和std::s

c++ - 通过采用 void * 的 C 接口(interface)传递 shared_ptr

我有一个使用SDL的C++项目,特别是SDL事件。我想将事件系统用于传入的网络消息,就像它用于UI事件一样。我可以定义一个新的事件类型并附加一些任意数据(参见thisexample)。如果我使用普通指针,这就是我会做的:Uint32message_event_type=SDL_RegisterEvents(1);/*Inthemaineventloop*/while(SDL_Poll(&evt)){if(evt.type==message_event_type){Message*msg=evt.user.data1;handle_message(msg);}}/*Networkingc

c++ - "Use of undefined type"带有 unique_ptr 以转发声明的类和默认移动构造函数/赋值

在下面的代码中,是避免编译错误并在A.cpp中手动包含B.h实现移动构造函数/赋值的唯一方法吗?//A.h#includeclassB;//implementationsomewhereinB.h/B.cppclassA{public:A()=default;~A()=default;A(constA&)=delete;A&operator=(constA&)=delete;A(A&&)=default;A&operator=(A&&)=default;private:std::unique_ptrm_b;};VisualStudio2015给出“错误C2027:使用未定义类型”,因为

java - C++0x - lambda 表达式看起来与 Java 的匿名内部类一样吗?

我在C++和Java上下文中对lambda表达式的解释是否正确? 最佳答案 它们并不完全相同。两者都创建未命名的类,但它们的相似性到此为止。在C++中,您创建一个闭包来捕获您的局部变量,可选地通过引用。在Java中,您只需获取当前局部变量值的快照(并且这些变量需要是“最终的”)。匿名内部类的目的是扩展另一个类或临时实现另一个接口(interface)。因此,匿名内部类可以在某种程度上模拟lambda表达式的工作,例如通过实现Runnable接口(interface)。Lambda表达式专门设计用于在其环境中调用并可能修改局部变量。

c++ - std::unique_ptr 删除函数,initializer_list - 驱动分配

全部,当我使用初始化列表格式实例化小部件数组时,指向成员变量小部件实例的裸指针可以编译,但在更改为std::unique_ptr后,gcc会给出有关已删除函数的编译错误。$uname-aLinux..3.5.0-21-generic#32-UbuntuSMP2012年12月11日星期二18:51:59UTCx86_64x86_64x86_64GNU/Linux$g++--versiong++(Ubuntu/Linaro4.7.2-5ubuntu1)4.7.2此代码给出以下编译器错误:#include#includeclassWidget{public:Widget(){}};class

c++ - Boost 1.53 本地日期时间编译器错误 -std=c++0x

使用g++版本4.7.2,如果我尝试编译以下内容#includeclassBar{public:Bar(){tz_db_.load_from_file("/home/date_time_zonespec.csv");}private:boost::local_time::tz_databasetz_db_;};intmain(){return0;}使用-std=c++0x我得到以下错误。Infileincludedfrom/usr/local/include/boost/date_time/local_time/local_time_types.hpp:18:0,from/usr/lo

c++ - 为什么 observer_ptr 在 move 后不归零?

为什么不是observer_ptrmove操作后归零?它在默认构造中被正确设置为nullptr,这确实有意义(并防止指向垃圾)。相应地,当std::move()开始时,它应该被清零,就像std::string、std::vector等这将使它成为多个上下文中的一个很好的候选者,在这些上下文中,原始指针是有意义的,并且自动在具有原始指针数据成员的类上生成move操作,例如thiscase.编辑正如@JonathanWakely在评论中指出的(与aforementionedquestion相关):ifobserver_ptrwasnullafteramoveitcanbeusedtoimp

c++ - 通过取消引用复制 std::unique_ptr 的值

我写了下面的代码,我试图将unique_ptr对象的值复制到一个结构中。#include#includeusingnamespacestd;structS{S(intX=0,intY=0):x(X),y(Y){}//S(constS&){}//S&operator=(constS&){return*this;}intx;inty;std::unique_ptrptr;};intmain(){Ss;s.ptr=std::unique_ptr(newS(1,4));Sp=*s.ptr;//Copythepointer'svaluereturn0;}它在VisualC++2012中弹出错误:

c++ - "Connecting"SDL_Surface 到 shared_ptr

我想知道如何将SDL_Surface*与shared_ptr连接起来?在删除SDL_Surface之前,我需要调用SDL_FreeSurface(SDL_Surface*)。如何在shared_ptr中“修改删除过程”? 最佳答案 只需将SDL_FreeSurface传递给构造函数:std::shared_ptrshared_surf(SDL_LoadBMP("foo.bmp"),SDL_FreeSurface);请确保您不使用SDL_SetVideoMode或SDL_GetVideoSurface返回的指针执行此操作。

c++ - 如何在 Android NDK 中使用 c++0x 线程?

我正在尝试用android-ndk-r8b编译这个简单的程序:jni/hello_jni.cpp#include#includevoidhello(){std::coutjni/Application.mkAPP_OPTIM:=releaseAPP_MODULES:=hello_threadAPP_STL:=gnustl_staticjni/Android.mkLOCAL_PATH:=$(callmy-dir)include$(CLEAR_VARS)LOCAL_CPPFLAGS+=-std=c++0x-frttiLOCAL_MODULE:=hello_threadLOCAL_LDLIB