手机
当前位置:查字典教程网 >编程开发 >ASP教程 >asp cint clng的范围与防止cint和clng的溢出解决方法大全
asp cint clng的范围与防止cint和clng的溢出解决方法大全
摘要:首先我们需要了解的是cint范围-32,768到32,767。clng范围-2,147,483,648到2,147,483,647。cint...

首先我们需要了解的是

cint范围 -32,768 到 32,767。

clng范围 -2,147,483,648 到 2,147,483,647。

cint与clng含义:

都可以强制将一个表达式转换成数据类型

cint与clng处理数据的范围:

CInt Integer -32,768 至 32,767,小数部分四舍五入。

CLng Long -2,147,483,648 至 2,147,483,647,小数部分四舍五入。

所谓溢出指的是超出处理数据的范围,下面代码是处理数据防止溢出的代码,大家可以自己看看:

'检测是否是短整数

复制代码 代码如下:

sub Is_Int(string)

if len(abs(string))>10 then response.write "数据溢出":response.end

if instr(string,"-")<1 then

if cint(left(string,4))>3276 and cint(right(string,1))>7 then response.write "数据溢出":response.end

else

if cint(left(abs(string),4))>3276 and cint(right(string,1))>8 then response.write "数据溢出":response.end

end if

end sub

'检测是否是长整数

复制代码 代码如下:

sub Is_Lng(string)

if len(abs(string))>10 then response.write "数据溢出":response.end

if instr(string,"-")<1 then

if clng(left(string,9))>214748364 and clng(right(string,1))>7 then response.write "数据溢出":response.end

else

if clng(left(abs(string),9))>21478364 and clng(right(string,1))>8 then response.write "数据溢出":response.end

end if

end sub

以下是一些检验函数,需要的朋友可以参考下:

第一种:

一、检测它是不是整数

复制代码 代码如下:

functionIs_Int(a_str)

ifnotisnumeric(a_str)orlen(str)>5then

Is_Int=false

exitfunction

elseiflen(str)<5then

Is_Int=true

exitfunction

endif

ifcint(left(a_str,4))>3276then

Is_Int=false

exitfunction

elseifcint(left(a_str,4))=3276andcint(right(a_str,1))>7then

Is_Int=false

exitfunction

else

Is_Int=true

exitfunction

endif

endfunction

二、检测它是不是长整数

复制代码 代码如下:

functionIs_Lng(a_str)

ifnotisnumeric(a_str)orlen(str)>10then

Is_Lng=false

exitfunction

elseiflen(str)<10then

Is_Lng=true

exitfunction

endif

ifclng(left(a_str,9))>214748367then

Is_Lng=false

exitfunction

elseifclng(left(a_str,9))=214748367andclng(right(a_str,1))>7then

Is_Lng=false

exitfunction

else

Is_Lng=true

exitfunction

endif

endfunction

如果我们只需要是数子,其它的东西,都可以替换为空,下面这个是查字典教程网站长写的一个正则,替换非数字的正则

复制代码 代码如下:

functionreplacestr(str)

dimre

setre=newregexp

re.ignorecase=true

re.global=true

re.pattern="D"

str=re.replace(str,"")

replacestr=str

setre=nothing

endfunction

下面是上面的调用方法

复制代码 代码如下:

id=replacestr(id)

iflen(id)>5thenid=left(id,5)

ifid<>""thenid=clng(id)

iferr.number<>0Orid="0"thenresponse.redirect"http://www.jb51.net"

dimrs

setrs=conn.execute("selectidfromnewswhereid="&id&"")

【asp cint clng的范围与防止cint和clng的溢出解决方法大全】相关文章:

asp实现sql的备份与恢复

通过Response.Flush()实现下载失败的解决方法

ASP编程入门进阶(十八):FSO组件之文件操作(上)

一个防止被采集的方法

msxml3.dll 错误 '800c0005'解决方案

另类的文件上传解决方案

Microsoft JET Database Engine 错误 '80004005' 未指定的错误的完美解决方法

asp获取数据库的连接属性的方法

asp的程序能实现伪静态化的方法

Session对象失效的客户端解决方法

精品推荐
分类导航