AWS Config Правила позволяют применять это требование с помощью управляемого правила AWS, называемого required-tags . Поскольку это управляемое правило, вам не нужно создавать функцию lamdba.
Единственная вещь я могу думать об этом, может использоваться, что-то вдоль этих строк:
var settings = ConfigurationSection.AppSettings;
var connectionString = settings<string>["connectionString"];
var timeout = settings<int>["timeout"];
, Но это на самом деле не покупает Вас ничто. Вы только что заменили круглые круглые скобки (в качестве в (int)settings["timeout"]
) с угловыми скобками, но не получили дополнительной безопасности типов, как можно свободно сделать
var timeout = settings<int>["connectionString"];
, Если у Вас есть что-то, что это сильно, но не со статическим контролем типов, Вы могли бы хотеть ожидать до C# 4.0 с динамичный ключевое слово.
Свойства не могут быть универсальными в C#2.0/3.0 поэтому, у Вас не может быть универсального индексатора.
Я не знаю, почему, но индексаторы просто синтаксический сахар. Запишите общий метод вместо этого, и Вы получите ту же функциональность. Например:
public T GetItem<T>(string key)
{
/* Return generic type T. */
}
Вы можете; просто отбросьте эти <T>
часть от Вашего объявления, и это будет хорошо работать. т.е.
public T this[string key]
{
get { /* Return generic type T. */ }
}
(Принятие Вашего класса универсально с параметром типа, названным T
).
Вот место, где это было бы полезно. Скажем, у вас есть настоятельно набранный дополнительный ключ
для объявления опций.
public static class DefaultOptions
{
public static OptionKey<bool> SomeBooleanOption { get; }
public static OptionKey<int> SomeIntegerOption { get; }
}
Там, где варианты выставляются через интерфейс IOPTIONS
:
public interface IOptions
{
/* since options have a default value that can be returned if nothing's
* been set for the key, it'd be nice to use the property instead of the
* pair of methods.
*/
T this<T>[OptionKey<T> key]
{
get;
set;
}
T GetOptionValue<T>(OptionKey<T> key);
void SetOptionValue<T>(OptionKey<T> key, T value);
}
код может затем использовать универсальный индексатор как приятные сильно напечатанные параметры магазина:
void Foo()
{
IOptions o = ...;
o[DefaultOptions.SomeBooleanOption] = true;
int integerValue = o[DefaultOptions.SomeIntegerOption];
}