草庐IT

my_variable_double

全部标签

c++ - long double sqrt() 的精度

我注意到sqrt()的longdouble版本的准确性存在问题。以下代码演示了该问题。#include#include#includeintmain(intargc,char**argv){intcount=0;longdoubles=sqrt(3L);std::cout.precision(21);std::cout编译运行>g++-osqrtsqrt.cpp&&./sqrt给予s=1.73205080756887719318,s^2=2.99999999999999965241.732050807568877193292.999999999999999652841.73205080

C++ 为两个 double 重载 operator%

是否可以为两个double重载operator%?constdoubleoperator%(constdouble&lhs,constdouble&rhs){returnfmod(lhs,rhs);}当然,这会产生错误,因为两个参数之一必须具有类类型。所以我考虑利用C++隐式构造函数调用的可能性来解决这个问题。我是通过以下方式做到的:classMyDouble{public:MyDouble(doubleval):val_(val){}~MyDouble(){}doubleval()const{returnval_;}private:doubleval_;};constdoubleop

c++ - 构造函数设置的 "const variables"用于表示 C++ 数组的边界?

下面的代码可以编译并且运行良好:classTest{private:constunsignedMAX;public:Test(constunsignedintn):MAX(n){}voidfoo(){intarray[MAX];...}};但是真的可以吗?我的意思是:Testa(3);Testb(8);array实际上分别有3个和8个单元格吗?如果是这样,是不是因为array是一个自动var并使用适当的维度进行实例化?谢谢 最佳答案 你写的在c99有效但不有效c++.我当然是在谈论您对VLA的使用的,而不是完整的片段。当使用g++-

c++ - condition_variable 的常见用例场景

条件变量可用于向其他线程发出信号,表明发生了某些事情:mutexm;condition_variablecv;threadt1([&cv]{//processing...cv.notify_one();});...unique_locklck(m);cv.wait(lck);但是正如您所看到的,在我们等待通知之前,有一个机会窗口,线程处理完成并且通知正在通过,所以我们将永远等待。在这种情况下,常见的解决方案是使用标志:mutexm;condition_variablecv;booldone=false;threadt1([&cv,&done]{//processing...done=t

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++ - 字符串到 double 转换 C++

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