1. vb 怎么将数据类型写成双精度型
1、因为此数据类型的有效数字是16位,它是单精度实数(有效数字8位)精度的两倍,故而得名双精度实型数。
2、详细如下:
a)、Single 数据类型
Single(单精度浮点型)变量存储为 IEEE 32 位(4 个字节)浮点数值的形式,它的范围在负数的时候是从 -3.402823E38 到 -1.401298E-45,而在正数的时候是从 1.401298E-45 到 3.402823E38。
b)、Double 数据类型
Double(双精度浮点型)变量存储为 IEEE 64 位(8 个字节)浮点数值的形式,它的范围在负数的时候是从 -1.79769313486232E308 到 -4.94065645841247E-324,而正数的时候是从 4.94065645841247E-324 到 1.79769313486232E308。
2. Java语言中的浮点型数据的float和double的单精度和双精度到底是啥意思
主要有下面几个区别,手册上的,希望能帮到你
1、变量类型不同
float属于单精度型浮点数据。
double属于双精度型浮点数据。
2、指数范围不同
float的指数范围为-127~128。
double而double的指数范围为-1023~1024
3、表达式指数位不同
float的表达式为1bit(符号位)+8bits(指数位)+23bits(尾数位)
double的表达式为1bit(符号位)+ 11bits(指数位)+ 52bits(尾数位)
4、占用内存空间不同
float占4个字节(32位)内存空间,其数值范围为3.4E-38~3.4E+38。
double占8 个字节(64位)内存空间,其数值范围为1.7E-308~1.7E+308。
5、有效位数不同
float只能提供七位有效数字。
double可提供16位有效数字。
3. Access数据库如何将默认字段大小改为双精度,就是我想在每次新增一个字段的时候,数据类型默认为数
将ACCESS选项中的“表设计”的"默认字段类型"和"默认字段大小"分别设置成"数字"和"双精度型"即可。
2003版本设置方法
菜单——工具——选项 打开选项对话框,然后选择“表/查询”选项卡,跟着在相应的下拉组合框里选择"数字"和"双精度型",最后保存设置,见图
4. C语言如何输出双精度浮点型数据
1.双精度浮点型数据用%lf输出。因为double是8个字节的,float是4个字节的,%f 的格式就是4个字节的,而 %lf 就是8个字节的。 例如:printf("%lf ",x);
2.short 占用内存空间2个字节,短整型数据用%d输出 例如:printf("%d ",a);
例:
#include <stdio.h>
int main()
{double x;
short int a;
printf("%lf",x); // 输入double型
printf("%d",a); //输入短整型
return 0;
}
(4)浮点导入数据库变成双精度扩展阅读:
C语言特有特点
1.C语言是一个有结构化程序设计、具有变量作用域(variable scope)以及递归功能的过程式语言。
2.C语言传递参数均是以值传递(pass by value),另外也可以传递指针(a pointer passed by value)。
3.不同的变量类型可以用结构体(struct)组合在一起。
4.只有32个保留字(reserved keywords),使变量、函数命名有更多弹性。
5.部份的变量类型可以转换,例如整型和字符型变量。
6.通过指针(pointer),C语言可以容易的对存储器进行低级控制。
7.预编译处理(preprocessor)让C语言的编译更具有弹性。
5. 如何单精度浮点数转化为双精度浮点数
强制类型转换,如
float pi=3.14;
double PI=pi;
6. 为什么设一个浮点变量 要求输入双精度浮点类型会出错
scanf ("%lf",&x);
%lf 输入的数会做为双精度来存,占用8个字节,存入以&x为起始的地址里,
而系统只为x 分配了4个字节的位置。后面超出来4个字节就会占用到别的地址,会地址出错。有可能写到不该写的地方。
7. mysql往数据库插入float类型的数据 为什么数字不对
float类型可以存浮点数,但是float有缺点,当不指定小数位数的时候,就会出现小数位数与想要的不一致,导致“报错”。在创建浮点类型的时候必须指定小数位数,float(m,d),m表示的是最大长度,d表示的显示的小数位数。
虽然两个类型的值有相似也有不相似,但定义的是float、插入的值只要不出错肯定是float类型,10表示该值一共显示10位整数,其中3位位于小数点后面。
(7)浮点导入数据库变成双精度扩展阅读:
浮点包可以将二进制浮点数存储为非标准化数,而不使用刚刚介绍的存储方法。“非标准化数”是带有保留指数值的非零浮点数,其中尾数的最高有效位为 0。
通过使用非标准化格式,浮点数的范围可以扩展,但会失去精度。您无法控制浮点数以标准化形式还是非标准化形式表示;浮点包决定了表示形式。浮点包从不使用非标准化形式,除非指数变为小于可以标准化形式表示的最小值。
8. c++如何把浮点型转化成双精度型
直接赋值即可。
9. Excel 求教:单精度浮点型与双精度浮点型的问题
求教,今天学习突然发现个问题,同样的代码,一个申明变量为单精度浮点型,一个申明变量为双精度浮点型,但是结果却不一样
a=3.11999988555908
b=3.12
代码:
Sub test2()
Const a As Single = 3.12
Const b As Double = 3.12
Range("A1") = a
Range("B1") = b
End Sub
结果在excel中如图
这样的话定义单精度浮点型不是没用,以后小数不是都要定义为双精度浮点型了吗?
浮点数的误差是一定存在,并且无法消除。
永远不要直接比较两个浮点数。比较的时候要先round。
把电脑中的浮点运算误差找出来 - 任何人的电脑都会有这个误差的
很多人在日常使用Excel,可能都没有注意到浮点小数带来的计算误差问题
因为日常使用的运算结果,肯定都是四舍五入之后的结果,可以排除浮点误差的影响
但是,浮点小数的误差,也会出现在运算的过程,有可能导致最终结果出错。
比方说 countif(A1:A10000,"=B1")这样的简单统计,也有可能出错。
附件生成5万个随机小数(四舍五入到2位小数位),加上然后马上减去同一个整数
对比计算前后的数值是否相等(数学上当然是绝对相等的,但是电脑的运算结果就不一定了。。。。。。)
附件会自动找出一批在你的电脑上会出现浮点小数误差导致错误的运算。
出现浮点小数运算误差的原因很简单,小数有无穷多个
甚至一个小数也有无穷多位,如十进制的1/3,或者二进制的0.1
所以计算机存储小数的时候,必定只能存储所有小数的一部分,而无穷小数则必须截断
因此,一个小数有时候就只能取一个接近值而不是精确值
而对应的浮点数运算,也只能得到接近值,而不是精确值
不同的CPU,比方说Intel的跟AMD的,或者奔腾跟赛扬,在硬件上对于截断的位置是不一样的
所以,同一个运算在不同的机器就可能有不同的结果
这也是为什么论坛经常有人说xx运算不正确,然后回帖的人说我的机器没事,其实就是CPU不同而已
另一方面,不同的软件,内部计算的时候,也许用了不同的CPU硬件实现的数据类型,或者精度设置也不一样,
所以,同一个运算在不同的软件也可能有不同的结果
编程,写公式要注意,假设 x,y 都是浮点数,er。。。。。。excel的每个小数单元格都是浮点数
那么永远不要写 if x=y 这样的句子,因为很可能数学上相等的x和y,在计算机内部是不等的
应该写成 if |x-y| / max(|x|,|y|) <= 0.0000000000001 之类
或者简单一点,用if round(x) = round(y) 来判断,这样最末一位的尾数浮点存储误差就不会影响整个数值了。
幸运的是,整数和定点小数不会受影响,编程时应该优先考虑使用整数和定点小数类型
另一方面,即使浮点小数可以完全表示我们要计算的数值,但是计算结果却也有可能产生误差
浮点,定点的意思是指小数点的位置
定点小数:小数点位置固定。
以十进制为例,假设一个数值类型可以有6个十进制位置,那么定点类型无须记录小数点位置,可以有以下类型:
整数类型,小数点位置就一定是个位后面,能够表达的最精确数字就是1,能够表达的范围是 000000 - 999999
两位小数类型,小数点位置就一定是百分位,能够表达的最精确数字就是0.01,,能够表达的范围是 0000.00 - 9999.99
。。。。。。等等
浮点小数:小数点位置可以变动,并且需要额外的记录去描述这个变动的小数点位置。
假设这里把其中一个位置用于记录小数点位置(可变范围 0-9),并且规定:
小数点位置取5,表示精度是1,小数点在个位后面,这个数值类型有0个小数位,可以表示 00000 到 99999 的数 (注意:这里只有5位有效数字)
小数点位置取6,表示精度是 0.1,小数点在十分位后面,这个数值类型有1个小数位,可以表示 0000.0 到 9999.9 的数
小数点位置取9,表示精度是 0.0001,小数点在万分位后面,这个数值类型有4个小数位,可以表示 0.0000 到 9.9999 的数
......
小数点位置取4,表示精度是 10,表示小数点在十位,这个数值类型可以表示 00000 x 10 到 999990 的数,精度是 10
......
小数点位置取0,表示精度是 100000,表示小数点在十万位,这个数值类型可以表示 00000 x 100000 到 9999900000 的数,精度是 100000
可见浮点小数通过可变的小数位置,使一个数值类型可以用一部分表示有效数字,另一部分表述每一单位有效数字的倍率
从而灵活地表示很大范围的数值,代价是:由于用了一部分记录内容去记录小数点位置,所以有效数字的长度比定点小数要低。
而且,一些定点数运算不会出现的问题,在浮点数运算会出现
如两个数相加
如果第一个浮点数是 100.01,第二个浮点数是 9999900000
按上述规则,这两个都是合法的浮点数,可是它们的和 99999000100.01 却无法用同一个浮点数类型表示出来。
一般计算机碰到这种情况,就会自动按比较大的数值来四舍五入,于是
100.01 + 9999900000 = 9999900000 (出现了100.01的误差)
这也是浮点数误差产生的一个原因:小的数值被大的数值“吸收”了。
要在Excel证明这一点就太简单了,因为excel的double类型浮点小数只有15个有效数字(即最多记录15个十进制数字)
所以Excel的单元格运算 12345012345678900000 + 12345.0123456789 = 12345012345678900000
-----------------------------------------------------------
VBA单精度浮点型Single与双精度浮点型Double的区别
浮点型说白了就是科学记数法
单精度浮点型(single)
在C++中,单精度浮点型(float )专指占用32位存储空间的单精度(single-precision )值。单精度在一些处理器上比双精度更快而且只占用双精度一半的空间,但是当值很大或很小的时候,它将变得不精确。当你需要小数部分并且对精度的要求不高时,单精度浮点型的变量是有用的。例如,当表示美元和分时,单精度浮点型是有用的。
在foxpro中,单精度浮点型是为了提供兼容性,浮点数据类型在功能上等价于数值型。
在VB中,Single 数据类型 Single(单精度浮点型)变量存储为 IEEE 32 位(4 个字节)浮点数值的形式,它的范围在负数的时候是从 -3.402823E38 到 -1.401298E-45,而在正数的时候是从 1.401298E-45 到 3.402823E38。6位有效位数
Single 的类型声明字符为感叹号 (!)。
双精度(double)型
C语言中,双精度(double)型占8 个字节(64位)内存空间,其数值范围为1.7E-308~1.7E+308,可提供16位有效数字。
Single 最多可以显示小数点后面7位 Double 最多可以显示小数点后面14位
Single 数据类型
Single(单精度浮点型)变量存储为 IEEE 32 位(4 个字节)浮点数值的形式,它的范围在负数的时候是从 -3.402823E38 到 -1.401298E-45,而在正数的时候是从 1.401298E-45 到 3.402823E38。Single 的类型声明字符为感叹号(!)。
Double 数据类型
Double(双精度浮点型)变量存储为 IEEE 64 位(8 个字节)浮点数值的形式,它的范围在负数的时候是从 -1.79769313486232E308 到 -4.94065645841247E-324,而正数的时候是从 4.94065645841247E-324 到 1.79769313486232E308。Double 的类型声明字符是数字符号(#)。