• String.Empty,NULL和""的区别


    String.Empty,NULL和""的区别

    string.Empty就相当于"" 
    一般用于字符串的初始化 
    比如: 
    string a; 
    Console.WriteLine(a);//这里会报错,因为没有初始化a

    而下面不会报错: 
    string a=string.Empty; 
    Console.WriteLine(a);

    或者用于比较: 
    if(a=="") 
    if(a==string.Empty) 
    上面两句是一样的效果。

          string.Empty不分配存储空间
          ""分配一个长度为空的存储空间   
          所以一般用string.Empty

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

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

    if (s == string.Empty) {
    // 

    if语句成立


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

    判定为空字符串的几种写法,按照性能从高到低的顺序是:
    s.Length == 0      优于 s == string.Empty      优于 s == ""

    判断字符串是否为空最好的方法就是    s.Length==0 !

    C#中的空值的判断较麻烦,不象在VB6中那么简单,这些各种空值的判断和理解对不熟悉的人来说,可能很麻烦,现就我在使用过程中的一点体会和大家共同分享。

    (1)NULL

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

    (2)DBNULL

          DBNull在DotNet是单独的一个类型,该类只能存在唯一的实例,DBNULL.Value,DBNull唯一作用是可以表示数据库中的字符串,数字,或日期,为什么可以表示原因是DotNet储存这些数据的类(DataRow等)都是以 object 的形式来储存数据的。对于 DataRow , 它的 row[column] 返回的值永远不为 null , 要么就是具体的为column 的类型的值 。 要么就是 DBNull 。 所以 row[column].ToString() 这个写法永远不会在ToString那里发生NullReferenceException。DBNull 实现了 IConvertible 。但是,除了 ToString 是正常的外,其他的ToXXX都会抛出不能转换的错误。

    (3)""和String.Empty

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

    (4)Convert.IsDBNull()

         Convert.IsDBNull()返回有关指定对象是否为 DBNull 类型的指示,即是用来判断对象是否为DBNULL的。其返回值是True或Flase。

    好了说了这么多,也不知道说明白了没有,其实这些广义上的"空值"理解了后,还是有很大的区别的,甚至根本就没有关系。完全是两个概念.

  • 相关阅读:
    MFC Document/View 3
    MFC Document/View 2
    c++基本类型&&&c++string与c风格字符串的相互转化
    C++不同变量所在内存&&new malloc的区别
    C# 操作Excel 复选框
    prepareStatement与Statement的区别
    Oracle查询用户所有表、字段等信息
    同样的用户和密码,PL/SQL可以正常登录,C#程序却出现 ORA-1017 用户名/口令无效
    javascript原生态的同步异步请求实现
    SQL 数据库是否安全
  • 原文地址:https://www.cnblogs.com/ysz12300/p/5494809.html
Copyright © 2020-2023  润新知