C#数组和串操作经验总结
C#数组有很多值得学习的地方,这里我们主要介绍存放字符序列的C#数组,包括介绍C#串操作等方面
关于C#数组和C#串操作:
1)串是由连续存储的字符组成
2)C#中的串具有恒定不变的特性,即 一旦被创建,就不能改变长度或者改变其中任何的字符。
3)串的连接、插入和删除等操作都是生成了新串而没有改变原串。
4)继承自 System.object。所以是引用类型(int,bool,char 等都是struct 不是class,是值类型)。
5)System.String 是密封类,所以不能被继承。
6)虽然System.String 是引用类型,但C#中将String 看作是基元类型,所以不用 new操作符创建实例,而是使用字符串驻留的机制。
7)System.String 继承自 IComparable, ICloneable, IConvertible, IComparable
8)C#提供了StringBuilder类型来支持高效地动态创建字符串。
下面是自定义一个string类,类中包含一个字段,用以存放字符序列的C#数组,还有一些常用的C#串操作。
- public class StringDS
- {
- private char[] data;//char数组
- //索引器
- public char this[int index]
- {
- get
- {
- return data[index];
- }
- set
- {
- data[index] = value;
- }
- }
- //构造函数
- public StringDS(char[] arr)
- {
- data = new char[arr.Length];
- for (int i = 0; i < arr.Length; i++)
- {
- data[i] = arr[i];
- }
- }
- //构造函数
- public StringDS(int len)
- {
- char[] arr = new char[len];
- data = arr;
- }
- //求串长
- public int GetLength()
- {
- return data.Length;
- }
- //串比较
- public int Compare(StringDS s)
- {
- int len=((this.GetLength()<=s.GetLength())?
- this.GetLength():s.GetLength());
- int i = 0;
- for (i = 0; i < len; ++i)
- {
- if (this[i] != s[i])
- {
- break;
- }
- }
- if (i <= len)
- {
- if (this[i] < s[i])
- {
- return -1;
- }
- else if (this[i] > s[i])
- {
- return 1;
- }
- }
- else if (this.GetLength() == s.GetLength())
- {
- return 0;
- }
- else if (this.GetLength() < s.GetLength())
- {
- return -1;
- }
- return 1;
- }
- //求子串
- public StringDS SubString(int index, int len)
- {
- if ((index<0) || (index>this.GetLength()-1) || (len<0) || (len>this.GetLength()-index))
- {
- Console.WriteLine("Position or Length is error!");
- return null;
- }
- StringDS s = new StringDS(len);
- for (int i = 0; i < len; ++i)
- {
- s[i] = this[i + index-1];
- }
- return s;
- }
- //串连接
- public StringDS Concat(StringDS s)
- {
- StringDS s1 = new StringDS(this.GetLength() +s.GetLength());
- for (int i = 0; i < this.GetLength(); ++i)
- {
- s1.data[i] = this[i];
- }
- for (int j = 0; j < s.GetLength(); ++j)
- {
- s1.data[this.GetLength() + j] = s[j];
- }
- return s1;
- }
- //串插入
- public StringDS Insert(int index, StringDS s)
- {
- int len = s.GetLength();
- int lenlen2 = len + this.GetLength();
- StringDS s1 = new StringDS(len2);
- if (index < 0 || index > this.GetLength() - 1)
- {
- Console.WriteLine("Position is error!");
- return null;
- }
- for (int i = 0; i < index; ++i)
- {
- s1[i] = this[i];
- }
- for(int i = index; i < index + len ; ++i)
- {
- s1[i] = s[i - index];
- }
- for (int i = index + len; i < len2; ++i)
- {
- s1[i] = this[i - len];
- }
- return s1;
- }
- //串删除
- public StringDS Delete(int index, int len)
- {
- if ((index < 0) || (index > this.GetLength() - 1)
- || (len < 0) || (len > this.GetLength() - index))
- {
- Console.WriteLine("Position or Length is error!");
- return null;
- }
- StringDS s = new StringDS(this.GetLength() - len);
- for (int i = 0; i < index; ++i)
- {
- s[i] = this[i];
- }
- for (int i = index + len; i < this.GetLength(); ++i)
- {
- s[i] = this[i];
- }
- return s;
- }
- //串定位
- public int Index(StringDS s)
- {
- if (this.GetLength() < s.GetLength())
- {
- Console.WriteLine("There is not string s!");
- return -1;
- }
- int i = 0;
- int len = this.GetLength() - s.GetLength();
- while (i < len)
- {
- if (this.Compare(s) == 0)
- {
- break;
- }
- }
- if (i <= len)
- {
- return i;
- }
- return -1;
- }
- }
- 上一篇:分析CLR Via的方法参数相关
- 下一篇:经典讲解创建CLR存储过程