标题:请教数据后怎么会自动跳出“#”符号
只看楼主
fdxxhjc
Rank: 1
等 级:新手上路
帖 子:305
专家分:0
注 册:2014-4-10
结帖率:73.44%
已结贴  问题点数:20 回复次数:4 
请教数据后怎么会自动跳出“#”符号
大侠好,我在编写代码时想编写这样一行代码
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
请教这是为何,如何避免出现这二个“#”,谢谢
搜索更多相关主题的帖子: 自动 跳出 符号 代码 And 
2018-09-27 15:02
wds1
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:贵宾
威 望:49
帖 子:393
专家分:2025
注 册:2016-3-10
得分:0 
数值太大,超出变量计算范围。
2018-09-27 15:05
ZHRXJR
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:125
帖 子:1034
专家分:5519
注 册:2016-5-10
得分:0 
# 是双精度数据类型的说明符,系统自动将数据设置为双精度数据类型,因此才会这样。
与 Dim X As Double 类同。

请不要选我!!!
2018-09-27 19:36
fdxxhjc
Rank: 1
等 级:新手上路
帖 子:305
专家分:0
注 册:2014-4-10
得分:0 
回复 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
但为何在下面的代码编辑中还有出现这个符号呢,请问能否设置成某种数据类型或修改代码使得代码编辑后不会出现“#”符号,谢谢先生指点
2018-09-28 20:17
风吹过b
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:364
帖 子:4912
专家分:29900
注 册:2008-10-15
得分:20 
自动出现 # 的必须是立即数。也就是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 。

授人于鱼,不如授人于渔
早已停用QQ了
2018-09-29 09:03



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-490037-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.140198 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved