分享
 
 
 

17.8 Indexers

王朝other·作者佚名  2006-05-15
窄屏简体版  字體: |||超大  

An indexer is a member that enables an object to be indexed in the same way

as an array. Indexers are declared

using indexer-declarations:

indexer-declaration:

attributesopt indexer-modifiersopt indexer-declarator {

accessor-declarations }

indexer-modifiers:

indexer-modifier

indexer-modifiers indexer-modifier

indexer-modifier:

new

public

protected

internal

private

virtual

sealed

override

abstract

extern

indexer-declarator:

type this [ formal-parameter-list ]

type interface-type . this [ formal-parameter-list ]

An indexer-declaration may include a set of attributes (§24) and a valid

combination of the four access modifiers

(§17.2.3), the new (§17.2.2), virtual (§17.5.3), override (§17.5.4),

sealed (§17.5.5), abstract (§17.5.6),

and extern (§17.5.7) modifiers.

Indexer declarations are subject to the same rules as method declarations (§

17.5) with regard to valid

combinations of modifiers, with the one exception being that the static

modifier is not permitted on an indexer

declaration.

The modifiers virtual, override, and abstract are mutually exclusive except

in one case. The abstract

and override modifiers may be used together so that an abstract indexer can

override a virtual one.

C# LANGUAGE SPECIFICATION

252

The type of an indexer declaration specifies the element type of the

indexer introduced by the declaration. Unless

the indexer is an explicit interface member implementation, the type is

followed by the keyword this. For an

explicit interface member implementation, the type is followed by an

interface-type, a ?.?, and the keyword

this. Unlike other members, indexers do not have user-defined names.

The formal-parameter-list specifies the parameters of the indexer. The

formal parameter list of an indexer

corresponds to that of a method (§17.5.1), except that at least one

parameter must be specified, and that the ref

and out parameter modifiers are not permitted.

The type of an indexer and each of the types referenced in the

formal-parameter-list must be at least as accessible

as the indexer itself (§10.5.4).

The accessor-declarations (§17.6.2), which must be enclosed in ?{? and ?}?

tokens, declare the accessors of the

indexer. The accessors specify the executable statements associated with

reading and writing indexer elements.

Even though the syntax for accessing an indexer element is the same as that

for an array element, an indexer

element is not classified as a variable. Thus, it is not possible to pass

an indexer element as a ref or out

argument.

The formal-parameter-list of an indexer defines the signature (§10.6) of

the indexer. Specifically, the signature of

an indexer consists of the number and types of its formal parameters. The

element type and names of the formal

parameters are not part of an indexer?s signature.

The signature of an indexer must differ from the signatures of all other

indexers declared in the same class.

Indexers and properties are very similar in concept, but differ in the

following ways:

? A property is identified by its name, whereas an indexer is identified by

its signature.

? A property is accessed through a simple-name (§14.5.2) or a

member-access (§14.5.4), whereas an indexer

element is accessed through an element-access (§14.5.6.2).

? A property can be a static member, whereas an indexer is always an

instance member.

? A get accessor of a property corresponds to a method with no parameters,

whereas a get accessor of an

indexer corresponds to a method with the same formal parameter list as the

indexer.

? A set accessor of a property corresponds to a method with a single

parameter named value, whereas a set

accessor of an indexer corresponds to a method with the same formal

parameter list as the indexer, plus an

additional parameter named value.

? It is a compile-time error for an indexer accessor to declare a local

variable with the same name as an indexer

parameter.

? In an overriding property declaration, the inherited property is accessed

using the syntax base.P, where P is

the property name. In an overriding indexer declaration, the inherited

indexer is accessed using the syntax

base[E], where E is a comma-separated list of expressions.

Aside from these differences, all rules defined in §17.6.2 and §17.6.3

apply to indexer accessors as well as to

property accessors.

When an indexer declaration includes an extern modifier, the indexer is

said to be an external indexer. Because

an external indexer declaration provides no actual implementation, each of

its accessor-declarations consists of a

semicolon.

[Example: The example below declares a BitArray class that implements an

indexer for accessing the

individual bits in the bit array.

using System;

class BitArray

{

int[] bits;

int length;

Chapter 17 Classes

253

public BitArray(int length) {

if (length < 0) throw new ArgumentException();

bits = new int[((length - 1) >> 5) + 1];

this.length = length;

}

public int Length {

get { return length; }

}

public bool this[int index] {

get {

if (index < 0 || index >= length) {

throw new IndexOutOfRangeException();

}

return (bits[index >> 5] & 1 << index) != 0;

}

set {

if (index < 0 || index >= length) {

throw new IndexOutOfRangeException();

}

if (value) {

bits[index >> 5] |= 1 << index;

}

else {

bits[index >> 5] &= ~(1 << index);

}

}

}

}

An instance of the BitArray class consumes substantially less memory than a

corresponding bool[] (since

each value of the former occupies only one bit instead of the latter?s one

byte), but it permits the same operations

as a bool[].

The following CountPrimes class uses a BitArray and the classical ?sieve?

algorithm to compute the number

of primes between 1 and a given maximum:

class CountPrimes

{

static int Count(int max) {

BitArray flags = new BitArray(max + 1);

int count = 1;

for (int i = 2; i <= max; i++) {

if (!flags[i]) {

for (int j = i * 2; j <= max; j += i) flags[j] = true;

count++;

}

}

return count;

}

static void Main(string[] args) {

int max = int.Parse(args[0]);

int count = Count(max);

Console.WriteLine("Found {0} primes between 1 and {1}", count, max);

}

}

Note that the syntax for accessing elements of the BitArray is precisely

the same as for a bool[]. end

example]

[Example: The following example shows a 26×10 grid class that has an

indexer with two parameters. The first

parameter is required to be an upper- or lowercase letter in the range A?Z,

and the second is required to be an

integer in the range 0?9.

C# LANGUAGE SPECIFICATION

254

using System;

class Grid

{

const int NumRows = 26;

const int NumCols = 10;

int[,] cells = new int[NumRows, NumCols];

public int this[char c, int colm]

{

get {

c = Char.ToUpper(c);

if (c < ’A’ || c > ’Z’) {

throw new ArgumentException();

}

if (colm < 0 || colm >= NumCols) {

throw new IndexOutOfRangeException();

}

return cells[c - ’A’, colm];

}

set {

c = Char.ToUpper(c);

if (c < ’A’ || c > ’Z’) {

throw new ArgumentException();

}

if (colm < 0 || colm >= NumCols) {

throw new IndexOutOfRangeException();

}

cells[c - ’A’, colm] = value;

}

}

}

end example]

17.8.1 Indexer overloading

The indexer overload resolution rules are described in §14.4.2.

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有