草庐IT

shared-object

全部标签

c++ - boost::make_shared 导致访问冲突

我有一个用于ARMV4IWindowsMobile6的VisualStudio2008C++应用程序,我正在使用boost::shared_ptr管理一个相当大的对象(4KB)。不幸的是,boost::make_shared导致访问冲突异常。我的代码:structFoo{chara[4*1024-1];};int_tmain(intargc,_TCHAR*argv[]){boost::shared_ptrf=boost::make_shared();//AccessViolationreturn0;}异常调用栈:test.exe!boost::detail::sp_ms_deleter

C++ make_shared 不可用

虽然我有std::tr1::shared_ptr在我的编译器中可用,我不有make_shared.谁能告诉我如何正确实现make_shared?我懂了我需要使用可变参数来为T的构造函数提供参数。但我的编译器中也没有可用的可变参数模板。 最佳答案 如果您的编译器不提供make_shared的实现并且您不能使用boost,并且您不介意缺少针对对象和引用计数器的单一分配优化,那么make_shared是这样的:不支持可变参数模板://zeroargumentsversiontemplateinlineshared_ptrmake_shar

c++ - 什么是内存更昂贵。 "creating and deleting objects"还是 "reusing a object"?

很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visitthehelpcenter.关闭10年前。我有一个对象,每10秒在整个游戏过程中需要一个对象。我应该继续删除对象还是继续使用同一个对象?对象在所谓的“空闲时间”中位于何处?因为是手游,内存是个问题。所以,只是想知道哪种方法会富有成效。"creatinganddeletingobjects"?或"reusingaobject"?谢谢

c++ - 是否可以在运行时确定指针指向 C++ 类还是指向 Objective-C 类?

问题在主题中。我想编写一些用于安全删除对象的通用模板函数,想知道是否可以使用这样的函数:templatevoidSafeDelete(T*&pVal){if(objc_is_cpp_object(pVal)){deletepVal;pVal=NULL;}else[pValrelease]} 最佳答案 如评论中所述,我建议不要混合使用C++delete和Objective-Crelease。仅出于技术角度,您可以使用以下SFINAE技巧运行时:templatestructvoid_{typedefvoidtype;};template

C++/Objective-C++ - 如何在 NSDictionary 中存储 C++ 变量?

我有一个C++std::vector>类型的变量这是在C++中定义和填充的类(从我的Objective-C++类中调用。)我想将此对象存储在NSDictionary中-或某种等价物。我显然不能简单地添加std::vector>到NSDictionary因为它不是id类型.所以我的问题是:如何实现相同的概念?如何存储std::vector>在各种字典中?我可以将vector对象包装在id中吗?以某种方式输入?即使它不是直接字典,我可以使用另一种方法吗?我还需要它是可变的,这样我就可以在运行时添加键/对象。我看过std::map,但我不确定这是否是我要找的。我也没有发现任何关于它可变的例子

c++ - 如何创建boost phoenix make_shared?

是否可以创建std::make_shared的boostphoenix惰性变体?我的意思是,让类似的事情成为可能namespacep=boost::phoenix;...expr=custom_parser[_a=p::make_shared(_1,_2,_3)]>>...由于std::make_shared的可变模板性质,不能使用BOOST_PHOENIX_ADAPT_FUNCTION。所以,如果可能的话,包装器应该是可变参数模板本身。 最佳答案 如果你能省下一组额外的括号:namespace{templatestructmake

c++ - Qt 中的 Objective-C with Mavericks

我一直在Qt中混合使用Objective-C和C++,没有任何问题;在需要时使用.mm文件。将我的构建机器升级到Mavericks后,我最初注意到缺少框架header,因此安装了XCode命令行工具,解决了这个问题。现在,我在编译Objective-C文件时遇到问题,错误提示框架中的代码。例如:-System/Library/Frameworks/Foundation.framework/Versions/C/Headers/NSUserNotification.h:16:44:error:missing','betweenenumeratorsNSUserNotificationAc

PostgreSQL提取键来自JSONB,异常“无法在标量上调用JSONB_OBJECT_KEYS”

我正在尝试与Postgres的JSONB相处。这里有很多问题,我想做的就是这样的事情:SELECTtable.column->>'key_1'asaFROM"table"我尝试了->还有一些括号的组合,但是我总是在nil中得到零。所以我试图获取所有钥匙首先看看它是否识别JSONB。SELECTjsonb_object_keys(table.column)asaFROM"table"这引发了一个错误:cannotcalljsonb_object_keysonascalar因此,要检查列类型(我创建的列类型,所以我知道是JSONB,但无论如何)SELECTpg_typeof(column)a

c++ - std::make_shared/std::make_unique 不使用列表初始化有什么原因吗?

具体来说:直接列表初始化(cppreference.com(3))。两者都是std::make_shared和统一初始化特性在C++11中被引入。所以我们可以在堆上分配对象时使用聚合初始化:newFoo{1,"2",3.0f}.这是一种直接初始化没有构造函数的对象的好方法,例如聚合、pod等。根据我的经验,现实生活中的场景(例如在函数中声明临时结构)以有效地向lambda提供参数集变得非常普遍:voidfoo(){structLambdaArgs{std::stringarg1;std::stringarg2;std::stringarg3;};autoargs=std::make_s

c++ - 如何测试 shared_ptr 是空的还是什么都不拥有

C++std::shared_ptr可能是空,也可能是null。这两个概念都存在,而且它们不是等价的。此外,这些情况之间的任何一种暗示都不总是正确的。后一种情况检测起来很简单,因为operatorbool恰好提供了那个测试。根据文档,它“检查*this是否存储了一个非空指针,即是否get()!=nullptr。”是否有针对前一种情况的测试,即事物为空的情况?我对此的使用非常简单。我有一个具有静态工厂方法的类。静态工厂方法里面是一个静态本地shared_ptr到类的一个实例,初始化为nullptr.对该工厂方法的第一次调用构造该类的实例并初始化静态本地shared_ptr在返回它的拷贝之