У меня есть функция, которая получает строку в качестве аргумента:
public async Task<List<string>> GetNames(string name)
{
...
}
Я хочу перегрузить эту функцию примерно так:
public async Task<List<string>> GetNames(string name = null)
{
...
}
Но в этом случае я получаю следующую ошибку:
"Type 'Nameservice' already defines a member called 'GetNames' with the same types".
Как я могу правильно перегрузить этот метод, чтобы использовать его, когда аргумент равен нулю.
во втором примере показан необязательный параметр. Вы не можете перегружать его. Вы намерены иметь другую реализацию для двух примеров, которые вы показываете? и если да, то в чем именно будет разница?
@NTINNEV Я не очень понимаю твой комментарий. Почему это актуально?
@MongZhu да, в первом случае, когда имя не равно нулю, я получаю некоторые данные из БД для этого имени, а затем сравниваю некоторые данные с именем. Если имя равно null, я этого не делаю
@MongZhu «Тип« Nameservice »уже определяет член с именем« GetNames »с теми же типами». Поскольку String всегда имеет значение NULL, эти два метода абсолютно одинаковы.
@NTINNEV «Поскольку String всегда может принимать значение NULL, эти два метода абсолютно одинаковы». Не совсем. Они одинаковы, потому что сигнатура, состоящая из имени и набора параметров, одинакова. Если сделать параметр необязательным, задав значение по умолчанию, это не изменит набор параметров, независимо от того, допускает ли он значение NULL или нет. Вы получите такое же сообщение об ошибке для параметра int: void Method( int a)
и void Method( int a = 0)
How can I overload this method properly to be used when argument is null.
Целью перегрузки является предоставление метода с тем же именем, но с другим набором параметров. Он не предназначен для утверждения о значениях параметра. Если вы хотите сделать это, вам нужно будет сделать это внутри метода и в этом случае вызвать другой метод
public async Task<List<string>> GetNames(string name)
{
if (name is null)
{
return await GetNames();
}
else
{
// use "name"
}
}
public async Task<List<string>> GetNames()
{
// do something different
}
в целях разъяснения:
GetNames(string name = null)
это не перегрузка, потому что набор параметров остается прежним. Это делает параметр необязательным! так что он больше не нужен на вызывающем сайте.
Предлагая if (name is null)
вместо if (name == null)
Предложение @Fildor реализовано. Почему именно лучше?
Оператор "= = " мог потенциально может быть перегружен. "is" - более безопасная альтернатива.
Строка является ссылочным типом и всегда допускает значение NULL.