null可赋值任何变量,将变量置为空 
DBNull只用于DataRow对象,表示数据库中的空值 
String.Empty是0长度字串 
Convert.IsDBNull判断是否为DBNull

DBNull.Value与Null的区别

Null是.net中无效的对象引用。

DBNull是一个类。DBNull.Value是它唯一的实例。它指数据库中数据为空(<NULL>)时,在.net中的值。

以下是我测试的一个例子。

例:表tbl_Student

id    name    address

1      jim      <NULL>

将上述表数据填充到.net 的名为dt的DataTable中。

dt.Rows[0]["address"]不等于null但是等于DBNull.Value.

可见null表示一个对象的指向无效,即该对象为空对象。

DBNull.Value表示一个对象在数据库中的值为空,或者说未初始化,DBNull.Value对象是指向有效的对象。

另外注:对上述dt,如果有如下代码:dt.Rows[0][100]。结果如何?

并非想象中的null。而是出现异常:索引超出数组界限。

对于普通的引用类型变量,如果指向对象为null,则会提示:未将对象引用设置到对象实例。但对于使用dt.Rows[i][j]取值,如果第i行存在但i行没有j列,则直接出现异常,不会返回一个指向null的dt.Rows[i][j]。

所以:使用(dt.Rows[0][100]!=null)判断没有意义。为避免0行的100列不存在。可以判断(dt.Rows[0].ItemArray.Length>100).

string.Empty不分配存储空间

""分配一个长度为空的存储空间

所以一般用string.Empty

为了以后跨平台,还是用string.empty

在 C# 中,大多数情况下 "" 和 string.Empty 可以互换使用。比如:

string s = "";

string s2 = string.Empty;

