1.并发和并行
单cpu,一个cpu处理任务,某个时刻只能处理一个任务调度,单线程
如一边听音乐一边写代码,你感觉cpu某刻只做一件事情,在多件事件中快速切换,肉眼感觉好像同时做了多个事情,并发执行
并发:两个或多个事件在同一时间段内发生,但是真正在某刻,只有一个事情在执行,cpu在快速的切换执行
并行:某一刻多个事情一起执行,多cpu,分布式,大数据,并行
2.进程和线程
进程:正在运行的软件,共享资源,同一个进程所在的内存空间是一起的。现在软件功能强大,不可能只有一个业务,可能会有多个功能模块,如qq:发消息 受消息,这多个功能之间也可能是并发执行的,这些功能看成一个任务,这些任务可以单独被cpu调度,单个的任务成为线程
线程:是cpu执行的最小单位的任务,一个进程可以由多个线程组成,如果只有一个线程,那么就是单线程的进程,现在进程都是多线程,线程是cpu调度的基本单位。每个线程都在争抢cpu,为了能够更快的执行自己。
3.为什么会有多线程?
多线程存在的原因是为了更好利用cpu,让cpu一直都在执行
4.多线程:java关于操作以及线程之间如何争抢cpu不需要程序员处理
Thread 线程类
现在我们所写的程序只有一个线程,主线程 main线程
方法:
currentThread() 获得当前线程
run()线程执行的步骤
start() 启动线程
setName() 修改线程名
getName() 获得线程名
setPriority(Thread.MAX_PRIORITY)设置线程优先级 Thread.NORM_PRIORITY Thread.MIN_PRIORITY
Thread.yield()礼让
Thread.sleep()睡眠阻塞
class MyThread1 extends Thread {
@Override
public void run() {
System.out.println("MyThread1");
}
}
class MyThread4 extends Thread {
@Override
public void run() {
// TODO Auto-generated method stub
System.out.println("MyThread2");
}
}
class MyThread3 extends Thread {
@Override
public void run() {
// TODO Auto-generated method stub
System.out.println("MyThread3");
}
}
public class Client {
public static void main(String[] args) {
MyThread1 thread1 = new MyThread1();
MyThread4 thread4 = new MyThread4();
MyThread3 thread3 = new MyThread3();
thread1.start();
thread4.start();
thread3.start();
//输出结果
}
}
输出结果不定
5.线程礼让,将cpu让出来
6.后台线程或守护线程:主线程消亡,我也消亡了
如GC,如果main执行完,GC也就退出了
7.总结
1.并发和并行
并发:同一时刻只有一个线程在执行,在同一时间段,多个线程交替执行,单cpu
并行:同一刻多个线程执行,多个cpu
2.进程和线程
进程:正在运行的软件
线程:cpu调度的任务单元,一个进程由多个线程组成,一个进程享受独有空间,多个线程共享资源空间
3.线程实现方法 ,继承Thread类,重写run方法
4.run和start区别
run方法是线程执行步骤,直接调用,就是主线程的普通方法
start,开启一个线程,进入就绪状态,等待cpu的调度,执行run方法
5.sleep 睡眠阻塞
6.线程生命周期
实例线程对象,调用start()进入就绪,当cpu调用,执行run(),run()执行完,消亡
cpu的时间片段到,进入就绪状态,等待cpu的再次调度
sleep,进入睡眠阻塞,时间到了,进入就绪
yiled(),让出cpu,等待让出的线程执行片段结束,再执行自己
后台线程,当守护的主线程销毁,立即销毁