进程、多任务

 1.例如吃饭的时候玩手机,边上厕所边玩手机,看似是同时做多个事情,本质上我们的大脑在同一时间只做了一件事情,这就是多任务

 2.道路窄的时候容易造成拥堵,可以拓宽道路,加多车道,同一个方向可以有多辆车并排行驶,这就是多线程

 

普通调用只有主线程一条执行路径,效率较低;多线程有多条执行路径,主线程和子线程并行交替执行,效率能有所提高

 

 

程序是静态的,他执行起来就是一个进程,是动态的概念,一个进程可以包含多个线程,每个进程至少要有一个线程

  注意:很多的多线程是模拟出来的,真正的多线程是指有多个CPU,即多核;如果是模拟的多线程,在同一时间CPU只能执行一个程序,因为不同程序之间切换的速度快,会有多线程的部分效果。

 

自己写的多线程类需要继承Thread类或者实现Runnable/Callable接口,重写run方法,使用多线程要调用start方法,如果调用run方法则还是单线程

 

线程不一定立即执行,要有CPU调度安排

因为Java的单继承特性,所以建议实现接口来达到多线程的目的,

 

注意:多个线程操作同一个资源的情况下,线程不安全,容易造成数据紊乱,要解决并发问题

 

明天实现龟兔赛跑的案例,学习Callable接口的实现

 
 
 

进程、多任务

 1.例如吃饭的时候玩手机,边上厕所边玩手机,看似是同时做多个事情,本质上我们的大脑在同一时间只做了一件事情,这就是多任务

 2.道路窄的时候容易造成拥堵,可以拓宽道路,加多车道,同一个方向可以有多辆车并排行驶,这就是多线程

 

普通调用只有主线程一条执行路径,效率较低;多线程有多条执行路径,主线程和子线程并行交替执行,效率能有所提高

 

 

程序是静态的,他执行起来就是一个进程,是动态的概念,一个进程可以包含多个线程,每个进程至少要有一个线程

  注意:很多的多线程是模拟出来的,真正的多线程是指有多个CPU,即多核;如果是模拟的多线程,在同一时间CPU只能执行一个程序,因为不同程序之间切换的速度快,会有多线程的部分效果。

 

自己写的多线程类需要继承Thread类或者实现Runnable/Callable接口,重写run方法,使用多线程要调用start方法,如果调用run方法则还是单线程

 

线程不一定立即执行,要有CPU调度安排

因为Java的单继承特性,所以建议实现接口来达到多线程的目的,

 

注意:多个线程操作同一个资源的情况下,线程不安全,容易造成数据紊乱,要解决并发问题

 

明天实现龟兔赛跑的案例,学习Callable接口的实现