一、单线程和多线程的区别
单线程指的是程序在执行时只有一个流程,也就是一次只能执行一个任务。当程序中某个任务需要花费大量时间时,单线程会导致整个程序阻塞,用户体验会变差。
多线程则是指程序在执行时可以同时执行多个任务,每个任务都是一个独立的线程。多线程可以充分利用多核处理器的优势,提高程序的运行效率。同时,多线程也可以避免某个任务阻塞导致整个程序停止响应的情况。
总的来说,单线程适合简单的任务或者不涉及大量计算的情况,而多线程适合需要处理大量计算或者需要同时进行多个任务的情况。在实际编程中,根据具体的需求来选择单线程还是多线程是很重要的。
二、计算密集型和IO密集型
1、计算密集型
计算任务中大部分时间花费在进行实际的计算操作上。这种情况下,计算机的CPU负载较高,而IO设备可能处于空闲状态。典型的计算密集型任务包括复杂的数学运算、图像处理、视频编解码等。在处理计算密集型任务时,通常需要考虑如何充分利用CPU资源,以提高计算效率。
2、IO密集型
计算任务中大部分时间花费在等待输入输出操作上,而不是实际的计算操作。这种情况下,计算机的CPU可能会空闲,等待IO操作完成。典型的IO密集型任务包括文件操作、网络通信等。在处理IO密集型任务时,通常需要考虑如何优化IO操作的效率,以提高整体性能。
三、线程并发的概念
补充:并行和并发的区别
并发:指同一个时间段里面,多个程序和任务看似同时执行。
实际上,在单核的处理器上,不存在同一时刻,同时执行的程序,操作系统通过快速频繁切换线程来实现多个任务同时执行的效果。
在多核的处理器上,存在并行执行的可能。
并行:在同一时刻,多个任务同时执行。通常出现在具有多核处理器的系统中,每个核心执行不同的任务。
线程并发(Concurrency with Threads)是指在计算机系统中,多个线程或进程同时执行的能力。线程并发是现代多核处理器和多任务操作系统的基本特征之一,它允许应用程序在多个线程之间分配任务,从而提高系统的整体性能和响应性。
a.exec()代码模拟(理解执行原理,不是具体代码)
while(1)
{
//scanf(...);
//等着用户键盘或者鼠标的操作操作
getmessage();//消息接收
postmessage();//消息处理
switch(msg){
case 鼠标移动:
调用鼠标移动的函数
break;
case 鼠标点击:
调用鼠标