https://blog.csdn.net/wanglui1990/article/details/79303894
Func<ΤResult> 委托:代理(delegate)一个返回类型为「由参数指定的类型的值(TResul)」 的无参方法。使用 Func<ΤResult> 委托,无需显式定义一个委托与方法的关联。 Func<ΤResult>原型:
public delegate TResult Func<out TResult>()
Func<ΤResult>示例: 主方法
namespace 异步操作
{
class Program
{
static void Main(string[] args)
{
FuncDelegate fDel = new FuncDelegate();
fDel.ExplicitlyDeclaresTest();
fDel.SimplifiesByFuncT();
fDel.SimplifiesByFuncTAndAnonymousMethod();
fDel.SimplifiesByFuncTAndLambda();
fDel.ExtendFuncT();
ActionTtest aDel = new ActionTtest();
aDel.ExplicitlyDeclaresActionTTest();
aDel.SimplifiesByActionT();
aDel.SimplifiesByActionTAndAnonymousMethod();
aDel.SimplifiesByActionTAndLambda();
aDel.ExtendActionT();
Console.Read();
}
}
}
示例代码:
namespace 异步操作
{
Action<Τ> 委托:代理(delegate)无返回值 参数类型为 T 的无参方法。使用 Action<Τ> 委托,无需显式定义一个委托与方法的关联。 Action<Τ>原型:
public delegate void Action<in T>(
T obj
)
Action<Τ>示例代码:
namespace 异步操作
{
delegate void DisplayMessage(string message);
总结:以后如果要新建委托与方法关联,可简化代码如下(使用匿名方法+Lambda+Func<Τ>)。
//Func<bool> methodCall = () => output.SendToFile()
//methodCall()//执行 关联的方法()
Func<关联方法返回类型> methodCall = () => 关联的方法()//传递匿名无参方法() 并与想要执行方法关联(=>),可关联方法可任意参数,但必须有返回类型(无返回值的用Action<T>)。
methodCall()。//执行 关联的方法
|
请发表评论