博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
重拾C#教程:高级部分-索引器(Indexer)
阅读量:5930 次
发布时间:2019-06-19

本文共 3650 字,大约阅读时间需要 12 分钟。

重拾C#教程:高级部分-索引器(Indexer)

索引器(Indexer) 允许一个对象可以像数组一样被索引。当您为类定义一个索引器时,该类的行为就会像一个 虚拟数组(virtual array) 一样。您可以使用数组访问运算符([ ])来访问该类的实例。

语法

一维索引器的语法如下:

element-type this[int index] {
// get 访问器 get {
// 返回 index 指定的值 } // set 访问器 set {
// 设置 index 指定的值 }}

索引器(Indexer)的用途

索引器的行为的声明在某种程度上类似于属性(property)。就像属性(property),您可使用 get 和 set 访问器来定义索引器。但是,属性返回或设置一个特定的数据成员,而索引器返回或设置对象实例的一个特定值。换句话说,它把实例数据分为更小的部分,并索引每个部分,获取或设置每个部分。

定义一个属性(property)包括提供属性名称。索引器定义的时候不带有名称,但带有 this 关键字,它指向对象实例。下面的实例演示了这个概念:

using System;namespace IndexerApplication{
class IndexedNames {
private string[] namelist = new string[size]; static public int size = 10; public IndexedNames() {
for (int i = 0; i < size; i++) namelist[i] = "N. A."; } public string this[int index] {
get {
string tmp; if( index >= 0 && index <= size-1 ) {
tmp = namelist[index]; } else {
tmp = ""; } return ( tmp ); } set {
if( index >= 0 && index <= size-1 ) {
namelist[index] = value; } } } static void Main(string[] args) {
IndexedNames names = new IndexedNames(); names[0] = "Zara"; names[1] = "Riz"; names[2] = "Nuha"; names[3] = "Asif"; names[4] = "Davinder"; names[5] = "Sunil"; names[6] = "Rubic"; for ( int i = 0; i < IndexedNames.size; i++ ) {
Console.WriteLine(names[i]); } Console.ReadKey(); } }}

当上面的代码被编译和执行时,它会产生下列结果:

ZaraRizNuhaAsifDavinderSunilRubicN. A.N. A.N. A.

重载索引器(Indexer)

索引器(Indexer)可被重载。索引器声明的时候也可带有多个参数,且每个参数可以是不同的类型。没有必要让索引器必须是整型的。C# 允许索引器可以是其他类型,例如,字符串类型。

下面的实例演示了重载索引器:

using System;namespace IndexerApplication{
class IndexedNames {
private string[] namelist = new string[size]; static public int size = 10; public IndexedNames() {
for (int i = 0; i < size; i++) {
namelist[i] = "N. A."; } } public string this[int index] {
get {
string tmp; if( index >= 0 && index <= size-1 ) {
tmp = namelist[index]; } else {
tmp = ""; } return ( tmp ); } set {
if( index >= 0 && index <= size-1 ) {
namelist[index] = value; } } } public int this[string name] {
get {
int index = 0; while(index < size) {
if (namelist[index] == name) {
return index; } index++; } return index; } } static void Main(string[] args) {
IndexedNames names = new IndexedNames(); names[0] = "Zara"; names[1] = "Riz"; names[2] = "Nuha"; names[3] = "Asif"; names[4] = "Davinder"; names[5] = "Sunil"; names[6] = "Rubic"; // 使用带有 int 参数的第一个索引器 for (int i = 0; i < IndexedNames.size; i++) {
Console.WriteLine(names[i]); } // 使用带有 string 参数的第二个索引器 Console.WriteLine(names["Nuha"]); Console.ReadKey(); } }}

当上面的代码被编译和执行时,它会产生下列结果:

ZaraRizNuhaAsifDavinderSunilRubicN. A.N. A.N. A.2

转载地址:http://dlutx.baihongyu.com/

你可能感兴趣的文章
关于KMP算法的一些个人理解
查看>>
领域驱动设计,构建简单的新闻系统,20分钟够吗?
查看>>
SpringBoot 填坑 | CentOS7.4 环境下,MySQL5.7 表时间字段默认值设置失效
查看>>
thinkphp源码分析(一)—开门篇
查看>>
关于HTML的那些事
查看>>
基于MaxCompute打造轻盈的人人车移动端数据平台
查看>>
进制转换的那些事儿
查看>>
css选择器
查看>>
支付宝工程师创造出了一个可以“拷贝”支付宝的神器
查看>>
egg(92)--egg之商品列表数据渲染
查看>>
力扣(LeetCode)141
查看>>
正则整理
查看>>
区块链应用场景
查看>>
十分钟完成vscode配合Eslint使用
查看>>
Ajax学习笔记
查看>>
CentOS7 下安装 Mysql 8
查看>>
将Gradle项目发布到Maven Central库中
查看>>
微服务中消息总线架构设计应用
查看>>
使用truffle部署以太坊智能合约到区块链
查看>>
面向什么编程?
查看>>