System.Convert 的一些事

简介:

经常看到同事写代码: 
bool? obj=从服务器返回来的值,可能为null。 

if(obj !=null && Convert.ToBoolean(obj)==true)
{
    //Do something
}


上面的代码的意图很明显,先判断obj 是不是null,如果不是null 的话,再调用Convert.ToBoolean方法,判断是不是True。


上面的方法没有任何问题,但有一点要确认的是, obj!=null 这句话需要判断吗?


于是笔者写了下面的代码来对Convert的ToXXX方法传递null值进行测试。

image

可以看到,method.Invoke(null,new object[]{null}) 
刻意的为ToXXX方法传递null值。


结果如下: 
clip_image004clip_image005

从而证明了,对Convert的ToXXX方法传递null值是不会跑出异常的,并且会返回默认的值, 
例如int:0,  string:"",  char:'\0',  bool:false;


这代表上面的代码可以简化为

if(Convert.ToBoolean(obj))
{
//Do something.
}

 

顺带提一下, 
下面的代码会跑出异常.Convert.ToChar(null); 
但是下面这段代码不会: 
object obj=null; 
Convert.ToChar(obj);返回'\0',空字符.

 

Convert.ToChar(null)在内部实际调用的是 Convert.ToChar(null, null),然而ToChar(null,null)的实现如下:

if (value == null)
{
     throw new ArgumentNullException("value");
}
if (value.Length != 1)
{
     throw new FormatException(Environment.GetResourceString("Format_NeedSingleChar"));
}
return value[0];

 

所以,直接传null值会出现异常。






本文转自LoveJenny博客园博客,原文链接:http://www.cnblogs.com/LoveJenny/archive/2011/06/11/2078602.html,如需转载请自行联系原作者
目录
相关文章
|
8月前
|
数据库 数据库管理
System.ArgumentException:“The specified invariant name ‘System.Data.SQLite‘ wasn‘t found in the list
System.ArgumentException:“The specified invariant name ‘System.Data.SQLite‘ wasn‘t found in the list
66 0
遍历字符串,String line = xxx for(int i = 0;i<line.length();i++){system.out.println(line.chartAt(i)); 单个
遍历字符串,String line = xxx for(int i = 0;i<line.length();i++){system.out.println(line.chartAt(i)); 单个
“System.out.println(的正确格式
“System.out.println(的正确格式
134 0
|
JavaScript 前端开发
|
开发工具 Perl
|
Oracle 关系型数据库 C++