直到最近才发现VB VB中的CDbl(x)操作基本上是一个转换(即C#中的VB等价的(double)x);但最近的一个发现显示,情况并非如此.
如果我有这个字符串:
Dim s As String = "12345.12345-"
我这样做:
Dim d As Double = CDbl(s)
d将被设置为值-12345.12345!现在,不要误会我,在我的具体情况下这样很方便;但是我不得不承认我为什么这么做很困惑.特别是,我很困惑,因为:
> Double.Parse不适用于上述输入.
> Double.TryParse不起作用
> Convert.Todouble不起作用
CDbl如何聪明?
它使用Microsoft.VisualBasic.CompilerServices.Conversions.Todouble().该函数包含对象的GetTypeCode()返回值的Select语句,因此可以根据参数的类型使用自定义转换器.字符串转换器考虑字符串可能包含货币值的可能性,并对字符串进行一些处理.货币值的一个允许的格式是尾随的负号.
这不是特别便宜.实现相同转换的最快方法是:
Dim s As String = "12345.12345-" Dim d As Double = Double.Parse(s,Globalization.NumberStyles.Any)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。