注册 登录
编程论坛 VB6论坛

请教数据后怎么会自动跳出“#”符号

fdxxhjc 发布于 2018-09-27 15:02, 2346 次点击
大侠好,我在编写代码时想编写这样一行代码
If (yc11 + yc21 = 5309568) And (ec11 + ec21 = 16312762752) And (yc11 + yc21 = 56383024693248) Then
但当我这行代码输入完毕敲回车键继续编写下一行代码时,一面一行代码中较大的二个数值后面会自动添加符号#,变成以下代码
If (yc11 + yc21 = 5309568) And (ec11 + ec21 = 16312762752#) And (yc11 + yc21 = 56383024693248#) Then
请教这是为何,如何避免出现这二个“#”,谢谢
4 回复
#2
wds12018-09-27 15:05
数值太大,超出变量计算范围。
#3
ZHRXJR2018-09-27 19:36
# 是双精度数据类型的说明符,系统自动将数据设置为双精度数据类型,因此才会这样。
与 Dim X As Double 类同。
#4
fdxxhjc2018-09-28 20:17
回复 3楼 ZHRXJR
请教先生,我在前面已经设置了
Dim yc11 As Double
Dim yc12 As Double
'--------------
Dim ec11 As Double
Dim ec12 As Double
'----------------
Dim sc11 As Double
Dim sc12 As Double
但为何在下面的代码编辑中还有出现这个符号呢,请问能否设置成某种数据类型或修改代码使得代码编辑后不会出现“#”符号,谢谢先生指点
#5
风吹过b2018-09-29 09:03
自动出现 # 的必须是立即数。也就是IDE不会给变量加#号。

If (yc11 + yc21 = 5309568) And (ec11 + ec21 = 16312762752#) And (yc11 + yc21 = 56383024693248#) Then
在你的代码中,16312762752  和 56383024693248
都超过了 long(2147483648) 的范围,可以使用数据只有 单精度浮点 和双精度浮点了。
但 单精度浮点,只能保存 7位有效数据,所以这个类型也被排除了,
简单类型中,只剩下 双精度浮点。

IDE 给你的立即数加上#号,实际上是给编译器看的,明确指示该立即数在内存中的保存方式,防止编译器出现错误。
在自己写代码时,除下显式定义数据类型外,也可以使用这种的说明符来定义


Const A1 = 56383#
Const A2 As Double = 56383
这二条语句都是定义一个 双精度浮点的常量。
检测结果
Dim c As Variant            '定义一个 Variant  类型的变量,以保存各种基本类型的数据
c = A1
MsgBox TypeName(c)

Const A1 = 56
Const A1 = 56#
这种的定义,按上面的测试代码,显示的 数据类型一个是 Integer ,一个就是 Double 。
1