草庐IT

member-initialization

全部标签

android-studio - 由于 "Could not initialize class com.intellij.ide.highlighter.JavaFileType",Kotlin 应用程序构建失败

我刚刚将AndroidStudio更新到2.2,现在我的Kotlin项目无法构建。gradle同步工作正常,但在尝试构建时,我立即遇到如下错误:Error:Executionfailedfortask':app:compileDebugKotlin'.>Couldnotinitializeclasscom.intellij.ide.highlighter.JavaFileType我检查了我的Kotlin插件是否是最新的。这个错误听起来像是与IDE和突出显示Java代码有关?任何帮助将不胜感激。 最佳答案 打开工具|Kotlin|在主

android-studio - 由于 "Could not initialize class com.intellij.ide.highlighter.JavaFileType",Kotlin 应用程序构建失败

我刚刚将AndroidStudio更新到2.2,现在我的Kotlin项目无法构建。gradle同步工作正常,但在尝试构建时,我立即遇到如下错误:Error:Executionfailedfortask':app:compileDebugKotlin'.>Couldnotinitializeclasscom.intellij.ide.highlighter.JavaFileType我检查了我的Kotlin插件是否是最新的。这个错误听起来像是与IDE和突出显示Java代码有关?任何帮助将不胜感激。 最佳答案 打开工具|Kotlin|在主

c++ - c++ : error: must use '.*' or '->*' to call pointer-to-member function in function 中的函数指针

代码片段如下。无法理解为什么会出现此错误。voidSipObj::check_each_field(){map::iteratormsg;stringstr;charname[20];boolres=false;sscanf(get_payload(),"%s%*s",name);LOGINFO(lc())second;res=(this).*sip_field();}}typedefbool(SipObj::*sip_field_getter)();staticmapsip_field_map;sip_field_getter是函数名的占位符 最佳答案

c++ initializer_list 和 shared_ptr 行为

这个问题在这里已经有了答案:Doubledeleteininitializer_listvs2013(1个回答)关闭8年前。我正在测试vs2013c++initializer_list。下面的代码可以编译。但是当我运行exe时崩溃。#include#includeclassBase{};classDerived:publicBase{};voidDoSomething(std::initializer_list>list){}intmain(){autoip=std::make_shared();std::cout()});//ng//DoSomething({ip,std::make

C++11 "In class initialization"功能不适用于 union

最小代码示例:structB{unionU{structS{}s;inti=100;}u;};现在,如果我们声明一个Bobj;,那么obj.u.i会被分配一个垃圾值而不是100。查看demohere.(垃圾值因优化标志等而异)。“类内初始化”功能是否应该与union一起使用。如果是,那么正确的语法是什么?或者这是一个g++错误?如果不是,那么inti=100;做什么? 最佳答案 这看起来像一个GCC错误。标准说(9.5p2):Atmostonenon-staticdatamemberofaunionmayhaveabrace-or-

c++ - 无法将 "member pointer to derived class"转换为 "member pointer to base class"

使用指向基类的指针调用类的虚成员函数当然是C++中非常常见的事情。所以我觉得很奇怪,当你有一个成员指针而不是一个普通指针时,似乎不可能做同样的事情。请考虑以下代码:structB{virtualvoidf();};structD:B{virtualvoidf();};structE{Bb;Dd;};intmain(){Ee;//Firstwithnormalpointers:B*pb1=&e.b;//OKB*pb2=&e.d;//OK,BisabaseofDpb1->f();//OK,callsB::f()pb2->f();//OK,callsD::f()//Nowwithmember

C++11/14 : How to remove a pointer-to-member from a type?

在C++11或C++1y/14中:给定一个TC::*形式的指向成员类型的值,我想得到指向类型例如:#includeusingnamespacestd;structT1{staticvoidf(){coutstructV;templatestructV{staticconstexprT1U1::*pm=&U1::x;};templatestructV{staticconstexprT2U2::*pm=&U2::x;};templatevoidf(Wpm){typedef???T;T::f();}intmain(){f(V::pm);f(V::pm);}有没有办法做到这一点?上面的???是

c++ - 使用 std::initializer_list 作为成员变量

这个问题在这里已经有了答案:Canitbesafetokeepacopyofanstd::initializer_list?Whatistherationale?(1个回答)关闭4年前。我有一个A类,它接受一个initializer_list并将其存储为一个成员变量。classA{public:A(std::initializer_listil):m_il(il){}std::initializer_listm_il;};另一个类B将A作为成员变量,默认使用initializer_list初始化classB{public:B(){std::cout现在,当我在main中运行这段代码时,

c++ - 错误 : Qualifiers dropped in binding reference of type x to initializer of type y

为什么下面会抛出这个错误:IntelliSense:qualifiersdroppedinbindingreferenceoftype"string&"toinitializeroftype"conststring".hclassA{public:wstring&GetTitle()const;private:wstringtitle;};.cppwstring&GetTitle()const{returnthis->title;}如果我删除const词,它就会停止提示,但我从未对变量进行任何更改? 最佳答案 通过返回对类成员的非c

c++ - initializer_list c++11 中的评估顺序

在下面的代码中,是否要求在f2之前调用f1(或反之亦然),还是未指定?intf1();intf2();std::initializer_listlist{f1(),f2()}; 最佳答案 这是C++标准的一个有趣的角落,其中执行顺序定义明确。第8.5.4节[dcl.init.list],第4段:Withintheinitializer-listofabraced-init-list,theinitializer-clauses,includinganythatresultfrompackexpansions(14.5.3),aree