多线程,多进程

visitNet(); 访问网络
visitDataBase( ); 访问数据库
updateUserInterface( ); 更新界面

进程和线程
进程:正在执行的程序
线程:一条独立的执行路线
一个进程可以只有一条线程,也可以有多条线程

为什么要开启多线程?
1,执行某些耗时任务
2,希望某些程序看起来像同时执行
3,希望完成某个特点的子任务
4,防止线程阻塞

开启多线程是提高了效率吗?
不是,反而降低了执行效率,但是提高了CPU的使用率
合理利用CPU使用率

java中开启了几个线程?
至少有两个
1,主线程
2,垃圾回收线程

多线程:具有完成特定功能的路径,是CPU最优先执行单位
CPU在某个时间刻度上只能执行一条线程的一条原子性语句

CPU的执行原理
1,真是情况下,CPU能够同时执行多个程序,本质只是在同一个时间刻度上执行一条线程的一条原子性语句,只不过CPU切换速度块,我们无法察觉以为是在同时执行。
2,并发和并行
并发:在同一时间段同时执行(看起来像同时执行,一个CPU)
并行:在统一时间刻度上同时执行(真正意义上的同时执行,比如多核处理器)
3,同步和异步
同步:并发情况下会出现同步问题
异步:能够同一个时间段处理多个任务

多线程和多进程好处
1,多线程提高进程的使用率,从而提高CPU的使用率
(如执行一些耗时操作,上次下载文件,访问数据库,更新界面等等…防止出现线程阻塞的现象)
2,多进程直接提高了CPU的使用率
(在操作系统中 同时运行多个程序)

进程: 一个独立的正在执行的程序
线程:一个进程的最基本执行单元,执行路径

注意:
1,在用一个时间点一个CPU钟只可能有一个县城在执行。
2,多线程不能提高效率,反而会降低效率,但是可以提高CPU的使用率
3,一个进程如果有多条执行路径,则成为多线程程序
4,java虚拟机的启动至少开启了两条线程,主线程和垃圾回收线程
5,一个线程可以理解为进程的子任务

你可能感兴趣的:(多线程,多进程)