Это не удается
string temp = () => {return "test";};
с ошибкой
Невозможно преобразовать лямбда-выражение в тип 'строка', потому что это не тип делегата
Что означает ошибка и как ее устранить?
Это не удается
string temp = () => {return "test";};
с ошибкой
Невозможно преобразовать лямбда-выражение в тип 'строка', потому что это не тип делегата
Что означает ошибка и как ее устранить?
Ответы:
Проблема здесь в том, что вы определили анонимный метод, который возвращает, string
но пытается назначить его напрямую string
. Это выражение, которое при вызове производит, а string
не напрямую string
. Его необходимо назначить совместимому типу делегата. В этом случае самый простой выбор -Func<string>
Func<string> temp = () => {return "test";};
Это можно сделать в одной строке с помощью небольшого приведения типов или использования конструктора делегата, чтобы установить тип лямбда-выражения, за которым следует вызов.
string temp = ((Func<string>)(() => { return "test"; }))();
string temp = new Func<string>(() => { return "test"; })();
Примечание. Оба образца можно сократить до формы выражения, в которой отсутствует { return ... }
Func<string> temp = () => "test";
string temp = ((Func<string>)(() => "test"))();
string temp = new Func<string>(() => "test")();
Func<string> temp = () => "test";
.
string temp = new Func<string>(() => "test")();
Вы пытаетесь назначить делегата функции строковому типу. Попробуй это:
Func<string> temp = () => {return "test";};
Теперь вы можете выполнить функцию следующим образом:
string s = temp();
Переменная «s» теперь будет иметь значение «test».
Используя небольшую вспомогательную функцию и дженерики, вы можете позволить компилятору определить тип и немного сократить его:
public static TOut FuncInvoke<TOut>(Func<TOut> func)
{
return func();
}
var temp = FuncInvoke(()=>"test");
Боковое примечание: это также хорошо, так как тогда вы можете вернуть анонимный тип:
var temp = FuncInvoke(()=>new {foo=1,bar=2});
вы можете использовать анонимный метод с аргументом:
int arg = 5;
string temp = ((Func<int, string>)((a) => { return a == 5 ? "correct" : "not correct"; }))(arg);
Анонимный метод может возвращать значение с помощью делегата func. Вот пример, в котором я показал, как вернуть значение с помощью анонимного метода.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace ConsoleApp1
{
class Program
{
static void Main(string[] args)
{
Func<int, int> del = delegate (int x)
{
return x * x;
};
int p= del(4);
Console.WriteLine(p);
Console.ReadLine();
}
}
}
Это еще один пример использования C # 8 ( также может работать с другими версиями .NET, поддерживающими параллельные задачи )
using System;
using System.Threading.Tasks;
namespace Exercise_1_Creating_and_Sharing_Tasks
{
internal static class Program
{
private static int TextLength(object o)
{
Console.WriteLine($"Task with id {Task.CurrentId} processing object {o}");
return o.ToString().Length;
}
private static void Main()
{
const string text1 = "Welcome";
const string text2 = "Hello";
var task1 = new Task<int>(() => TextLength(text1));
task1.Start();
var task2 = Task.Factory.StartNew(TextLength, text2);
Console.WriteLine($"Length of '{text1}' is {task1.Result}");
Console.WriteLine($"Length of '{text2}' is {task2.Result}");
Console.WriteLine("Main program done");
Console.ReadKey();
}
}
}