C#数组和串操作经验总结

C#数组有很多值得学习的地方,这里我们主要介绍存放字符序列的C#数组,包括介绍C#串操作等方面

旌德网站制作公司哪家好,找创新互联公司!从网页设计、网站建设、微信开发、APP开发、成都响应式网站建设公司等网站项目制作,到程序开发,运营维护。创新互联公司于2013年开始到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选创新互联公司

关于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 , IEnumerable , IEnumerable, IEquatable 。
8)C#提供了StringBuilder类型来支持高效地动态创建字符串。

下面是自定义一个string类,类中包含一个字段,用以存放字符序列的C#数组,还有一些常用的C#串操作。

 
 
 
  1. public class StringDS
  2. {
  3. private char[] data;//char数组
  4. //索引器
  5. public char this[int index]
  6. {
  7. get 
  8. {
  9. return data[index];
  10. }
  11. set
  12. {
  13. data[index] = value;
  14. }
  15. }
  16. //构造函数
  17. public StringDS(char[] arr)
  18. {
  19. data = new char[arr.Length];
  20. for (int i = 0; i < arr.Length; i++)
  21. {
  22. data[i] = arr[i];
  23. }
  24. }
  25. //构造函数 
  26. public StringDS(int len)
  27. {
  28. char[] arr = new char[len];
  29. data = arr;
  30. }
  31. //求串长 
  32. public int GetLength()
  33. {
  34. return data.Length;
  35. //串比较 
  36. public int Compare(StringDS s) 
  37. {
  38. int len=((this.GetLength()<=s.GetLength())? 
  39. this.GetLength():s.GetLength()); 
  40. int i = 0; 
  41. for (i = 0; i < len; ++i) 
  42. if (this[i] != s[i]) 
  43. break; 
  44. if (i <= len)
  45. {
  46. if (this[i] < s[i])
  47. {
  48. return -1;
  49. }
  50. else if (this[i] > s[i])
  51. {
  52. return 1;
  53. }
  54. }
  55. else if (this.GetLength() == s.GetLength())
  56. {
  57. return 0;
  58. }
  59. else if (this.GetLength() < s.GetLength())
  60. {
  61. return -1;
  62. }
  63. return 1;
  64. //求子串 
  65. public StringDS SubString(int index, int len) 
  66. if ((index<0) || (index>this.GetLength()-1) || (len<0) || (len>this.GetLength()-index)) 
  67. Console.WriteLine("Position or Length is error!"); 
  68. return null; 
  69. StringDS s = new StringDS(len); 
  70. for (int i = 0; i < len; ++i) 
  71. s[i] = this[i + index-1]; 
  72. return s; 
  73. //串连接 
  74. public StringDS Concat(StringDS s)
  75. {
  76. StringDS s1 = new StringDS(this.GetLength() +s.GetLength());
  77. for (int i = 0; i < this.GetLength(); ++i)
  78. {
  79. s1.data[i] = this[i];
  80. }
  81. for (int j = 0; j < s.GetLength(); ++j)
  82. {
  83. s1.data[this.GetLength() + j] = s[j];
  84. }
  85. return s1;
  86. //串插入 
  87. public StringDS Insert(int index, StringDS s) 
  88. int len = s.GetLength(); 
  89. int lenlen2 = len + this.GetLength(); 
  90. StringDS s1 = new StringDS(len2); 
  91. if (index < 0 || index > this.GetLength() - 1) 
  92. Console.WriteLine("Position is error!"); 
  93. return null; 
  94. for (int i = 0; i < index; ++i) 
  95. s1[i] = this[i]; 
  96. for(int i = index; i < index + len ; ++i) 
  97. s1[i] = s[i - index]; 
  98. for (int i = index + len; i < len2; ++i) 
  99. s1[i] = this[i - len]; 
  100. }
  101. return s1;
  102. }
  103. //串删除 
  104. public StringDS Delete(int index, int len)
  105. {
  106. if ((index < 0) || (index > this.GetLength() - 1)
  107. || (len < 0) || (len > this.GetLength() - index))
  108. {
  109. Console.WriteLine("Position or Length is error!");
  110. return null;
  111. }
  112. StringDS s = new StringDS(this.GetLength() - len);
  113. for (int i = 0; i < index; ++i)
  114. {
  115. s[i] = this[i];
  116. }
  117. for (int i = index + len; i < this.GetLength(); ++i)
  118. {
  119. s[i] = this[i];
  120. }
  121. return s;
  122. //串定位 
  123. public int Index(StringDS s) 
  124. if (this.GetLength() < s.GetLength()) 
  125. Console.WriteLine("There is not string s!"); 
  126. return -1; 
  127.  
  128. int i = 0; 
  129. int len = this.GetLength() - s.GetLength(); 
  130. while (i < len
  131. if (this.Compare(s) == 0) 
  132. {
  133. break;
  134. }
  135. }
  136. if (i <= len)
  137. {
  138. return i;
  139. }
  140. return -1;
  141. }

当前文章:C#数组和串操作经验总结
网站路径:http://www.shufengxianlan.com/qtweb/news42/214842.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联