草庐IT

double-brace-initialize

全部标签

c++ - 从字符串到数字大于 std::numeric_limit<double>::digits10 的 double 的转换

std::stringstr="12345679012.124678";doubleback=boost::lexical_cast(str);std::stringstr2=boost::lexical_cast(back);//herestr2isequaltostr即使数字的有效数字大于std::numeric_limit::digits10(即15),此处也没有丢失(即最终字符串=原始字符串)是否正常? 最佳答案 是的,这很正常。std::numeric_limit::digits10指的是确保强制转换无损的最大位数。这并不

c++ - 编译器如何传递 `std::initializer_list` 值? (或 : how can I get around a universal overload with one? )

Continuingmysaga,我意识到我可以使用单个std::initializer_list参数来重载我的访问函数:classarray_md{//...my_type&operator[](size_typei){/*Lotsofcode*/}my_typeconst&operator[](size_typei)const{/*sameLotsofcode,with"const"sprinkledin*/}my_type&operator[](std::initializer_listi){/*Lotsofdifferentcode*/}my_typeconst&operato

qt.network.ssl: QSslSocket::connectToHostEncrypted: TLS initialization failed

方法一:如果是https,改为http。方法二:Qt解决qt.network.ssl:QSslSocket::connectToHostEncrypted:TLSinitializationfailed问题-CSDN博客其他: 

c++ - 为什么 g++ 声明某些 valarray<double> o 有 "no matching function for call cbegin(o)"?

请考虑以下代码:usingcustom_t=std::valarray;custom_to;unsignedacc=std::accumulate(std::cbegin(o),std::cend(o),0);g++-5说Nomatchingfunctionforcalltocbegin(custom_t&)如果我改用std::begin(o)和std::end(o),一切正常。这是编译器错误吗?代码使用VisualStudio2015编译。 最佳答案 这是一个libstdc++错误,我刚刚创建了https://gcc.gnu.or

C++ 复制构造函数被调用而不是 initializer_list<>

基于这段代码structFoo{Foo(){coutilist){cout输出是:默认构造函数抄袭者抄袭者在第三种情况下,我将b放入应该调用initializer_list构造函数的大括号初始化中。相反,复制构造函数带头。你们有人能告诉我这是如何工作的吗?为什么? 最佳答案 正如NicolBolas所指出的,此答案的原始版本是不正确的:撰写本文时的cppreference错误地记录了在列表初始化中考虑构造函数的顺序。以下是使用标准n4140草案中存在的规则的答案,该标准非常接近官方C++14标准。原答案的文字仍然包含在内,以备记录。

c++ - 理解 double-to-int 转换中的 int-vs-trunc 关系

当我运行以下代码时#include#includeusingnamespacestd;intmain(){enum{FACTOR=3};doubled=1.0/FACTOR;doubled_i=int(d*FACTOR);inti_t=std::trunc(d*FACTOR);doubled_r=std::round(d*FACTOR);cout在Code::Blocks17.12IDE中(使用我认为/希望的全包工具),我得到了这些令人困惑的结果:0vs1vs1我尝试更改编译器,但没有任何改变。最后我安装了MinGW-64版本8.1.0。我的构建日志显示--------------Cl

c++ - Microsoft VS C++ 编译器是否存在 Bug Initialize a reference from a temporary object

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:Bindingtemporarytoalvaluereference使用VS2008C++编译器编译代码无编译错误。classA{};intmain(){A&a_ref=A();return0;}我相信C++标准,包括C++2003和即将到来的C++0x,都不允许它。而且我还遇到了gcc编译器的编译时错误。所以我想知道的是,这是VS编译器允许从临时对象初始化引用的已知错误。还是VS编译器的功能扩展?如果是,临时对象的生命周期是多少?

c++ - 我如何在 C++ 中对包含 double 值的字符串强制执行精度

示例输入字符串:char*str="12345.567675";如果我需要小数点后3位的精度,则需要输出:str="12345.568";有没有办法在不将字符串转换为double然后再转换回字符串的情况下执行此操作? 最佳答案 是的,在高层:1.搜索“.”在字符串中。2.如果'.'的位置+3小于你做的长度。3.否则,在'.'位置连接字符串+3.4.这里有点棘手:你需要检查下一个字符是否存在,('.'+4),如果它的值>=5则转到4.1(否则转到5)4.1.将字符串复制到左侧多一个空格的新字符串(因为在“4”循环中9.9999将更改为

C++ 将 lexical_cast double boost 为字符串

对于下面的一段代码std::cout(2.34)我得到以下输出:2.3399999999999999如果我这样做doubled=2.34;std::stringstreamss;ss我得到以下输出:2.34为什么会这样?显然,我正在寻找后者的输出表示,而不是前者。谢谢, 最佳答案 这与boost::lexical_cast无关,但它伴随着double的内部表示:另请参阅此答案:C++internalrepresentationofdouble/float 关于C++将lexical_ca

c++ - 内存屏障 : How to ensure initialization writes are seen by worker threads?

我对使用内存屏障/栅栏进行编程还很陌生,我想知道我们如何才能保证设置写入在随后在其他CPU上运行的辅助函数中可见。例如,请考虑以下内容:intsetup,sheep;voidSetupSheep()://RunonceCPU1:setup=0;...muchlaterCPU1:sheep=9;CPU1:std::atomic_thread_fence(std::memory_order_release);CPU1:setup=1;之后运行(不是并发),很多很多次:voidManipulateSheep():CPU2:intmySetup=setup;CPU2:std::atomic_t