草庐IT

double-brace-initialize

全部标签

c++ - 术语的含义 - Resource Acquisition Is Initialization

我知道RAII的作用。当/如果代码抛出异常时,这都是为了防止内存泄漏等。现在,我想了解那个智能术语的含义。http://en.wikipedia.org/wiki/AcquisitionAcquisition意味着获得某物。那么,当我们说资源获取就是初始化时,这是什么意思?我只是在这里谈论这个术语的含义,而不是一般的概念。 最佳答案 之前有人说过(可能是ScottMeyers说的,我记不清了),RAII应该被称为“Destructionisresourcerelease”,或者类似的词。“资源获取即初始化”字面上的意思是,当一个对象

c++ - "crosses initialization of variable"仅当初始化结合声明时

我读过thisquestion关于“跳转到案例标签”错误,但我还有一些疑问。我在Ubuntu12.04上使用g++4.7。这段代码报错:intmain(){intfoo=1;switch(foo){case1:inti=0;i++;break;case2:i++;break;}}错误是jump-to-case-label.cpp:Infunction‘intmain()’:jump-to-case-label.cpp:8:8:error:jumptocaselabel[-fpermissive]jump-to-case-label.cpp:5:9:error:crossesinitia

c++ - 如何判断 double float 是否可以安全地存储为单精度 float ?

这个问题在这里已经有了答案:关闭9年前。PossibleDuplicate:Realnumbers-howtodeterminewhetherfloatordoubleisrequired?我正在尝试检查从double到float的转换是否会导致精度损失。显然,我可以进行转换并将float转换回double并将其与原始值进行比较。我很好奇是否有更直接的方法。

c++ - 如何使用外部链接在 namespace 范围内定义常量 double?

我正在尝试创建一个带有外部链接的命名空间范围常量//insomeincludefile:namespacefoo{constexprdoublebar(){return1.23456;}//internallinkageconstexprdoublebaz=1.23456;//internallinkageconstdoublebing=1.23456;//internallinkage}这可能吗? 最佳答案 是,也不是;你可以使用extern:[C++11:3.5/3]:Anamehavingnamespacescope(3.3.

Ruby Double Splat参数太贪婪,哈希参数

在Ruby2.4.1中,我有这样的方法:defexample(*args,**kwargs)pargspkwargsend我可以通过位置论点不是哈希很好:irb(main):001:0>example("Greetings")["Greetings"]{}而且,如果我想使用命名参数,那也很好:irb(main):002:0>example(something:42)[]{:something=>42}但是,试图将哈希作为位置论点,这发生了:irb(main):002:0>example({something:42})[]{:something=>42}我想*args拿{something:42

c++ - 使用 Float 或 Double 类型时不显示小数

我的代码是这样的:#includeintmain(){usingnamespacestd;constfloatdollar=1.00;cout我是C++的初学者。我输入这段代码只是玩玩,并假设控制台会显示“你有10.00美元,但它实际上显示我有“10”而不是“10.00”美元。有人能告诉我这是为什么吗? 最佳答案 由于您正在处理美元金额,您可以在写入cout之前设置以下内容:std::cout.precision(2);std::cout.setf(std::ios::fixed);Livecodeexampleatcoliru#i

c++ - 嵌套的 std::initializer_lists 的数据元素是否保证是连续的?

可以通过嵌套大括号括起来的列表来创建多维初始化器,如{{1,2,3},{4,5,6}}中所示。接受它的函数可以使用嵌套的std::initializer_list编写。是否保证数据元素是连续的?这是一个例子:voidf(std::initializer_list>a){for(autoconst&p:a)for(autoconst&q:p)std::cout上面的代码在我的机器上输出了连续的地址。0x400c600x400c640x400c680x400c6c0x400c700x400c74有保证吗?更新答案一定是否定的。voidg(std::initializer_lista,std

c++ - 字符串到 double 转换 C++

这个问题在这里已经有了答案:HowdoIprintadoublevaluewithfullprecisionusingcout?(17个答案)关闭8年前。我正在尝试将字符串转换为double,但我的double在小数点后第三位被截断。我的字符串如下所示:“-122.39381636393”转换后它看起来像这样:-122.394voidsetLongitude(stringlongitude){this->longitude=(double)atof(longitude.c_str());coutlongitude输出示例:gotlongitude:-122.39381636393set

c++ - Python ctypes : initializing c_char_p()

我写了一个简单的C++程序来说明我的问题:extern"C"{inttest(int,char*);}inttest(inti,char*var){if(i==1){strcpy(var,"hi");}return1;}我把它编译成一个so.从python我调用:fromctypesimport*libso=CDLL("Debug/libctypesTest.so")func=libso.testfunc.res_type=c_intforiinxrange(5):charP=c_char_p('bye')func(i,charP)printcharP.value当我运行它时,我的输出

c++ - 在 8 字节边界上对齐 double ?

在数字代码中是否有一个通用的可移植习语(我正在用D编写,但与语言无关的C和C++答案对我也很有用)以确保所有经常访问的堆栈分配的double是在8字节边界上对齐?我目前正在优化一些数字代码,其中未对齐的堆栈分配double(仅在4字节边界上对齐)导致大约1.5到2倍的性能下降。 最佳答案 这是特定于编译器的。在x86上使用GCC,您将使用-malign-double 关于c++-在8字节边界上对齐double?,我们在StackOverflow上找到一个类似的问题: