复习专项使用,中有些常用的办法运用

图片 2

复习专项使用,中有些常用的办法运用

一、字符串

一.string.Empty

  •   经过string定义一个字符串,只怕经过String类来成立对象。

    •   通过new String()
      创制有眨眼间间二种构造函数(从元数据卡塔尔国,以此顺序成立string;
    • 图片 1图片 2

      //
              // 摘要:
              //     将 System.String 类的新实例初始化为由 Unicode 字符数组指示的值。
              //
              // 参数:
              //   value:
              //     Unicode 字符的数组。
              [SecuritySafeCritical]
              public String(char[] value);
              //
              // 摘要:
              //     将 System.String 类的新实例初始化为由指向 8 位有符号整数数组的指针指示的值。
              //
              // 参数:
              //   value:
              //     一个指针,指向以 null 结尾的 8 位带符号整数数组。
              //
              // 异常:
              //   T:System.ArgumentNullException:
              //     value 为 null。
              //
              //   T:System.ArgumentException:
              //     如果 value 是用 ANSI 编码的,则不能使用 value 初始化 System.String 的新实例。
              //
              //   T:System.ArgumentOutOfRangeException:
              //     要初始化的新字符串的长度过大,无法分配,该长度由 value 的 null 终止字符决定。
              //
              //   T:System.AccessViolationException:
              //     value 指定的地址无效。
              [CLSCompliant(false)]
              [SecurityCritical]
              public String(sbyte* value);
              //
              // 摘要:
              //     将 System.String 类的新实例初始化为由指向 Unicode 字符数组的指定指针指示的值。
              //
              // 参数:
              //   value:
              //     指向以 null 终止的 Unicode 字符数组的指针。
              //
              // 异常:
              //   T:System.ArgumentOutOfRangeException:
              //     当前进程并不是对所有编址字符都有读取权限。
              //
              //   T:System.ArgumentException:
              //     value 指定了包含无效 Unicode 字符的数组,或者 value 指定了小于 64000 的地址。
              [CLSCompliant(false)]
              [SecurityCritical]
              public String(char* value);
              //
              // 摘要:
              //     将 System.String 类的新实例初始化为由重复指定次数的指定 Unicode 字符指示的值。
              //
              // 参数:
              //   c:
              //     一个 Unicode 字符。
              //
              //   count:
              //     c 出现的次数。
              //
              // 异常:
              //   T:System.ArgumentOutOfRangeException:
              //     count 小于零。
              [SecuritySafeCritical]
              public String(char c, int count);
              //
              // 摘要:
              //     将 System.String 类的新实例初始化为由 Unicode 字符数组、该数组内的起始字符位置和一个长度指示的值。
              //
              // 参数:
              //   value:
              //     Unicode 字符的数组。
              //
              //   startIndex:
              //     value 内的起始位置。
              //
              //   length:
              //     要使用的 value 内的字符数。
              //
              // 异常:
              //   T:System.ArgumentNullException:
              //     value 为 null。
              //
              //   T:System.ArgumentOutOfRangeException:
              //     startIndex 或 length 小于零。- 或 -startIndex 和 length 之和大于 value 中的元素数。
              [SecuritySafeCritical]
              public String(char[] value, int startIndex, int length);
              //
              // 摘要:
              //     将 System.String 类的新实例初始化为由指向 8 位有符号整数数组的指定指针、该数组内的起始位置和一个长度指示的值。
              //
              // 参数:
              //   value:
              //     指向 8 位带符号整数数组的指针。
              //
              //   startIndex:
              //     value 内的起始位置。
              //
              //   length:
              //     要使用的 value 内的字符数。
              //
              // 异常:
              //   T:System.ArgumentNullException:
              //     value 为 null。
              //
              //   T:System.ArgumentOutOfRangeException:
              //     startIndex 或 length 小于零。- 或 -由 value + startIndex 指定的地址相对于当前平台来说太大;即,地址计算溢出。-
              //     或 -要初始化的新字符串的长度太大,无法分配。
              //
              //   T:System.ArgumentException:
              //     由 value + startIndex 指定的地址小于 64K。- 或 -如果 value 是用 ANSI 编码的,则不能使用 value 初始化 System.String
              //     的新实例。
              //
              //   T:System.AccessViolationException:
              //     value、startIndex 和 length 共同指定的地址无效。
              [CLSCompliant(false)]
              [SecurityCritical]
              public String(sbyte* value, int startIndex, int length);
              //
              // 摘要:
              //     将 System.String 类的新实例初始化为由指向 Unicode 字符数组的指定指针、该数组内的起始字符位置和一个长度指示的值。
              //
              // 参数:
              //   value:
              //     指向 Unicode 字符数组的指针。
              //
              //   startIndex:
              //     value 内的起始位置。
              //
              //   length:
              //     要使用的 value 内的字符数。
              //
              // 异常:
              //   T:System.ArgumentOutOfRangeException:
              //     startIndex 或 length 小于零,value + startIndex 引起指针溢出,或者当前进程并不是对所有编址字符都有读取权限。
              //
              //   T:System.ArgumentException:
              //     value 指定了包含无效 Unicode 字符的数组,或者 value + startIndex 指定了小于 64000 的地址。
              [CLSCompliant(false)]
              [SecurityCritical]
              public String(char* value, int startIndex, int length);
              //
              // 摘要:
              //     将 System.String 类的新实例初始化为由指向 8 位有符号整数数组的指定指针、该数组内的起始位置、长度以及 System.Text.Encoding
              //     对象指示的值。
              //
              // 参数:
              //   value:
              //     指向 8 位带符号整数数组的指针。
              //
              //   startIndex:
              //     value 内的起始位置。
              //
              //   length:
              //     要使用的 value 内的字符数。
              //
              //   enc:
              //     一个对象,用于指定如何对 value 所引用的数组进行编码。如果 enc 为 null,则假定以 ANSI 编码。
              //
              // 异常:
              //   T:System.ArgumentNullException:
              //     value 为 null。
              //
              //   T:System.ArgumentOutOfRangeException:
              //     startIndex 或 length 小于零。- 或 -由 value + startIndex 指定的地址相对于当前平台来说太大;即,地址计算溢出。-
              //     或 -要初始化的新字符串的长度太大,无法分配。
              //
              //   T:System.ArgumentException:
              //     由 value + startIndex 指定的地址小于 64K。- 或 -未能使用 value 初始化 System.String 的新实例,假定 value
              //     按照 enc 的指定进行编码。
              //
              //   T:System.AccessViolationException:
              //     value、startIndex 和 length 共同指定的地址无效。
              [CLSCompliant(false)]
              [SecurityCritical]
              public String(sbyte* value, int startIndex, int length, Encoding enc);
      

      View Code

    • 图片 3图片 2

      char []cstr = { 'a','b','c','d','e'};
                  char cstr1 = 'a';
                  sbyte se = 113;
      
                  String a = new String(cstr);
                  //
      
                  String b = new String(&cstr1);
      
                  String c = new String(&se);
      
                  String d = new String('d',2);
      
                  String e = new String(cstr,2,3);
      
                  String f = new String(&se,0,1);
                  Console.WriteLine((int)Convert.ToChar(f)+"n");//113
                  String g = new String(&se,0,1,Encoding.UTF8);
                  Console.WriteLine("a:{0}nb:{1}nc:{2}nd:{3}ne:{4}nf:{5}ng:{6}",a,b,c,d,e,f,g);
      

      View Code

  •   string是C#基元类型(primitive),string简单的话就是编译器直接帮忙的数据类型。运算符(==
    和 !=)是为着相比 string 对象的值, 并不是相比引用

    • string a = “1234”;
                  string b = "123";
                  b += "4";
                  Console.WriteLine(a == b);//比较值
                  Console.WriteLine((object)a == (object)b);//比较引用()
      

       

  •   string连接操作 (+=卡塔尔

    •   短处很刚烈, 操作频仍的话非常浪费内部存款和储蓄器空间的
    •   使用StringBuilder类对象方法append替代+=, 质量还应该有所提高
  •   null,” “和string.Empty的区别
    •   null代表不引用任何变量的空援用的值,null是引用变量的暗许值,
      值类型变量不也许利用
    •   ””表示分配一个内部存储器为空的贮存空间。
    •   string.Empty表示空字符串,並且不分配内部存储器空间。
  •   判定字符串为空 的俩种办法
    •   x.length==0 // 无法看清为null的字符串
    •   string.IsNullOrEmpty(x)
        

string.Empty就也等于 “” ,经常用来字符串的最早化 ,

举例说: string a; Console.WriteLine(a);//这里会报错,因为尚未开端化a

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

抑或用于比较: if(a==””) if(a==string.Empty) 上面两句是同少年老成的成效。

 

二.String.IsNullOrEmpty 方法

String.IsNullOrEmpty(value)

指令钦定的字符串是 null 依旧 Empty 字符串。 能同期测量试验 String 是还是不是为
null 或其值是不是为 Empty 等价于  result = (value) == null || (value) ==
String.Empty;

参数 value :类型:System.String ,要测量检验的字符串。

归来值 类型:System.Boolean, 倘若 value 参数为 null 或空字符串
(“”),则赶回 true;不然重临 false。

 

三.Nullable可空类型

Nullable<Int32>,读作“可空的 Int32”,能够被赋值为 -2147483648 到
2147483647 之间的放肆值,也得以被赋值为 null 值。

Nullable<bool> 可以被赋值为 true 或 false,或
null。在拍卖数据库和其余满含恐怕未赋值的成分的数据类型时,将 null
赋值给数值类型或布尔型的法力特别有用。

比如说,数据库中的布尔型字段能够积存值 true 或
false,或然,该字段也足以未定义。 

可空类型具备以下特点:  ·可空类型表示可被赋值为 null
值的值类型变量。不恐怕成立基于援用类型的可空类型。(引用类型已协理 null
值。)。 

·语法 T? 是 System.Nullable<T> 的简写,此处的 T
为值类型。那二种情势得以交流。  ·

为可空类型赋值与为日常值类型赋值的不二等秘书籍风姿罗曼蒂克致,如 int? x = 10; 或 double? d
= 4.108;。 

·假诺底工项指标值为 null,请使用 System.Nullable.GetValueOrDefault
属性重返该底蕴项目所赋的值或默许值,

举个例子 int j = x.GetValueOrDefault();  ·请使用 HasValue 和 Value
只读属性测量检验是或不是为空和查找值,比方 if(x.HasValue) j = x.Value;  
假若此变量包蕴值,则 HasValue 属性重回True;也许,借使此变量的值为空,则赶回 False。   假如已赋值,则 Value
属性再次回到该值,不然将引发 System.InvalidOperationException。 

  可空类型变量的暗许值将 HasValue 设置为 false。未定义 Value。  ·使用 ??
运算符分配默许值,当前值为空的可空类型被赋值给非空类型时将运用该私下认可值,

如 int? x = null; int y = x ?? -1;。 

·分歧意行使嵌套的可空类型。将不编写翻译下边风华正茂行:Nullable<Nullable<int>>
n; 

程序代码

class NullableExample 

{  

   static void Main()

    {  

     int? num = null;  

    if (num.HasValue == true) 

     {  

      System.Console.WriteLine(“num = ” + num.Value); 

     } 

     else 

    {  

      System.Console.WriteLine(“num = Null”); 

     }  

    // 赋值为可空类型的暗中同意值 int y = num.GetValueOrDefault();  

    // 假如num.HasValue重返false,则num.Value将会引发
InvalidOperationException非凡 

    try

    {

        y = num.Value;

     }  

     catch (System.InvalidOperationException e) 

    {  

      System.Console.WriteLine(e.Message); 

    } 

   } 

}  

上述将展示输出:  num = Null   Nullable object must have a value.

 

基类型(基本类型)

Nullable 类型用?构造,如:int?是整型int的Nullable 类型,三个Nullable
类型的基类型必需是值类型,

如int是值类型,它的Nullable 就是int? 如: int i=0; int? j=null;
基类型不能够是援用类型,如: string s=”abc”; string? s=null;//错误

 

可空的流年类型调换为string时索要介意:

Nullable<System.DateTime> SendTime;

string timeStr=SendTime.HasValue ? Send提姆e.Value.ToString(“yyyy-MM-dd
hh:mm:ss”) : “当前变量为null”;

HasValue :
获取三个值,提示当前的System.Nullable<T>对象是或不是有值。重返True和False.

admin

网站地图xml地图