草庐IT

DOUBLE_BUFFERED

全部标签

c++ - 从 double 到 unsigned int 的转换

我遇到了将值从Double转换为int的问题。我尝试运行以下代码:intmain(){doubleval_d=6.25e-05;cout从double到int的转换可能会删除小数部分,但应保留整数部分是吗?我得到的输出是:1600015999那么为什么这里的o/p不同呢?这只发生在软呢帽上。在Windows和Ubuntu上它工作正常。(两个输出都是16000)我调整了上面的代码并得到了以下结果:intmain(){doubleval_d=6.25e-05;cout新输出是160001600016000 最佳答案 当源文本“6.25e

c++ - 为什么在我的 64 位机器上 double 和 long double 完全一样?

这个问题听起来像是针对初学者的,但是当我发现这个问题时,我想我要么是初学者,要么我的comp缺少一些东西:intmain(){cout程序输出:881515我以为longdouble是10个字节,有18个十进制数字,而double是8个字节,有15个数字,但看来我错了。为什么会这样?在64位机器上使用MSVC2010。 最佳答案 如您所知,在MSVC++中,longdouble是double的同义词。显然这是为了利用仅限于64位操作的SSE/SSE2/SSE3指令集。另见here获取更多信息。

c++ - double 会在算术表达式中隐式转换为 unsigned int 吗?

在StanleyB.Lippman的C++Primer中,关于“隐式转换”的部分说:intival;unsignedintui;floatfval;fval=ui-ival*1.0;ivalisconvertedtodouble,thenmultipliedby1.0.Theresultisconvertedtounsignedint,thensubtractedbyui.Theresultisconvertedtofloat,thenassignedtofval.但我不这么认为:我认为实际上ival被转换为double然后乘以1.0然后ui是哪个是类型unsignedint转换为do

c++ - 如何在 C++11 constexpr 中检查 double 的位模式是 0x0?

我想检查给定的double/浮点变量是否具有实际位模式0x0。不要问为什么,它用在Qt中的一个函数中(qIsNull()),我希望它是constexpr。原始代码使用了union:union{doubled;int64_ti;}u;u.d=d;returnu.i==0;这当然不能用作constexpr。下一次尝试使用reinterpret_cast:return*reinterpret_cast(&d)==0;但是虽然它在GCC4.7中作为constexpr工作,但它在Clang3.1中失败了(正确地,指针操作的b/c)。最后的想法是去Alexandrescuesque做这个:temp

c++ - 使用 boost spirit (longest_d) 解析 int 或 double

我正在寻找一种将字符串解析为int或double的方法,解析器应该尝试这两种选择并选择与输入流的最长部分匹配的那个。有一个已弃用的指令(longest_d)完全符合我的要求:number=longest_d[integer|real];...既然它已被弃用,还有其他选择吗?如果有必要实现语义操作来实现所需的行为,有人有什么建议吗? 最佳答案 首先,请切换到SpiritV2-多年来它已经取代了经典spirit。其次,您需要确保首选int。默认情况下,double可以很好地解析任何整数,因此您需要改用strict_real_polici

c++ - 错误 83 错误 C2398 : conversion from 'double' to 'float' requires a narrowing conversion

我找到了很多关于这个错误的帖子,但我可以找到克服它的方法。这是触发错误的代码:voidmain(){floatf{1.3};}为什么在初始化列表中没有像其他变量那样发生转换?例如,这工作顺利:floatf=1.3; 最佳答案 您评论说使用1.3会导致您的编译器出错。这意味着您发现了一个编译器错误。标准很清楚这不是缩小转换,因此应该允许。引用N4140(大致为C++14):8.5.4List-initialization[dcl.init.list]7Anarrowingconversionisanimplicitconversion

c++ - 为什么在 MSVC 中默认将浮点值(如 3.14)视为 double 值?

为什么我需要放置3.14f而不是3.14来禁用所有这些警告?这是否有连贯的原因? 最佳答案 这就是C++(和C)标准所决定的。浮点文字是double类型,如果你需要它们是float,你可以在它们后面加上一个f后缀。似乎没有任何具体说明原因,但我猜它是a)为了与C的兼容性,以及b)在精度和存储之间进行权衡。2.13.3FloatingliteralsThetypeofafloatingliteralisdoubleunlessexplicitlyspecifiedbyasuffix.ThesuffixesfandFspecifyfloa

c++ - 使用字符串流时如何停止 double 转换为科学计数法

我正在创建一个函数来返回小数位数和整数位数,并使用sstream将插入的typename数字转换为字符串。然而,当转换为字符串时,数字以科学计数法出现,这对于计算正常数字中的位数没有用。我怎样才能阻止这种情况发生在我下面的函数中?enum{DECIMALS=10,WHOLE_NUMBS=20,ALL=30};templateintNumbs_Digits(Tnumb,intscope){stringstreamss(stringstream::in|stringstream::out);stringstreamss2(stringstream::in|stringstream::out

c++ - MSVC 用 double 支撑初始化似乎违反了标准?

看看这个简单的程序:intmain(){floatf2=7.2;//OK,withwarningfloatf3=7.199999809265137;//OK,nowarningfloatf4{7.2};//Failsfloatf5{7.199999809265137};//OK,nowarningfloatf6={7.2};//Failsfloatf7={7.199999809265137};//OK,nowarning}当使用默认选项(cl/W4,版本19.00.23918)使用MSVC2015编译时,我收到以下消息:FloatTest.cpp(2):warningC4305:'in

c++ - 将双数组转换为 double 结构

可以将double组转换为由double构成的结构吗?structA{doublex;doubley;doublez;};intmain(intargc,char**argv){doublearr[3]={1.0,2.0,3.0};A*a=static_cast(static_cast(arr));std::coutxyz这会打印123。但它是否保证每次都能与任何编译器一起工作?编辑:根据9.2.21:Apointertoastandard-layoutstructobject,suitablyconverted?usingareinterpret_cast,pointstoitsin