草庐IT

C++语法歧义

全部标签

c++ - 从哪里获得自定义 Visual Studio 2008 语法突出显示(复杂的)

好吧,我曾经看到过更多的语法高亮显示,而默认的语法高亮显示在VS2008中真的很有限,所以我在想,是否有这样的高亮显示:定义的变量会有自己的颜色。定义的函数会有自己的颜色。预定义函数会有自己的颜色(来自库等,可能会有自己的列表)。常量/枚举有自己的颜色。typedefs/defs会有自己的颜色。字符串(引号之间的东西)会有自己的颜色。floats/double的颜色会有所不同(会检查1.0f或1.0等)因为这太棒了,我以前没有在任何语法高亮系统中见过1,2,4,5,如果有这样的系统就好了。这会大大加快编程速度,因为如果我犯了错误,我会在编译前立即看到它。我看了一些MSDN网站,做起来非

C++ 隐式转换和重载函数调用中的歧义

我面临以下问题:我有一个类V(比如一个vector),我可以从中生成两个类:CI和I(想想const_iterator和迭代器)。如果我有一个constV,那么我只能生成CI(再次想到iterator和const_iterator)。本质上,我想用(CIci)替换(constV&v),用(Ii)替换(V&v)。此外,我仍然希望能够将Vobj直接传递给需要I或CI的函数,从而实现从V和constV到CI和I的隐式转换。我面临的问题是,虽然重载函数可以区分(constV&v)和(V&v),但当我传递Vobj时,它们无法“区分”(CIci)和(Ii)。在代码中:structV{};struc

c++ - 复杂的 C++ 模板语法

加入SO后,每当我打开讨论模板的主题时,我经常会看到这种语法。我试着在谷歌上搜索,但没有成功。templatechar(&f(T[1]))[1];//whatisit?whatistheuseof'[]'bracketsandtheintegerinit?templatechar(&f(...))[2];//notthiseitherintmain(){charc[sizeof(f(0))==2];}//andthis?从这里:SFINAEwithinvalidfunction-typeorarray-typeparameters?请解释我放置注释的3行。我特别想了解语法。我们可以只在

c++ - 复杂层次结构中的统一初始化语法?

我正在使用GCC4.4.5。这是我的问题的重现:#includeclassTest{public:Test(inta,intb=42):m_a(a),m_b(b){}private:intm_a;intm_b;};typedefstd::vectorTestList;classTestMaster{public:TestMaster(TestListtests=TestList()):m_tests(tests){}private:TestListm_tests;};现在,这有效:intmain(){TestListtest_list={15,22,38};return0;}但这不能编

c++ - 模板函数调用歧义是如何解决的?

我想做一个函数conj仅当参数类型不是std::complex时才会应用.我可以使用enable_if,但我需要这样做吗?如果我有以下内容:namespace{templateTconj(Tx){returnx;}}我们已经在stdtemplatestd::complexconj(std::complexx);会调用conj(z)吗?其中z是std::complex被解析为标准版本(因为它是“更好”的匹配?) 最佳答案 Willacalltoconj(z)wherezisstd::complexberesolvedtothestdv

c++ - 专门化成员 S::display 需要 ‘template<>’ 语法

我正在创建一个特征类来帮助我的程序。我有一个名为operations的模板类包含方法display和area.当我定义这些函数时,我得到了错误。他们在这里:error:specializingmember‘traits::operations::display’requires‘template’syntaxerror:specializingmember‘traits::operations::area’requires‘template’syntax如您所见,编译器要我插入template就在这些定义之前。但是当我这样做时,我会收到一大页错误。出了什么问题,我该如何解决?这是我的程

c++ - 重载函数歧义

首先我要指出,这是我的第一个stackoverflow问题,所以请多多包涵。我在重载C++中的函数时遇到了一些问题。我正在尝试使用以下原型(prototype)创建一个函数:voidpush_at_command(std::string,std::vector,int);voidpush_at_command(std::string,std::vector,std::vector,int);voidpush_at_command(std::string,std::vector,std::vector,std::vector,int);voidpush_at_command(std::s

c++ - 是数组 a<T, N> = { initializer-list };正确的语法?

在工作草案中http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2010/n3225.pdf23.3.2它说Anarrayisanaggregate(8.5.1)thatcanbeinitializedwiththesyntaxarraya={initializer-list};我会通过arraya={initializer-list};是正确的,有人可以解释一下这种奇怪的语法吗? 最佳答案 草稿有误。C++11标准的最终版本有arraya如您所料。

c++ - 尾随返回类型函数语法中的 auto 关键字背后是否有意图?

在C++11中,这两行是等价的。据我所知,advantageofthesecondsyntax是返回类型在类范围内。因此,您可以直接使用类的嵌套类型和非静态成员的decltype表达式。此外,函数名称排列得很好。intfoo(intbar);autofoo(intbar)->int;这里使用了auto关键字,也可以用来自动导出局部变量的类型。但是,我在这里看不到类比。在函数声明语法中,没有派生任何东西。箭头后面明确提到了返回类型。就我个人而言,我会说没有auto关键字语法会更清晰。这背后有什么用意吗?哪个? 最佳答案 论文"Decl

c++ - 数组文字语法怪癖

当我使用数组文字时,我在不同的编译器上看到了奇怪的行为。我遇到的第一个问题是当我有这样一个程序时:voidf(int*){}intmain(){usingT=int[];f(T{1,2,3});}关于Clang3.5这编译得很好,但是在g++4.9上它给出了错误:source_file.cpp:Infunction‘intmain()’:source_file.cpp:8:17:error:takingaddressoftemporaryarrayf(T{1,2,3});在VC++它给出了错误:Processexitcodeisnot0:255这很奇怪。如果我使T等于int[3]而不是