- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Asp.Net中的Action和Func委托实现由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
前言 。
最近在阅读某开源框架源码的时候,发现作者在其中运用了很多 Action委托 和 Func委托 ,虽然我之前在项目中也有一些对委托的实操,但还是免不了长时间的不用,当初消化的一些委托基础都遗忘了。。。索性,趁热打铁,借助这次分享的机会,也帮自己重新巩固下.Net中关于委托的一些基础用法.
直奔主题 。
从.Net Framework1.0开始就为我们提供了委托的功能使用。那个时候.Net内置委托Action和Func还没有问世,那么,我们先来看看1.0版本时候的委托。委托从字面上来理解就是“帮别人干活”,具体干活的内容交给了“方法”,所以通俗点理解—— 委托通常被用来表示对一个方法的调用 。具体怎么用,我们接着往下看.
声明委托 。
格式:
形如:
1
2
3
4
5
6
7
8
9
10
11
|
/// <summary>
/// 声明委托
/// </summary>
public
delegate
void
BuyGoodsDelegate(
string
Name);
/// <summary>
/// 委托的方法
/// </summary>
public
void
BuyGoods(
string
Name)
{
Console.WriteLine($
"小明让我去买{Name}"
);
}
|
委托和方法关联 。
在声明了委托和定义好方法之后,我们需要将委托和方法进行关联,这样委托才能知道自己要调用的是哪个方法.
1
2
|
//委托和方法关联
BuyGoodsDelegate buyGoods =
new
BuyGoodsDelegate(BuyGoods);
|
委托调用方法 。
将委托和方法进行关联之后,我们就可以直接操作委托实例来进行方法的调用,调用方式和直接调用方法差不多.
1
2
3
4
|
//调用方式1
buyGoods(
"鞋子"
);
//调用方式2
buyGoods.Invoke(
"衣服"
);
|
4.效果 。
有了上面的使用之后,我们会发现委托基本都是根据具体方法来声明的,如果不同的方法有3个,4个或者更多的参数,显然,我们需要分别声明不同参数个数的委托,不经意间多了一道“声明委托”的门槛。于是,在.Net Framework3.5版本之后发布了.Net自带的内置委托Action和Func。我们 不用再做“声明委托”的工作 ,直接可以使用.
Action委托 。
Action委托 提供无参数、有参数方法,但不提供返回类型 ,具有Action、Action<T>、Action<T1,T2>、Action<T1,T2,T3>……Action<T1,……T16>多达16个参数的形式,其中传入参数均采用泛型T,涵盖了几乎所有可能存在的无返回值的委托类型.
Func委托 。
Func委托 提供无参数、有参数方法,同时提供返回类型 ,具有Func<TResult>、Func<T,Tresult>……Func<T1,T2,T3……,Tresult>17种类型重载,T1……T16为参数,Tresult为返回类型.
前面我们说,Action委托和Func委托不用再声明,便可直接使用,除了这一点,它们还支持 匿名函数、lamda表达式形式 .
普通函数调用 。
其中,Student是入参类型,string为返回参数类型 。
1
2
3
4
5
6
7
8
9
10
11
12
|
//委托和方法关联
Func<Student,
string
> funcNew = FuncTestDelegate;
/// <summary>
/// string返回类型方法
/// </summary>
/// <param name="student"></param>
/// <returns></returns>
public
string
FuncTestDelegate(Student student)
{
return
student.StudentName;
}
|
我们可以看到Func委托使用的时候,不用声明便可以直接使用.
匿名函数 。
匿名函数需要用关键字“delegate”声明 。
1
2
3
4
5
6
7
|
//Func 匿名函数
Func<
int
,
int
,
string
> func3 =
delegate
(
int
num1,
int
num2)
{
return
$
"Func:总和:{num1+ num2}"
;
};
//调用
var result = func3(10, 20);
|
lamda表达式 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
//Func lamda表达式 无参数
Func<
string
> func1 = () =>
{
return
"Func:你好"
;
};
var result = func1();
//Func lamda表达式 有参数
string
aa =
"ABC"
;
string
bb =
"DEF"
;
Func<
string
,
string
,
string
> func2 = (p1, p2) =>
{
return
$
"Func:{p1},你好{p2}"
;
};
result = func2(aa, bb);
|
Action委托实例 。
Action委托和Func委托的 唯一区别就是没有返回类型 ,其他用法都一样,当不需要返回类型的时候,直接用Action委托.
1
2
3
4
5
6
|
//Action lamda表达式
Action<
string
,
string
> action = (p1, p2) =>
{
Console.Write($
"Action:{p1},你好{p2}"
);
};
action(
"ABC"
,
"DEF"
);
|
小结 。
本文中,主要介绍了自定义委托以及.Net内置委托Action和Func的基础用法,以及他们之间的一些区别。总体上来看还是比较简单的,稍微动动手自己写一遍就能感受到其中的魅力。不多说了,希望充足自己的同时也能给更多的小伙伴的生活中加点盐.
到此这篇关于Asp.Net中的Action和Func委托的文章就介绍到这了,更多相关Asp.Net中的Action和Func委托内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。
原文链接:https://www.cnblogs.com/chenxf1117/p/14105319.html 。
最后此篇关于Asp.Net中的Action和Func委托实现的文章就讲到这里了,如果你想了解更多关于Asp.Net中的Action和Func委托实现的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我在等待异步功能完成时苦苦挣扎。特别是,我发现这两种方法在测试继续之前等待异步函数完成,但不知道其中的区别(如果有区别的话):。我的目标是在实际测试开始之前等待bepreEach()块中的两个异步函数
我在等待异步功能完成时苦苦挣扎。特别是,我发现这两种方法在测试继续之前等待异步函数完成,但不知道其中的区别(如果有区别的话):。我的目标是在实际测试开始之前,在beforeEach()块中等待两个Ja
为什么是Func<>从 Expression> 创建通过 .Compile() 比仅使用 Func<> 慢得多直接声明? 我刚从使用 Func 更改为直接声明为从 Expression> 创建的一个在
我正在创建一个 Validator类(class)。我正在尝试实现 Linq SelectMany我的验证器的扩展方法能够使用 Linq 查询组合表达式并验证最终结果,即使基础值发生变化也是如此。 下
function sum(a) { let currentSum = a; function f(b) { currentSum += b; return f; }
我只知道i = i++;是未定义的行为,但是如果一个表达式中调用了两个或多个函数,并且所有功能是一样的。是未定义吗?例如: int func(int a) { std::cout << a <
我如何定义一个对象,以便作用于它的任何函数都作用于它的一个字段?这可能吗? class Mydata(object): def __init__(self, val): sel
这个问题一直很有趣,尽管它不一定很整洁。我有以下代码: import random def d(m): return random.randint(1, m) print(3*d(6)) 这将
能否请您解释一下使用 func.apply(null, arr) 的区别?和 func.apply(this, arr)在下面的代码示例中? var Foo = function() { fu
我想收集/运行任务,然后对它们执行 Task.WhenAll。 var tasks = new List(); foreach (var thing in things) { tasks.Add(
我有以下代码: static Func s_objToString = (x) => x.ToString(); static Func s_stringToString = s_objToStrin
相关主题: Create Expression> dynamically 我在互联网上搜索但所有样本都解释了 Expression来自 T ? 谢谢 编辑 1) T输入我的代码在运行时确定,例如我想用
我正在尝试使用 LinqKit 动态生成 linqtosql 查询.在将表达式发送到 LinqKit 之前,我想检查要为预测添加的字段。所以我想出了一些想法,比如 Expression> GetPr
我遇到了一些麻烦,我写了一个 Func,IDE 不喜欢我在 Func 体内调用 Func ,我不太明白为什么,因为如果我将这个确切的代码放在方法体中,并使用相同的返回类型和参数,那么它就可以工作。 代
我现在正在学习使用 Class 语法来创建 React 组件,请注意我现在必须声明这样的方法: class Foo extends React.Component { ... bar
下面两种说法有区别吗?他们都工作。 if ( ((Func)(()=>true))() ) { .... }; if ( new Func(()=>true)()) { .... }; 最佳答案 不,
这个问题在这里已经有了答案: Difference between func() and (*this).func() in C++ (4 个答案) 关闭 6 年前。 如果我有一个带有虚函数而没有自
主要问题是“是否可以将任何类型的 func 作为参数传递以及如何传递?”。我正在学习 Go 并且想像这样制作我自己的异步包装函数: func AsyncFunc(fn func(), args ...
有没有简单的转换方法 Expression> 到 Expression> T从哪里继承自TBase? 最佳答案 只要 T 派生自 TBase,您就可以使用原始表达式的主体和参数直接创建所需类型的表达式
我有以下方法,其中 T 在 Func 中使用: public void DoSomething(string someString, Func someMethod) { if(some
我是一名优秀的程序员,十分优秀!