草庐IT

C++ 依赖注入(inject)——通过引用还是通过 boost::shared_ptr?

在需要构造函数依赖注入(inject)的情况下,使用引用注入(inject)与使用boost::shared_ptr注入(inject)有哪些注意事项?还有其他常见的方法吗?它与上述两种方法相比如何? 最佳答案 您可以选择如何管理要注入(inject)的对象的生命周期。整体架构可能会决定哪种选择最有意义。有了引用,更高层次的东西必须管理对象的生命周期;使用shared_ptr将自动管理生命周期。 关于C++依赖注入(inject)——通过引用还是通过boost::shared_ptr?,

c++ - 在 C++0x 中实现生成器

python关键字yield对我来说是一个很好的概念抽象,让我能够将算法的重要部分提炼成人类可读的形式。我们之前讨论过:Pythongeneratorsinvariouslanguages其中针对C++中仅适用于Windows的库给出了答案。此外,我在问题中找到了另一个使用时髦宏扩展的示例:GeneratorsinC++—invaliduseofnonstaticdatamember我的计算机科学知识告诉我,屈服函数有somethingtodowithco-routines和monad,但我不太清楚这如何适合C++或C++0x可以完成的任务。似乎在C++中,如果不使用宏扩展或windo

c++ - 通过继承扩展 shared_ptr

做这样的事情有什么不好?classmyclass:publicstd::shared_ptr{//somecode,anallocationisneverdonestd::stringget_info(){if(*this!=nullptr)return""+(this->info*3)+"";elsereturn"";}};当类中没有分配时---只是像上面那样提供一些装饰? 最佳答案 原则上允许从STL类派生,参见here和here.但是,您必须知道您不应该使用指向基类的指针——即std::shared_ptr*。在这种情况下。所

c++ - 将 std::ptr_fun 用于成员函数

考虑以下几点:classA{public:boolis_odd(inti){return(i%2)!=0;}voidfun(){std::vectorv2;v2.push_back(4);v2.push_back(5);v2.push_back(6);//failsherev2.erase(std::remove_if(v2.begin(),v2.end(),std::not1(std::ptr_fun(is_odd))),v2.end());}};上面的代码无法否定is_odd()的效果,因为它是一个成员函数。对std::ptr_fun()的调用失败。我如何让它发挥作用?请注意,我希

c++ - 侵入式_ptr : Why isn't a common base class provided?

boost::intrusive_ptr需要intrusive_ptr_add_ref和intrusive_ptr_release被定义为。为什么不提供一个可以做到这一点的基类?这里有一个例子:http://lists.boost.org/Archives/boost/2004/06/66957.php,但海报说“我不一定认为这是个好主意”。为什么不呢?更新:我认为这个类可能被多重继承滥用这一事实是不够的。任何从具有自己的引用计数的多个基类派生的类都会有同样的问题。这些引用计数是否通过基类实现都没有区别。我认为多线程没有任何问题;boost::shared_ptr提供原子引用计数,这个

c++ - boost::smart_ptr 可以用于多态吗?

可以boost::smart_ptr比如scoped_ptr和shared_ptr可以用在多态中吗?classSomeClass{public:SomeClass(){a_ptr.reset(newSubClass);}private:boost::scoped_ptra_ptr;} 最佳答案 我相信答案是肯定的;对boost指针进行编码,以便在父类(superclass)所在的任何地方都接受派生类。 关于c++-boost::smart_ptr可以用于多态吗?,我们在StackOver

C++11 闭包 shared_ptr

创建由shared_ptr管理的堆分配闭包的语法是什么。我想将闭包传递给函数并能够传递nullptr。似乎使用了shared_ptr但我无法理解从lambda表达式初始化它的语法 最佳答案 应该是这样的autolambda=[](){/*dosomethingusefull*/};autop=std::make_shared>(lambda);但实际上你可能不需要shared_ptr,因为function可以从nullptr构造。std::functionfnc(nullptr); 关于

c++ - 在 C++/CLI 中使用 unique_ptr 时出现链接器错误

我目前正在转换我的auto_ptr实例至unique_ptr,但我遇到了一个问题。它在代码的C++部分工作得很好,但在我的托管C++/CLI层(该软件同时使用C#和C++)中执行它时,我遇到链接错误。它编译得很好,但在链接时会中断。auto_ptr从来没有任何问题.我目前正在使用VisualStudio2010。有人知道使用unique_ptr时遇到的任何问题吗?在C++/CLI中?我试图在下面的一段代码中总结我的问题,但请注意下面的代码实际上可以编译和工作(我检查了指针的所有权是否正确移动).编译时我没有收到链接错误,但下面的代码是纯C++而不是C++/CLI。我只是想提供一个代码构

c++ - 为什么 ofstream 在 0x0A 之前插入一个 0x0D 字节?

我正在使用ofstreamfout("filename");在C++中输出一个无符号字符数组但它会在两者之间产生虚假字符。这是造成问题的代码部分:for(inti=0;i这是数组的定义:unsignedcharDChuffTable[12]={0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,0x09,0x0A,0x0B};在输出文件中,我在0x09和0x0A之间得到一个虚假的0x0D。在要打印之前,我在Debug模式下检查了数组,它没有改变。请告诉我您对这个问题的看法。 最佳答案 您的流以文

c++ - 如何传递 unique_ptr<T> 代替原始 *output* 指针参数?

我在外部库中有一个预先存在的函数,它看起来像这样;boolCreateTheThing(MyThing*&pOut);简而言之;我给它一个原始指针(通过引用),函数分配内存并将我的指针分配给新分配的对象。当函数返回时,我有责任在我完成后释放内存。显然,我想将此结果存储到unique_ptr中,并避免使用手册delete.我可以创建一个临时原始指针以用于API调用,并将其传递到unique_ptr的构造函数中;MyThing*tempPtr;CreateTheThing(tempPtr);unique_ptrrealPtr=unique_ptr(tempPtr);还有比这更直接的方法吗?