首页 > 代码库 > ylbtech-LanguageSamples-Indexers_2(索引器)
ylbtech-LanguageSamples-Indexers_2(索引器)
ylbtech-Microsoft-CSharpSamples:ylbtech-LanguageSamples-Indexers_2(索引器) |
1.A,示例(Sample) 返回顶部 |
Indexers_2 示例
本示例演示 C# 类如何声明索引器,以表示不同种类事物的类似数组的集合。 有关其他信息,请参见属性(C# 编程指南)。
安全说明 |
---|
提供此代码示例是为了阐释一个概念,它并不代表最安全的编码实践,因此不应在应用程序或网站中使用此代码示例。 对于因将此代码示例用于其他用途而发生的偶然或必然损害,Microsoft 不承担任何责任。 |
在 Visual Studio 中生成并运行 Indexers_2 示例
在“调试”菜单上,单击“开始执行(不调试)”。
从命令行生成并运行 Indexers_2 示例
在命令提示符处,键入以下命令:
csc indexers_2.csindexers_2
1.B,示例代码(Sample Code)返回顶部 |
1.B.1, Indexers_2.cs
// 版权所有(C) Microsoft Corporation。保留所有权利。// 此代码的发布遵从// Microsoft 公共许可(MS-PL,http://opensource.org/licenses/ms-pl.html)的条款。////版权所有(C) Microsoft Corporation。保留所有权利。// indexedproperty.csusing System;public class Document{ // 以下类型允许以类似字数组的方式查看文档: public class WordCollection { readonly Document document; // 包含文档 internal WordCollection(Document d) { document = d; } // Helper 函数 -- 从字符“begin”开始在字符数组“text”中搜索 // 字数“wordCount”。如果少于 // wordCount 字数,则返回 false。将“start”和 // “length”设置为文本中字的位置和长度: private bool GetWord(char[] text, int begin, int wordCount, out int start, out int length) { int end = text.Length; int count = 0; int inWord = -1; start = length = 0; for (int i = begin; i <= end; ++i) { bool isLetter = i < end && Char.IsLetterOrDigit(text[i]); if (inWord >= 0) { if (!isLetter) { if (count++ == wordCount) { start = inWord; length = i - inWord; return true; } inWord = -1; } } else { if (isLetter) inWord = i; } } return false; } // 获取和设置包含文档中的字的索引器: public string this[int index] { get { int start, length; if (GetWord(document.TextArray, 0, index, out start, out length)) return new string(document.TextArray, start, length); else throw new IndexOutOfRangeException(); } set { int start, length; if (GetWord(document.TextArray, 0, index, out start, out length)) { // 用字符串“value”替换位于 start/length 处的 // 字: if (length == value.Length) { Array.Copy(value.ToCharArray(), 0, document.TextArray, start, length); } else { char[] newText = new char[document.TextArray.Length + value.Length - length]; Array.Copy(document.TextArray, 0, newText, 0, start); Array.Copy(value.ToCharArray(), 0, newText, start, value.Length); Array.Copy(document.TextArray, start + length, newText, start + value.Length, document.TextArray.Length - start - length); document.TextArray = newText; } } else throw new IndexOutOfRangeException(); } } // 获取包含文档中字的计数: public int Count { get { int count = 0, start = 0, length = 0; while (GetWord(document.TextArray, start + length, 0, out start, out length)) ++count; return count; } } } // 以下类型允许以类似字符数组的方式查看文档 // : public class CharacterCollection { readonly Document document; // 包含文档 internal CharacterCollection(Document d) { document = d; } // 获取和设置包含文档中的字符的索引器: public char this[int index] { get { return document.TextArray[index]; } set { document.TextArray[index] = value; } } // 获取包含文档中字符的计数: public int Count { get { return document.TextArray.Length; } } } // 由于字段的类型具有索引器, // 因此这些字段显示为“索引属性”: public WordCollection Words; public CharacterCollection Characters; private char[] TextArray; // 文档的文本。 public Document(string initialText) { TextArray = initialText.ToCharArray(); Words = new WordCollection(this); Characters = new CharacterCollection(this); } public string Text { get { return new string(TextArray); } }}class Test{ static void Main() { Document d = new Document( "peter piper picked a peck of pickled peppers. How many pickled peppers did peter piper pick?" ); // 将单词“peter”更改为“penelope”: for (int i = 0; i < d.Words.Count; ++i) { if (d.Words[i] == "peter") d.Words[i] = "penelope"; } // 将字符“p”更改为“P” for (int i = 0; i < d.Characters.Count; ++i) { if (d.Characters[i] == ‘p‘) d.Characters[i] = ‘P‘; } Console.WriteLine(d.Text); }}
1.B.2,
1.C,下载地址(Free Download)返回顶部 |
作者:ylbtech 出处:http://ylbtech.cnblogs.com/ 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。 |
ylbtech-LanguageSamples-Indexers_2(索引器)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。