不同窗体处于不同线程,相互之间需要通信时,需要用到委托
或事件
。
一
Form1.cs
:1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18using System.Windows.Forms;
namespace SelfLianXiDelegate
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
public void ChangeLblText(string str)
{
this.lblCounter.Text = str;
}
}
}
Form2.cs
:1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30using System;
using System.Windows.Forms;
namespace SelfLianXiDelegate
{
//public delegate void AddCounter(string str);
public partial class Form2 : Form
{
//public AddCounter addCounter;
Action<string> addCounter;
public Form2()
{
InitializeComponent();
Form1 form1 = new Form1();
addCounter = form1.ChangeLblText;
form1.Show();
}
int count = 0;
private void btnCounter_Click(object sender, EventArgs e)
{
count++;
if (addCounter != null) {
addCounter(count.ToString());
}
}
}
}
Program.cs
:1
2
3
4
5
6
7
8
9
10
11
12
13
14using System.Windows.Forms;
namespace SelfLianXiDelegate
{
class Program
{
static void Main(string[] args)
{
Application.EnableVisualStyles();
Application.SetCompatibleTextRenderingDefault(false);
Application.Run(new Form2());
}
}
}
输出:
二
按照事件的写法,这样子可能更标准一点。
FrmA.cs 发布者
:1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25using System;
using System.Windows.Forms;
namespace SelfLianXiDelegate
{
public delegate void AddCounter(string str); // [1]声明委托
public partial class FrmA : Form
{
public AddCounter addCounter; // [2]创建委托
//public event Action<string> addCounter; // [2]创建事件
public FrmA()
{
InitializeComponent();
}
int count = 0;
private void btnCounter_Click(object sender, EventArgs e)
{
count++;
addCounter?.Invoke(count.ToString()); // [3]发布事件
}
}
}
FrmB.cs 订阅者
:
1 | using System.Windows.Forms; |
主程序
:
1 | using System.Windows.Forms; |
输出:
三
事件本质上就是委托的运用。但是直接用委托有种情况不安全,在订阅者中可以让委托 = null
,全部失效。事件就不一样,只允许+=
和-+
,除非自己的内部可以使用=
。