Esto falla
string temp = () => {return "test";};
con el error
No se puede convertir la expresión lambda al tipo 'cadena' porque no es un tipo delegado
¿Qué significa el error y cómo puedo solucionarlo?
Esto falla
string temp = () => {return "test";};
con el error
No se puede convertir la expresión lambda al tipo 'cadena' porque no es un tipo delegado
¿Qué significa el error y cómo puedo solucionarlo?
Respuestas:
El problema aquí es que ha definido un método anónimo que devuelve un string
pero está intentando asignarlo directamente a un string
. Es una expresión que cuando se invoca produce un string
no es directamente un string
. Debe asignarse a un tipo de delegado compatible. En este caso, la opción más sencilla esFunc<string>
Func<string> temp = () => {return "test";};
Esto se puede hacer en una línea mediante un poco de conversión o usando el constructor delegado para establecer el tipo de lambda seguido de una invocación.
string temp = ((Func<string>)(() => { return "test"; }))();
string temp = new Func<string>(() => { return "test"; })();
Nota: Ambas muestras se pueden acortar a la forma de expresión que carece de { 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")();
Está intentando asignar un delegado de función a un tipo de cadena. Prueba esto:
Func<string> temp = () => {return "test";};
Ahora puede ejecutar la función así:
string s = temp();
La variable "s" ahora tendrá el valor "prueba".
Usando una pequeña función auxiliar y genéricos, puede dejar que el compilador infiera el tipo y acortarlo un poco:
public static TOut FuncInvoke<TOut>(Func<TOut> func)
{
return func();
}
var temp = FuncInvoke(()=>"test");
Nota al margen: esto también es bueno, ya que luego puede devolver un tipo anónimo:
var temp = FuncInvoke(()=>new {foo=1,bar=2});
puedes usar un método anónimo con argumento:
int arg = 5;
string temp = ((Func<int, string>)((a) => { return a == 5 ? "correct" : "not correct"; }))(arg);
Un método anónimo puede devolver un valor usando un delegado func. Aquí hay un ejemplo en el que he mostrado cómo devolver un valor utilizando un método anónimo.
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();
}
}
}
Este es otro ejemplo que usa C # 8 ( también podría funcionar con otras versiones de .NET que admitan tareas paralelas )
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();
}
}
}