jjzjj

instance-specific

全部标签

c++ - 错误 : no instance of overloaded function "std::make_shared" matches the argument list

查看ApreviousstackQuestionstd:make_sharedvsstd::shared_ptr,我试图在一个uni项目中实现它。这是之前的“问题”:Ican'tthinkofanysituationwherestd::shared_ptrobj(newObject("foo",1));wouldbepreferredtoautoobj=std::make_shared("foo",1);因此我采用了这段代码:std::shared_ptrpT1(newTriangle(pCanvas,30,30,30,60,60,30,255,0,0));并将其修改为这段代码:aut

c++ - 'more than one instance of overloaded function "sqrt“匹配参数列表”怎么办?

我的代码在for循环中出错,for(j=3;j:morethanoneinstanceofoverloadedfunction"sqrt"matchestheargumentlist.我该如何解决?#include//determineifnumberisprimeboolisPrime(longn){intj,num=0;{if(num 最佳答案 尝试:for(j=3;j(num));j+=2)发生的事情是包含3个不同的definitionsofsqrt并且编译器不知道您要使用哪个。

c++ - GCC 手册中提到的 "C++ ABI Specification"是什么?

我在查看C++的GCC手册时,发现了以下引述:Version0referstotheversionconformingmostcloselytotheC++ABIspecification.Therefore,theABIobtainedusingversion0willchangeindifferentversionsofG++asABIbugsarefixed.(source)可以看出,上述段落引用了某种看似标准的C++ABI。然而,据我了解,不存在这样的ABI。这段话在说什么?一个好的答案将给出尽可能详尽的解释。将“C++ABI规范”放入我首选的搜索引擎中没有任何用处。

C++ STL : Why is there no upper_bound equivalent that retrieves the greatest element smaller then a specific key?

通常,STL是为提高速度而构建的。然而,在map和set数据结构上只有upper_bound和lower_bound并且没有操作来检索具有小于输入键的最大键的条目k.为什么是这样?我知道我可以简单地做一个lower_bound并做一个--it检索它,但根据数据结构,立即搜索正确的条目可能比搜索另一个条目然后返回一步更有效。例如,std::map使用红黑树,即二叉搜索树。如果upper_bound返回的元素是大于根的最小元素,则--it必须回到根,查询O(logn)的额外成本。如果这是Java,我会接受设计决定。然而,STL是为实现最高速度而构建的,那么为什么要省略此操作?澄清:我不是在

C++ 与 git 和 CMake : How to build submodules with specific parameters?

考虑一个在git存储库中组织的C++项目。假设git存储库有一个子模块,(super)项目依赖于该子模块构建了一个库。如果(super)项目不仅依赖于库,还依赖于使用特定(CMake)参数构建的库,那么如何确保在构建(super)项目时使用这些参数构建子模块? 最佳答案 必须将构建选项(如MYLIB_WITH_SQLITE)添加到库的接口(interface)中,即在老式配置的情况下添加到MYLIB_DEFINITIONS变量中-模块,或者到INTERFACE_COMPILE_DEFINITIONS属性,如果库使用install(E

C++/线程 : No instance of constructor "std::thread::thread" > matches the argument list

我在线程方面遇到了一些问题,因为我对它很陌生。我得到一个:noinstanceofconstructor"std::thread::thread"matchestheargumentlistargumenttypesare(void())恰好在std::threadt1(TestPlay);voidCMusicTCPDlg::OnBnClickedBtplaymusic(){std::threadt1(TestPlay);t1.join();}voidCMusicTCPDlg::TestPlay(){if(CFugue::GetMidiOutPortCount()我引用了一些线程页面,

c++ - "more than one instance of overloaded function "标准::战俘 "matches the argument list"

使用C++,我尝试#defineTINYstd::pow(10,-10)我为定义了TINY的类(.h)提供了带有#include和命名空间信息的代码#pragmaonce#include"MMath.h"#include#include#includeusingnamespacestd;#defineTINYstd::pow(10,-10)我在.cpp文件中的一些函数实现中使用了TINY,而TINY给出了错误IntelliSense:morethanoneinstanceofoverloadedfunction"std::pow"matchestheargumentlist什么是正确的

C++ 宏 : manipulating a parameter (specific example)

我需要更换GET("any_name")与Stringstr_any_name=getFunction("any_name");困难的部分是如何去掉引号。可能的?有什么想法吗? 最佳答案 怎么样:#defineUNSAFE_GET(X)Stringstr_##X=getFunction(#X);或者,为了防止嵌套宏问题:#defineSTRINGIFY2(x)#x#defineSTRINGIFY(x)STRINGIFY2(x)#definePASTE2(a,b)a##b#definePASTE(a,b)PASTE2(a,b)#def

c++ - 警告 LNK4075 : ignoring '/EDITANDCONTINUE' due to '/INCREMENTAL:NO' specification

我有一个链接到外部.lib(libprotobuf.lib)的项目。当我在发行版中编译时,没有警告。但是,当我在调试中编译时,我收到此警告:warningLNK4075:ignoring'/EDITANDCONTINUE'dueto'/INCREMENTAL:NO'specificationFile:\libprotobuf.lib(message_lite.obj)我一直在研究这个问题,从thisquestion.开始我一直在调整项目的选项,并且(在调试配置中):/Zi-所以编辑并继续不应该打开。/INCREMENTAL-所以增量应该打开。知道为什么我仍然收到此警告吗?我最好的猜测是

c++ - 为什么在我的析构函数中抛出时总是得到 "terminate called after throwing an instance of..."?

我正在尝试编写一个单元测试来检测对我的类的lock()功能的无效使用。为此,我想使用析构函数并从那里抛出异常。不幸的是,g++没有捕获异常,而是决定调用std::terminate()。类有一个非常简化的版本:classA{public:A():f_lock(0){}~A(){if(f_lock)throwmy_exception("stilllocked");}lock(){++f_lock;}unlock(){--f_lock;}private:intf_lock;};有一个有效的测试:A*a=newA;a->lock();...a->unlock();deletea;我正在尝试编