草庐IT

Double-precision_floating-point_f

全部标签

C++:如何在不进行舍入、截断或填充的情况下将 float 转换为字符串?

这个问题在这里已经有了答案:WhydoIseeadoublevariableinitializedtosomevaluelike21.4as21.399999618530273?(14个答案)关闭6年前。我遇到了一个问题,但无法解决。需要大师的帮助。这是示例代码:-floatf=0.01f;printf("%f",f);如果我们在调试期间检查变量中的值f包含'0.0099999998'值并且printf的输出是0.010000。一个。有什么方法可以强制编译器将相同的值分配给float类型的变量?我想将float转换为字符串/字符数组。怎么可能只有且只有完全相同的值才能转换为字符串/字符

c++ - 如何检查 double 是否有小数部分?

基本上我有两个变量:doublehalfWidth=Width/2;doublehalfHeight=Height/2;因为它们被除以2,所以它们要么是整数,要么是小数。我如何检查它们是整数还是.5? 最佳答案 您可以使用modf,这应该足够了:doubleintpart;if(modf(halfWidth,&intpart)==0){//yourcodehere} 关于c++-如何检查double是否有小数部分?,我们在StackOverflow上找到一个类似的问题:

c++ - boost::multiprecision::float128 和 C++11

我尝试在C++11(gcc4.8.1)下使用boost::multiprecision::float128(boost1.55.0),但出现以下编译器错误:/cm/shared/apps/boost/gcc/1.55.0/include/boost/multiprecision/float128.hpp:Instaticmemberfunction‘staticstd::numeric_limits>::number_typestd::numeric_limits>::min()’:/cm/shared/apps/boost/gcc/1.55.0/include/boost/multi

c++ - 从 double 截断到 float?

#includeusingnamespacestd;intmain(void){floathaha[2];float(&ptr)[2]=haha;ptr[0]=0.54;ptr[1]=0.65;cout我目前正在使用入门C++学习复杂的数组声明,在我的代码中,我收到警告说WarningC4305'=':truncationfrom'double'to'float'Arrayforbothptr[0]和ptr[1]出于某种原因,但我在任何地方都看不到double,但当我将代码修改为ptr[0]=(float)0.54;ptr[1]=(float)0.65;我似乎没有警告谁能解释为什么?提

c++ - 使用(float&)int可以进行类型修剪,(float const&)int可以像(float)int那样转换吗?

VS2019版本x86。templatefloatget()const{intf=_mm_extract_ps(fmm,i);return(floatconst&)f;}当使用return(float&)f;编译器使用时extractpsm32,...movssxmm0,m32。正确的结果当使用return(floatconst&)f;编译器使用时extractpseax,...movdxmm0,eax。错误的结果T&和Tconst&首先是T,然后是const的主要思想。const只是程序员的某种协议(protocol)。您知道您可以解决它。但是汇编代码中没有任何const,只能输入f

c++ - x86-64 长 double

longdouble在Intel64位平台上的实际精度是多少?是80位填充到128位还是实际的128位?如果是前者,除了gmp之外,还有其他选择可以实现真正的128精度吗? 最佳答案 x86-64精度与常规x86相同。扩展double为80位,使用x87ISA,添加了6个填充字节。没有128位FP硬件。不过,四精度或扩展四精度的软件实现可能会受益于x86-6464x64=>128整数乘法指​​令。 关于c++-x86-64长double,我们在StackOverflow上找到一个类似的问

c++ - Windows 和 Linux 中 C++ 中 double 的精度位数不同。为什么? Linux显示超过20个非零精度数字

刚刚做了这个:doubleval1=numeric_limits::max();cout.precision(70);cout在Windows中,我在17位数字(小数点后16位数字)后开始得到0。然而在Linux中,当我不断增加cout.precision(NUMBER)时,越来越多的数字不断显示并且它们不是零。此外,运行以下代码在Windows和Linux上都会显示“15”。Windows系统是32位的,Linux系统是64位的,如果有区别的话。typedefstd::numeric_limitsdl;cout谁能帮忙解释一下这是怎么回事?我认为Windows和Linux中的精度位数

c++ - 使用 GCC 和 C++11 实现类型 "long double"

我尝试搜索有关longdouble的信息,到目前为止,我了解到编译器对它的实现有所不同。在Ubuntu(XUbuntu)Linux12.10上使用GCC时,我得到了这个:doublePId=acos(-1);longdoublePIl=acos(-1);std::cout.precision(100);std::cout输出:PId8:3.141592653589793115997963468544185161590576171875PIl16:3.141592653589793115997963468544185161590576171875有人明白为什么他们输出(几乎)相同的东西吗

c++ - 错误 C2296 : '%' : illegal, 左操作数在 C++ 中的类型为 'double'

我必须对双数使用“%”,但在C++中它不起作用。示例:doublex;temp=x%10;我收到这个错误:errorC2296:'%':illegal,leftoperandhastype'double'如何在不将数字从double转换为整数的情况下解决这个问题?如果我转换它,我会丢失小数部分,我不想。还有其他选择吗? 最佳答案 %没有为double定义,但您可以使用fmod代替:ComputeremainderofdivisionReturnsthefloating-pointremainderofnumer/denom(roun

c++ - C/C++ - 将 24 位有符号整数转换为 float

我正在用C++编程。我需要将一个24位有符号整数(存储在一个3字节数组中)转换为float(规范化为[-1.0,1.0])。平台是x86上的MSVC++(这意味着输入是小端)。我试过这个:floatconvert(constunsignedchar*src){inti=src[2];i=(i我不完全确定,但我从这段代码中得到的结果似乎不正确。那么,我的代码错了吗?如果错了,为什么? 最佳答案 您不是将24位符号扩展为整数;高位将始终为零。无论您的int大小是多少,此代码都有效:if(i&0x800000)i|=~0xffffff;编