草庐IT

c++ - 不理解 C++ 类型不匹配 : const Foo* to Foo* const&

拥有这组对象和语句:QSetset;iteratorQSet::insert(constT&value)//typeofthefunctionIwanttocallconstFoo*get()const//typeofthefunctionIusetogettheargumentset.insert(get());//thelineshowingupaserror我收到错误“参数1没有从‘constFoo*’到‘Foo*const&’的已知转换”。我想我在阅读这些类型时遇到了麻烦,因为我不知道我应该怎么做才能完成这项工作。根据我的阅读,const关键字适用于其左侧的类型,但顶级cons

C++ 构造函数的乐趣——用自身的拷贝构造 Foo

我有:classFoo;classBar{Foofoo;Bar():foo(foo){};}Barbar;此时,是bar.foo//[这个问题源于一个错误的引用计数指针实现;我可以发誓我确保每个指针都指向非空的东西;但我最终得到了一个指向NULL的指针。] 最佳答案 一旦您进入构造函数的主体,foo就会完全初始化(这是有保证的一般情况;特别是当它在初始化列表中完成初始化后。)在你的例子中,你是从一个非构造的对象复制构造的。根据§12.7/1(谢谢你,gf),这会导致未定义的行为:Foranobjectofnon-PODclassty

c++ - 为什么我不能用 foo(char* args[]) 做 foo({"asd","asd1"})?

我正在阅读C++Primer,在第6.2节中它说:"Parameterinitializationworksthesamewayasvariableinitialization."然而当我这样做时:voidfoo(char*args[]){return;}intmain(){char*args[]={"asd","dsa"};//ok.foo({"asd","dsa"});//error.}这是为什么? 最佳答案 作为@T.C.在评论中指出,函数参数中的args被转换为char**因为函数不能将数组作为参数。既然你做不到char**

c++ - 在包 BAR 中使用 R 包 FOO 中的 C++ 代码的最佳方法

我正在尝试使用Rcpp定义一个函数来加速。情况如下:我有一个FOO包,里面有很多C++代码(我自己的包,目前没有使用Rcpp),它定义了一组函数,例如foo_a和foo_b。在另一个包BAR(使用Rcpp)中,我正在定义一个函数(使用Rcpp属性),我想在其中调用函数foo_a和foo_b。我该如何解决这个问题?在其他帖子中看了一下我发现我以某种方式在FOO中包含头文件并在BAR中使用属性//[[Rcpp::depends(FOO)]],但我似乎错过一些点。有关如何操作的任何提示?最好的拉斯编辑:感谢您的评论,我喜欢KevinUshey的方法并尝试实现它。然而,经过一些编码后,我意识到

c++ - decltype(auto) foo() 在没有任何警告的情况下返回本地引用

在使用现代C++中的示例时,我编写了以下代码。#include#includestaticintcount=0;classCounter{public:Counter(){++count;};Counter(Counter&r){++count;};Counter(Counter&&r){++count;};~Counter(){--count;};voidfoo(){};};decltype(auto)foo_warn(){Counterc;return(c);//Warningaboutreturninglocalreference}decltype(auto)foo_no_war

c++ - 当一个方法只接受 Foo *const 时,我应该 const_cast "this"吗?

我有一个类Foo这是一个self引用的树状结构(最低限度):classFoo{public://Getsthischild'spositionrelativetoit'sparent.intgetPosition()const{returnparent->indexOf(this);}intindexOf(constFoo*constchild)const{returnchildren.indexOf(child);//thislinecausesanerror.}private:Foo*parent;QListchildren;}行returnchildren.indexOf(chi

c++ - 不能为 std::basic_string<T> foo = "foo"推导出 T = char?

问题:在下面的代码中,第一个示例的模板参数类型推导似乎失败了,但第二个示例却没有。我不明白为什么第一个样本无法推断出T=char.我会认为T从"foo"转换时可以推导出至std::bacis_string,但即使这不起作用,我也提供了第二个函数参数,我认为它会明确约束T至char.为什么它会失败?Doesnotwork:#include#includetemplatevoidprint(conststd::basic_string&a,conststd::basic_string&b){std::cout错误:string.cpp:14:5:error:nomatchingfuncti

c++ - 为什么允许 "a.template foo<0>();"即使 "a.foo<0>();"已经足够了?

structA{templatevoidfoo(){}};intmain(){Aa;a.foo();//oka.templatefoo();//alsook}显然,a.foo();比a.templatefoo();更简洁、直观、更具表现力.为什么C++允许a.templatefoo();尽管a.foo();够了吗? 最佳答案 有时,在模板中,您需要编写a.templatefoo()而不是a.foo().@melpomene在评论中给出了这个很好的例子:templatevoiddo_stuff(){Ta;a.templatefoo()

c++ - 将 vector<fooType> foo[num] 移植到 Windows(无 C99)

我们可以动态分配std::vectorfoo[num];像这样吗?std::vector*lSamplesPerClass=newvector[nClasses];[...]delete[]lSamplesPerClass; 最佳答案 是的,你可以(假设你真的想要一个vector数组)。但是,如果您改为这样做,将会更安全、更易于管理:std::vector>foo(num);如果标准库可以为你做,永远不要自己做动态分配。 关于c++-将vectorfoo[num]移植到Windows(无

windows - Win 7 64 位 gmcs hello.cs -pkg :gtk-sharp-2. 0 上的单声道开发环境找不到文件

我下载了Mono并将其安装在Win764bit上我按照说明访问了这个网站http://www.mono-project.com/Mono_Basics我打开了单声道命令提示符并编译并运行了控制台helloworld然后我尝试用编译窗口化的helloworld示例gmcshello.cs-pkg:gtk-sharp-2.0我明白了C:\Code\NoControl\Mono>gmcshello.cs-pkg:gtk-sharp-2.0errorCS0006:Metadatafile`C:/PROGRA\~2/MONO-2\~1.8/lib/mono/gtk-sharp-2.0/pango