知识补充
进程:计算机概念,程序在服务器运行时占据全部计算资源综总和
虚拟的,
线程:计算机概念,进程在响应操作时最小单位,也包含CPU 内存 网络 硬盘IO
虚拟的概念,更加看不见摸不着
一个进程会包含多个线程;线程隶属于某个进程,进程销毁线程也就没了
句柄:其实是个long数字,是操作系统标识应用程序
多线程:计算机概念,一个进程有多个线程同时运行
C#里面的多线程:
Thread类是C#语言对线程对象的一个封装
为什么可以多线程呢?
1 多个CPU的核可以并行工作,
4核8线程,这里的线程指的是模拟核
2 CPU分片,1s的处理能力分成1000份,操作系统调度着去响应不同的任务
从宏观角度来说,感觉就是多个任务在并发执行
从微观角度来说,一个物理cpu同一时刻只能为一个任务服务
并行:多核之间叫并行
并发:CPU分片的并发
其实C#里面完成异步就是用的多线程技术实现的
下面将展示异步调用方法
DoSomethingLong方法
/// <summary>
/// 一个比较耗时耗资源的私有方法
/// </summary>
/// <param name="name"></param>
private void DoSomethingLong(string name)
{
Console.WriteLine($"****************DoSomethingLong Start {name} {Thread.CurrentThread.ManagedThreadId.ToString("00")} {DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff")}***************");
long lResult = 0;
for (int i = 0; i < 1_000_000_000; i++)
{
lResult += i;
}
//Thread.Sleep(2000);
Console.WriteLine($"****************DoSomethingLong End {name} {Thread.CurrentThread.ManagedThreadId.ToString("00")} {DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff")} {lResult}***************");
}
处理回调方式一
//Action委托,传入参数为string
Action<string> action = this.DoSomethingLong;
//AsyncCallback回调:将后续动作通过回调参数传递进去,子线程完成计算后,去调用这个回调委托
AsyncCallback callback = ar =>
{
Console.WriteLine($"btnAsyncAdvanced_Click计算成功了。{ar.AsyncState}。{Thread.CurrentThread.ManagedThreadId.ToString("00")}");
};
//BeginInvoke,第一个参数为DoSomethingLong方法传入的参数,第二个参数为回调,第三个参数为回调传入的参数,可以通过ar.AsyncState获取
action.BeginInvoke("Method", callback, "花生");
执行结果
处理回调方式二(可以用来完成进度条功能)
int i = 0;
Action<string> action = this.DoSomethingLong;
AsyncCallback callback = ar =>
{
Console.WriteLine($"btnAsyncAdvanced_Click计算成功了。{ar.AsyncState}。{Thread.CurrentThread.ManagedThreadId.ToString("00")}");
};
IAsyncResult asyncResult = action.BeginInvoke("Method", callback, "花生");
while (!asyncResult.IsCompleted)
{
if (i < 9)
{
Console.WriteLine($"中华民族复兴完成{++i * 10}%....");
}
else
{
Console.WriteLine($"中华民族复兴完成99.999999%....");
}
Thread.Sleep(200);
}
Console.WriteLine("中华民族复兴已完成,沉睡的东方雄狮已觉醒!");
等待异步处理完成方式一
asyncResult.AsyncWaitHandle.WaitOne(-1);//一直等待任务完成
asyncResult.AsyncWaitHandle.WaitOne(1000);//最多等待1000ms,超时就不等了
等待异步处理完成方式二
Func<int> func = () =>
{
Thread.Sleep(2000);
return DateTime.Now.Hour;
};
int iResult = func.Invoke();//22
IAsyncResult asyncResult = func.BeginInvoke(ar =>
{
//int iEndResult = func.EndInvoke(asyncResult);这个只能出现一次
//回调出现
//int iEndResultIn = func.EndInvoke(ar);
}, null);
//主线程出现
int iEndResult = func.EndInvoke(asyncResult);//22