C# 委托 Action<T>

 1         Thread BackgroundThread;
 2         private void button1_Click(object sender, EventArgs e)
 3         {
 4             if (BackgroundThread == null)
 5             {
 6                 BackgroundThread = new Thread(new ThreadStart(ThreadMethod));
 7                 BackgroundThread.IsBackground = true;
 8                 BackgroundThread.Start();
 9             }
10         }
11
12         void ThreadMethod()
13         {
14             int value = 0;
15             Action<int> UiDelegate = delegate(int DisValue)
16             {
17                 label24.Text = DisValue.ToString();
18             };
19             while (true)
20             {
21                 value++;
22                 label24.Invoke(UiDelegate, value);
23                 Thread.Sleep(1000);
24             }
25         }
时间: 2024-11-11 03:09:02

C# 委托 Action<T>的相关文章

C#委托Action、Action&lt;T&gt;、Func&lt;T&gt;、Predicate&lt;T&gt;

CLR环境中给我们内置了几个常用委托Action. Action<T>.Func<T>.Predicate<T>,一般我们要用到委托的时候,尽量不要自己再定义一 个委托了,就用系统内置的这几个已经能够满足大部分的需求,且让代码符合规范. 一.Action Action封装的方法没有参数也没有返回值,声明原型为: 1 public delegate void Action(); 用法如下: 1 public void Alert() 2 { 3 Console.Write

C#语法糖之第五篇: 泛型委托- Action&lt;T&gt;

因为工作的原因(其实还是个人的惰性)昨天没有给大家分享文章,然后这几天也有很多园友也提出了他们报告的意见及指导,再次感谢这些兄弟们的照顾我 和支持,这个分类的文章我当时想的是把我的学习经验和工作中用到的语法给大家分享给大家,希望能起到帮助的作用,但是本人也是个菜鸟,不是什么大神,所以 学习中也有不足的地方和没有扫到的地方,这里对上次扩展方法语法糖的问题,扩展方法确实是3.0开始就有了,或许是我以前没有用到,也没有查询欠缺,若要给大家带来不便,请大家原谅,现在把标题也修改为C#语法糖了,这里给大家

[转]C#委托Action、Action&lt;T&gt;、Func&lt;T&gt;、Predicate&lt;T&gt;

CLR环境中给我们内置了几个常用委托Action. Action<T>.Func<T>.Predicate<T>,一般我们要用到委托的时候,尽量不要自己再定义一 个委托了,就用系统内置的这几个已经能够满足大部分的需求,且让代码符合规范. 一.Action Action封装的方法没有参数也没有返回值,声明原型为: 1 public delegate void Action(); 用法如下: 复制代码 1  public void Alert() 2  { 3     Co

C#学习笔记:泛型委托Action&lt;T&gt;和Fun&lt;TResult&gt;

转自:http://www.cnblogs.com/Joetao/articles/2094271.html 本节学习了泛型委托Action<T>和Fun<TResult>两类特殊的委托,这两个特殊的委托是Dot FrameWrok自带的.结合lambda表达式,可以在写程序时,简洁代码和提高编码效率. (一)Action<T>和Fun<TResult>两个委托的不同点: Action<T>只能委托必须是无返回值的方法 Fun<TResul

[C#] 委托Action和Func

一.说明 一般我们定义委托都是有如下两步: public delegate void MyDelegate(string name);//定义委托public MyDelegate myDelegate; //使用委托 .csharpcode, .csharpcode pre { font-size: small; color: black; font-family: consolas, "Courier New", courier, monospace; background-col

C#委托(Action、Func、predicate)

Predicate 泛型委托:表示定义一组条件并确定指定对象是否符合这些条件的方法.此委托由 Array 和 List 类的几种方法使用,用于在集合中搜索元素. public delegate bool Predicate<T>(T obj);类型参数介绍:T: 要比较的对象的类型.obj: 要按照由此委托表示的方法中定义的条件进行比较的对象.返回值:如果 obj 符合由此委托表示的方法中定义的条件,则为 true:否则为 false. List<String> listStrin

C# 委托 Action Func

Action<T> : 传递参数,只进不出,所以方法为void Func<in T, out Tv> : 传递参数,有进有出,所以传递的方法要return using System; using System.Collections.Generic; using System.Linq; namespace rooxml { public class main { public delegate void fucA(string s); public static void Mai

C# 匿名方法 委托 Action委托 Delegate委托

原文地址:https://msdn.microsoft.com/zh-cn/library/bb882516.aspx 匿名函数是一个“内联”语句或表达式,可在需要委托类型的任何地方使用. 可以使用匿名函数来初始化命名委托,或传递命名委托(而不是命名委托类型)作为方法参数. C# 2.0 引入了匿名方法,而在 C# 3.0 及更高版本中,Lambda 表达式取代了匿名方法,作为编写内联代码的首选方式. 实例参考: 1 using System; 2 using System.Collection

委托delegate 泛型委托action&lt;&gt; 返回值泛型委托Func&lt;&gt; 匿名方法 lambda表达式 的理解

1.使用简单委托 namespace 简单委托 { class Program { //委托方法签名 delegate void MyBookDel(int a); //定义委托 static MyBookDel myBookDel; //普通方法 public static void MathBook(int a) { Console.WriteLine("我是数学书" + a); } static void Main(string[] args) { myBookDel += Ma