标签:char 转化 检查 null name 注释 缓冲 目标变量 lock
字符串是Unicode字符串数组,且是不可变的
这种操作不会影响到原来的字符串,它会新添加一个副本。
有关Split的操作
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Reflection; using System.Runtime.CompilerServices; using System.Diagnostics; namespace ConsoleApp2 { class Program { static void Main(string[] args) { string s1 = "hi there! this, is: a string."; char[] delimiter = { ‘ ‘, ‘!‘, ‘,‘, ‘.‘,‘:‘ }; string[] words = s1.Split(delimiter, StringSplitOptions.RemoveEmptyEntries); foreach (string s in words) { Console.WriteLine(s); } } } }
StringBuilder类可以帮助你动态,有效的产生字符串,并且避免创建许多副本
StringBuilder类是BCL的成员,位于Syste.Text命名空间中,是Unicode的可变数组
创建了StringBuilder对象之后,类分配一个比当前字符串长度更长的缓冲区,只有缓冲区能容纳对字符串的改变就不会分配内存
如果大于当前的缓存,就会分配更大的缓冲区,把字符串复制其中,和原来的缓冲区区一样。
所有的预定义的简单类型都有一个叫做Parse的静态方法,它接受一个表示这个类型的字符串值,并且把它转化为类型的实际值
每一个具有Parse方法的内置类型都有一个TryParse方法
TryParse方法接受两个参数并且返回一个bool值
第一个是希望转化的字符串
第二个是指向目标变量的引用的out参数
如果TryParse成功,返回true,否则返回false
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Reflection; using System.Runtime.CompilerServices; using System.Diagnostics; namespace ConsoleApp2 { class Program { static void Main(string[] args) { string parseResultSummary; string stringFirst = "28"; int intFirst; bool success = int.TryParse(stringFirst, out intFirst); parseResultSummary = success ? "was successfully pared" : "was not successfully parsed"; Console.WriteLine("String {0} {1}",stringFirst,parseResultSummary); string stringSecond = "vt750"; int intSecond; success = int.TryParse(stringSecond, out intSecond); parseResultSummary = success ? "was successfully parsed" : "was not successfully parsed"; Console.WriteLine("String {0} {1}", stringSecond, parseResultSummary); } } }
可空类型总是基于另外一个叫做基础类型的已经被声明的类型
要创建可空类型的变量,只需要在变量声明中的基础类型的名字后面加一个问号
使用可空类型必须确保变量不是null的,尝试读取一个null的变量会产生异常
由两个连续的问号组成
struct MyStruct{ public int x; public int y; public MyStruct(int xVal,int yVal) { x = xVal; y = yVal; } }
static void Main(string[] args) { MyStruct? mSNull = new MyStruct(5, 10); Console.WriteLine(mSNull.Value.x); }
前两种形式在程序终止后都不返回值给执行环境,后面的两种返回int,0通常表示成功。
参数 可以有0个或多个,即使没有参数,args参数也不会是null,而是是一个没有元素的数组
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Reflection; using System.Runtime.CompilerServices; using System.Diagnostics; namespace ConsoleApp2 { class MyClass { class MyCounter { public int Count { get; private set; } public static MyCounter operator ++(MyCounter current) { current.Count++; return current; } } private MyCounter counter;//嵌套类类型的字段 public MyClass() { counter = new MyCounter(); }//构造函数 public int Incr() { return (counter++).Count; }//构造函数 public int GetValue() { return counter.Count; }//获取计数值 } class Program { static void Main() { MyClass mc = new MyClass(); mc.Incr(); mc.Incr(); mc.Incr(); mc.Incr(); mc.Incr(); mc.Incr(); Console.WriteLine(mc.GetValue()); } } }
嵌套类型的可见性还会影响基类成员的继承,如果封闭类型是一个派生类,嵌套类型就可以统一使用相同的名字来隐藏成员。可以在嵌套类型的声明上使用new修饰符来显式隐藏。
嵌套类型中的this引用指的是嵌套类型的对象。如果嵌套类型的对象需要访问封闭类型,它必须持有封闭类型的引用。以下代码表示。把封闭对象提供的this引用作为参数传给嵌套类型的构造函数
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Reflection; using System.Runtime.CompilerServices; using System.Diagnostics; namespace ConsoleApp2 { class SomeClass//封闭类 { int Field1 = 15, Field2 = 20;//封闭类的字段 MyNested mn = null;//嵌套类的引用 public void PrintMyMembers() { mn.PrintOuterMembers();//调用嵌套类中的方法 } public SomeClass()//构造函数 { mn = new MyNested(this);//创建嵌套类实例 this给封闭类型传递引用 } class MyNested//嵌套类声明 { SomeClass sc = null;//封闭类的引用 public MyNested(SomeClass SC)//嵌套类的构造函数 { sc = SC;//存储嵌套类的引用 } public void PrintOuterMembers() { Console.WriteLine("Field1 : {0}",sc.Field1);//封闭字段 Console.WriteLine("Field2 : {0}",sc.Field2);//封闭字段 } } } class Program { static void Main() { SomeClass MySC = new SomeClass(); MySC.PrintMyMembers(); } } }
标签:char 转化 检查 null name 注释 缓冲 目标变量 lock
原文地址:https://www.cnblogs.com/yinghualuowu/p/9439389.html