一、概要
索引器使你可从语法上方便地创建类、结构或接口,以便客户端应用程序可以像访问数组一样访问它们。编译器将生成一个 Item 属性(或者如果存在 IndexerNameAttribute,也可以生成一个命名属性)和适当的访问器方法。在主要目标是封装内部集合或数组的类型中,常常要实现索引器。例如,假设有一个类 TempRecord,它表示 24 小时的周期内在 10 个不同时间点所记录的温度(单位为华氏度)。此类包含一个 float[] 类型的数组 temps,用于存储温度值。通过在此类中实现索引器,客户端可采用 float temp = tempRecord[4] 的形式(而非 float temp = tempRecord.temps[4])访问 TempRecord 实例中的温度。索引器表示法不但简化了客户端应用程序的语法;还使类及其目标更容易直观地为其它开发者所理解。
语法声明:
代码语言:javascript复制public int this[int param]
{
get { return array[param]; }
set { array[param] = value; }
}
二、应用场景
这里分享一下设计封装的角度使用索引器,场景是封装一个redis的helper类。在此之前我们先看一个简单的官方示例。
代码语言:javascript复制using System;
class SampleCollection<T>
{
// Declare an array to store the data elements.
private T[] arr = new T[100];
// Define the indexer to allow client code to use [] notation.
public T this[int i]
{
get { return arr[i]; }
set { arr[i] = value; }
}
}
class Program
{
static void Main()
{
var stringCollection = new SampleCollection<string>();
stringCollection[0] = "Hello, World";
Console.WriteLine(stringCollection[0]);
}
}
// The example displays the following output:
// Hello, World.
RedisHelper类的封装(伪代码),这样用的好处是不用在需要设置redis的db号而大费周章。
代码语言:javascript复制public class RedisHelper
{
private static readonly object _lockObj = new object();
private static RedisHelper _instance;
private int dbNum;
private RedisHelper() { }
public static RedisHelper Instance
{
get
{
if (_instance == null)
{
lock (_lockObj)
{
if (_instance == null)
{
_instance = new RedisHelper();
}
}
}
return _instance;
}
}
public RedisHelper this[int dbid]
{
get
{
dbNum = dbid;
return this;
}
}
public void StringSet(string content)
{
Console.WriteLine($"StringSet to redis db { dbNum }, input{ content }.");
}
}
调用:
代码语言:javascript复制RedisHelper.Instance[123].StringSet("测试数据");
运行效果:
Reference:
https://docs.microsoft.com/zh-cn/dotnet/csharp/language-reference/keywords/this?f1url=?appId=Dev16IDEF1&l=ZH-CN&k=k(thisCSharpKeyword);k(TargetFrameworkMoniker-.NETFramework,Version%3Dv4.0);k(DevLang-csharp)&rd=true?WT.mcid=WDIT-MVP-5004326
https://docs.microsoft.com/zh-cn/dotnet/csharp/programming-guide/indexers/using-indexers?WT.mc_id=WDIT-MVP-5004326
https://docs.microsoft.com/zh-cn/dotnet/csharp/programming-guide/indexers/?WT.mc_id=WDIT-MVP-5004326