草庐IT

code-sharing

全部标签

c++ - 有没有办法更改现有 shared_ptr 实例的删除操作

我有一个函数,我希望在90%的时间内完成清理操作,但在10%的时间内我希望完成一些其他操作。有什么方法可以使用一些标准范围的控件,例如shared_ptr这样一开始它可以有一个删除操作,然后在函数中可以更改删除操作?shared_ptrptr(newT,std::mem_fun_ref(&T::deleteMe));ptr.pn.d=std::mem_fun_ref(&T::queueMe); 最佳答案 不是真的-shared_ptr的标准以这样的方式编写Deleter可以按值存储在控制节点(一个包含引用计数器、保存删除器、跟踪弱指

c++ - 开始 Code::blocks 和 UnitTest++

我即将开始一个C++项目,但我还停留在基础上。我想使用(linux)Code::BlocksIDE,创建一个普通项目很容易。但是我想使用UnitTest++框架进行TDD,但我不知道如何干净利落地设置所有内容。我已经问过question关于放置UnitTest::RunAllTests()命令的位置,他们告诉我最好的位置是单独程序的main()。我如何在Code::Blocks中做到这一点?我想我需要创建2个项目:拥有自己的main()的“真实”项目;包含测试和main()的单元测试项目,其中包含UnitTest::RunAllTests()。然后以某种方式构建第一个项目并在其构建过程

c++ - 模板部分特化 : How can code duplication be avoided?

当模板完全专用时,不需要复制成员函数。例如,在以下代码中,foo()只写一次。#includetemplateclassB{public:voidfoo();private:voidheader();};templatevoidB::foo(){//specializedcode:header();//genericcode:std::coutvoidB::header(){std::coutvoidB::header(){std::cout但是,对于偏特化,需要复制类定义和所有成员函数。例如:#includetemplateclassA{public:voidfoo();privat

c++ - 使用 braced-init 初始化 std::shared_ptr<std::map<>>

我有以下shared_ptr到map:std::shared_ptr>我想使用braced-init来初始化它。可能吗?我试过:std::strings1("temp");std::shared_ptr>foo=std::make_shared>(1000.0,s1);但是在使用Xcode6.3编译时出现以下错误:/usr/include/c++/v1/map:853:14:Candidateconstructornotviable:noknownconversionfrom'double'to'constkey_compare'(aka'conststd::__1::less')fo

c++ - 如何为 std::shared_ptr<PureVirtualClass> 传递默认参数

我有一个类型的函数virtualvoidfoo(bla,bla,bla,std::shared_ptrlogger)=0;我想传递一个带有NULL指针的默认参数,例如:virtualvoidfoo(bla,bla,bla,std::shared_ptrlogger=NULL)=0;所以在实现中,如果logger是NULL我什么也不做,否则我使用logger。我试图寻找解决方案但找不到..UPD:重复声明无关紧要,我问的是默认NULL参数。有没有可能gcc4.4不支持nullptr? 最佳答案 你可以简单地这样做:virtualvoi

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

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

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++ - 在 Code::Blocks 中调试似乎不起作用 - 缺少调试符号

我正在尝试调试Code::Blocks中的程序。我尽可能地遵循了thisguide和thisshortvideo,但是调试器不会在断点处停止...我看到一个similarquestion仍然没有解决(我不确定我是否应该解决它或打开一个包含更多细节的新问题),我确实选中了“Producedebuggingsymbols[-g]”标志。优化和“去除所有符号[-s]”也都被禁用。我什至尝试了标志-ggdbassuggestedthere,也没有成功。我正在使用TDM-GCC4.5.2(我刚刚升级,之前我与4.5.1有同样的问题),调试器是GNUgdb(GDB)7.2(之前与GDB7.1有同样

C++11 闭包 shared_ptr

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

VS Code配置matlab

前言:matlab很好地集成了大量数学处理函数,甚至封装了包括信号处理、图像处理、神经网络等在内的方法。但matlab启动慢、没有代码补全、开发环境不友善等缺点常受人诟病,算法编写者往往需要进行大量重复动作。而VSCode是微软推出的一款轻量、开源、生态极好的编辑器。本文详细介绍使用VSCode配置matlab环境的方法,使算法编写者可以利用VSCode编写.m文件,充分利用VSCode的开发友善性与matlab的强大功能。本文需要的工具/软件:Matlab软件VSCode软件VSCode插件:CodeRunnerVSCode插件:MatlabVSCode插件:matlab-formatter