A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© ィSlick 中级黑马   /  2013-10-21 10:30  /  846 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

在编程过程中,不时会遇到一些小细节问题拿不准,举两个例子,
(1)DbCommand.ExecuteScalar方法执行时,如果没有满足条件的数据,会返回null还是DBNull.Value?
(2)将DBNull.Value转换成Boolean类型时,会发生异常呢,还是会转换为true或者false呢?
当我遇到此类问题时,没有十足的把握,就需要写一段代码来验证一下。现在想来,编程中遇到的此类问题已经有不少了。由于不注意整理总结,前面积累的小细节知识都丢失了。
现在写这篇文章把此类问题集中整理一下,以方便自己查询,并给其他遇到类似问题的同行做参考。
(1)DbCommand.ExecuteScalar方法执行时,如果没有满足条件的数据,会返回null还是DbNull.Value?
答案:返回DBNull.Value
(2)使用Convert.ToString()方法将null或者DBNull.Value转换为字符串,分别得到什么结果?是null还是空字符串"" ?
答案:二者都得到空字符串"" 。
(3)将DBNull.Value转换成Boolean类型时,会发生异常呢,还是会转换为true或者false呢?
答案:会发生异常。
(4)关于文件扩展名。如何获得文件扩展名?当然可以找到最后一个.所在位置然后取子串,但是FileInfo类提供了一个Extension属性可以直接提到扩展名。关于这个属性,有几个小细节不太确定,如下。
FileInfo.Extension属性是否包含扩展名中的.,即abc.txt扩展名是txt还是.txt?
答案:.txt
如果文件没有扩展名,如c:\somefile,那么FileInfo.Extension属性返回什么?null还是""还是整个文件名?
答案:空字符串""
(5)关于int.TryParse(string s, out int n)。如果string为空或者非整数字符,那么会影响到第二个输出参数吗?
答案:我期望的情况是,如果s不是一个合法的整数,不能转换为整数,那么TryParse返回false,而且n的值不应该受影响。测试结果显示,实际情况并非如此,如果s无法转换为整数,则n的值变成了0,丢失掉原来的值了。

评分

参与人数 1技术分 +1 收起 理由
追溯客 + 1

查看全部评分

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马