草庐IT

C++:通过隐式构造函数初始化 int 变量

我正在学习C++,我对int变量的初始化有点困惑。此代码(包括注释)是Nawaz在本主题WhydoesC++requireauser-provideddefaultconstructortodefault-constructaconstobject?中的回答的复制/粘贴。structPOD{inti;};PODp1;//uninitialized-butdon'tworrywecanassignsomevaluelateron!p1.i=10;//assignsomevaluelateron!PODp2=POD();//initialized对于p2,我知道发生了以下情况:调用默认构造

c++ - VS 2017 不会隐式地将 const char* 转换为 char*

这个问题在这里已经有了答案:Conversionfromstringliteraltochar*isdeprecated[duplicate](2个答案)关闭4年前。我最近安装了VS2017,遇到了一个奇怪的问题。基本上,如果不明确地将它们转换为(char*),我就不能使用硬编码字符串。如果我说类似Function("test")的话,它只会抛出一个错误,指出constchar*与char*不兼容。我真的不想坚持使用VS2015:(。有人知道如何让VS认识到它们是同一回事吗?非常感谢。

C++11 从初始化列表到数组参数的隐式转换

在C++11中,是否可以做类似下面的事情?templatevoidfoo(arraysrc){...}...foo({1,2,3})我目前正在运行GCC4.8。 最佳答案 是的,我设法完成了以下工作(因为您允许类似的事情):templatevoidfoo(arraysrc){...}...foo('a','b');foo(1,2,3);方法如下:#include#include#includeusingnamespacestd;templatevoidfoo(arraysrc){for(autoe:src)coutautomake_

c++ - 隐式转换将符号 'int"更改为 'unsigned int"

我正在使用clang++编译程序,我需要在clang++中正确编译它。我在其他编译器上没有错误。代码中的错误行是memset(grid_,0,sizeof(int)*x_quadrants*y_quadrants);整个函数是这样的:Ocean::Ocean(intnum_boats,intx_quadrants,inty_quadrants){grid_=newint[x_quadrants*y_quadrants];memset(grid_,0,sizeof(int)*x_quadrants*y_quadrants);x_quadrants_=x_quadrants;y_quadr

c++ - 隐式转换会丢失信息吗?

根据https://www.learncpp.com/cpp-tutorial/44-implicit-type-conversion-coercion/"Theimportantthingtorememberaboutpromotionsisthattheyarealwayssafe,andnodatalosswillresult."但是https://www.geeksforgeeks.org/type-conversion-in-c/指出:"Itispossibleforimplicitconversionstoloseinformation,signscanbelost(whe

c++ - 隐式转换和复制构造函数

更新:suggestedduplicate只解决了这个问题的一部分。那里没有解释了解正在发生的事情的关键(首先创建临时引用的事实)。这是我第一次使用隐式转换,所以我这样写:classA{};classB{public:B(A&other){}//CopyconstructorB(constB&other){}};intmain(){Afoo;Bbar=foo;}这会按预期进行编译,但如果我删除const,我的编译器(gcc版本4.8.4)会在分配时产生,并显示一条我无法理解的错误消息:test.cc:Infunction‘intmain()’:test.cc:12:13:error:n

c++ - C++11 中的默认构造函数、POD 的初始化和隐式类型转换

我刚看了Chandler在GoingNative2012上关于Clang的演讲。他展示了以下代码:#includestructS{intn;};structX{X(int){};};voidf(void*){std::cerrChandler指出,这为c++11调用了f(void*),为c++03调用了f(X)。他还指出,原因是S().n默认初始化为0,使其成为nullptr常量。首先,我假设成员变量n的零初始化依赖于编译器实现并且不受标准保证(或者这是否随c++11发生了变化)?Chandler暗示这是由于支持常量表达式,但我仍然不能完全理解他的推理。其次,为什么f(X)会被C++0

c# - 为什么构造函数总是与类同名,以及它们是如何被隐式调用的?

我想知道为什么构造函数的名称总是与类名相同,以及当我们创建该类的对象时如何隐式调用它。谁能解释一下这种情况下的执行流程? 最佳答案 Iwanttoknowthatwhythenameofconstructorisalwayssameasthatofclassname因为这种语法不需要任何新的关键字。除此之外,没有充分的理由。Tominimizethenumberofnewkeywords,Ididn'tuseanexplicitsyntaxlikethis:classX{constructor();destructor();}Ins

c++ - 在没有隐式转换的情况下在编译时检测运算符

我正在使用C++03methodtodetectthepresenceofafunctionatcompiletime.我必须使用此方法而不是void_t方法,即使我使用的是C++14,因为我必须支持GCC4.9,并且在使用void_t方法时出错(奇怪的是只有Ubuntu14的GCC4.9有这个问题,而不是Fedora的,但它已在GCC5+AFAICT中全面修复)。具体来说,我正在检查operator是否存在这样我就可以拥有一个pretty-print功能,可以接受任何类型。当函数被调用时,如果类型支持它,您会得到常规的ostream输出,并且当运算符未定义时,您会收到一条关于没有实现

c++ - 与枚举的隐式转换

这是一个基本问题,我希望轻松地谷歌一下,但没有找到答案。假设我有一个枚举:enumabc{a,b,c};支持哪些隐式转换?编译器之间是否有任何编译器扩展或不同行为?我问的是关于到枚举的隐式转换:enumabctest=(**whichtypecanappearhere?**);以及从枚举的隐式转换:(**whichtypecanappearhere?**)test2=test;我想知道C和C++的答案。 最佳答案 正如引用所说:Valuesofunscopedenumerationtypeareimplicitly-converti