if (s == string.Empty) {

判定为空字符串的几种写法,按照性能从高到低的顺序是:

s.Length == 0      优于 s == string.Empty      优于 s == ""

您关于String.Empty和Null的问题是这样的,这两个都是表示空字符串,其中有一个重点是string str1= String.Empty和 string str2=null 的区别,这样定义后,str1是一个空字符串,空字符串是一个特殊的字符串,只不过这个字符串的值为空,在内存中是有准确的指向的,string str2=null,这样定义后,只是定义了一个string 类的引用,str2并没有指向任何地方,在使用前如果不实例化的话,都将报错。textBox1.Text的值为零长度字符串 ""。

null是C#关键字,是表示不引用任何对象的空引用的文字值。null 是引用类型变量的默认值。 
DBNULL表示类,表示空值. 
该类用于指示不存在某个已知值(通常在数据库应用程序中)。 
在数据库应用程序中,空对象是字段的有效值。该类区分空值(空对象)和未初始化值(DBNull.Value 实例)。例如,表可以包含具有未初始化字段的记录。默认情况下,这些未初始化字段具有 DBNull 值。 
String.Empty表示空字符串,该属性为只读. 
Convert.IsDBNULL(object value)是一个方法,就是判断参数对象是否为DBNULL对象类型,如果是返回true,不是返回false

C#中空值(null)与空字符串("")的区别

问:

string aa = String.Empty;
string aa = null;
string aa = "";
有什么区别?

答1:

一、
string aa;

string aa = null;
一样。
他么都是声明了一个sting对象的名字aa(可以理解为C\C++中指向sting类型变量的指针,或者说引用),但是并没有赋予aa一个与之对应的实际对象(没有内存分配)。所以aa在这里什么都不是,等待分配。

二、
string aa = String.Empty;

string aa = "";
以及
string aa;
aa="";
是一样的。
aa被声明为一个空的字符串。
实际上是aa在这里代表了一个内容为空字符串的字符串对象。

三、
究竟前面两种情况在使用中有什么不一样呢?
前者由于没有指向具体对象,所以在没有将它指向具体对象之前,不能用“.”运算符引用string类对象的很多方法和属性。
但是后者就可以。

答2:

empty
使用 Empty 常量值初始化字符串可新建字符串长度为零的 String 对象。零长度字符串的字符串表示形式为 ""。使用 Empty 值(而不是 null)初始化字符串可以降低发生 NullReferenceException 的可能性。

Null 字符串和空字符串
空字符串是不包含字符的 System.String 对象的实例。在各种编程方案中经常会使用空字符串表示空白文本字段。可以对空字符串调用方法,因为它们是有效的 System.String 对象。
相反,null 字符串并不引用 System.String 对象的实例,任何对 null 字符串调用方法的尝试都会生成 NullReferenceException

C#中的DBNull、Null、String.Empty和“”相关推荐

  1. C#中的DBNull、Null、和String.Empty解释

    1.对DBNull的解释:     该类用于指示不存在某个已知值(通常在数据库应用程序中).     在数据库应用程序中,空对象是字段的有效值.该类区分空值(空对象)和未初始化值(DBNull.Val ...

  2. C#中NULL,,DBNULL,String.Empty,Convert.IsDBNull()的区别

    C#中的空值的判断较麻烦,不象在VB6中那么简单,这些各种空值的判断和理解对不熟悉的人来说,可能很麻烦,现就我在使用过程中的一点体会和大家共同分享. (1)NULL null 关键字是表示不引用任何对 ...

  3. NULL,,String.Empty三者在C#中的区别

    (1)NULL null 关键字是表示不引用任何对象的空引用的文字值.null 是引用类型变量的默认值.那么也只有引用型的变量可以为NULL,如果int i=null,的话,是不可以的,因为Int是值 ...

  4. Java 中关于String的空对象(null) ,空值(empty),空格 的总结

    Java 中关于String 对象的空对象(null), 空值(""),空格(" ")对于很多人来说很模糊,下面将分别介绍一下他们的用法:定义,判断,运算. 首 ...

  5. Mysql 数据库默认值选 ‘‘“ 、Null和Empty String的区别

    Mysql 数据库默认值选 ''" .Null和Empty String的区别 1:空值('')是不占用空间的 2: MySQL中的NULL其实是占用空间的.官方文档说明: "NU ...

  6. string.empty , , null 以及性能的比较

    一:这种结论,个人觉得仍然存疑  http://www.cnblogs.com/wangshuai901/archive/2012/05/06/2485657.html  1.null null 关键 ...

  7. String.Empty,NULL和的区别

    string.Empty不分配存储空间       ""分配一个长度为空的存储空间          所以一般用string.Empty 为了以后跨平台,还是用string.emp ...

  8. string.Empty和null三者的区别

    本文来讨论"",string.Empty和null三者到底有什么区别 这是一个及其常见的问题,网上已经有关于这个问题的很多讨论.但是我觉得都是不求甚解,有一些还是在误导别人.下面我 ...

  9. ,string.Empty和null三者的区别

    这是一个及其常见的问题,网上已经有关于这个问题的很多讨论.但是我觉得都是不求甚解,有一些还是在误导别人.下面我来说下我对这三者的理解,如有错误的地方请大家及时指正. 一:""与st ...

最新文章

  1. AHOI2008 聚会
  2. 微信小程序发红包功能实现,附效果图加讲解。
  3. ubuntu上建立mini2440 qt编译环境
  4. JDK(JAVA)的安装和配置
  5. 全球及中国矿棉板行业运营能力状况与十四五规模预测报告2022年
  6. 用J-Link烧写u-boot到Nor Flash—— 韦东山嵌入式Linux视频学习笔记04
  7. 启动zookeeper_Giraph源码分析(一)—启动ZooKeeper服务
  8. EEPlat 主子表和对象引用配置实例
  9. Java 编译,运行错误之 java.lang.UnsupportedClassVersionError: Bad version n umber in .class file
  10. activemq高可用
  11. 转:Visio 2010 产品秘钥 亲测可用的
  12. 分公司可以作为著作权人申请软件著作权登记证书么?
  13. 本地win10服务器不能复制文件,解决Win10无法复制文件并提示“0x80070032”错误的方法...
  14. xp计算机启动检测硬盘,取消WinXP开机自检技巧五则
  15. mysql和oracle面试题_【SQL 面试题2】Mysql 和Oracle数据库
  16. webstorm下载地址分享
  17. CS106B Assignment #4:Boggle
  18. 强化学习《蘑菇书 EasyRL第一章 概览》
  19. Why does Markov Matrix contain eigenvalue=1 and eigenvalues less than or equa to1?
  20. 计算机网络——(6)网络互联技术与设备

热门文章

  1. oracle赋予一个用户查询另一个用户中所有表
  2. 回溯---分割字符串使得每个部分都是回文数
  3. kettle变量(param命名参数)
  4. 统计字符串中某个字出现的次数
  5. echarts 柱状图 ,颜色和显示设置
  6. 图论测试题(一)第一题:longest
  7. 5个能提高你工作效率的Excel技巧
  8. WordPress插件开发-创建、停用、删除插件
  9. sort,uniq,wc指令简单用法
  10. 用iptables实现G1手机cmwap代理上http网站[转]