作者:luomo | 来源:互联网 | 2023-10-15 14:35
字符串字符串是Unicode字符串数组,且是不可变的这种操作不会影响到原来的字符串,它会新添加一个副本。有关Split的操作usingSystem;usingSyste
字符串
字符串是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类可以帮助你动态,有效的产生字符串,并且避免创建许多副本
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的变量会产生异常
- 使用方式一样
- 要检测可空类型是否有值,可以将它和null比较或检查他的hasValue属性
使用空接合运算符
由两个连续的问号组成
使用可空用户自定义类型
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);
}
Nullable
Main方法
前两种形式在程序终止后都不返回值给执行环境,后面的两种返回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();
}
}
}