并发与并行
并发:指两个或多个事件在同一时间段内发生 交替执行
并行:指两个或多个事件在同一时刻发生(同时发生)
线程与进程
进程:一个内存中运行的应用程序就成为进程
线程:
线程是进程当中的一个执行单元,一个进程至少有一个线程
线程的调度:
分时调度
所有线程轮流使用CPU,平均分配每个线程占用CPU的时间
抢占式调度
优先让优先级高的线程使用CPU,如果线程的优先级相同,那么会随机选择一个(线程随机性),Java使用的就是抢占式调度
创建线程类
主线程:执行main方法的线程叫做主线程
Java虚拟机允许应用程序并发地运行多个执行线程 高优先级的线程执行 优先于 低优先级的线程
Thread类
含有方法 start 功能:使两个线程并发地运行;当前线程(从调用返回给 start方法) 和另一个线程(执 行其run方法)
多次启动一个线程是非法的。线程结束运行后不能再重新启动
public class Demo extends Thread{
//创建多线程的第一种方法:创建Thread类的子类
//继承Thread并且重写Thread中的run方法,设置线程任务
@Override
public void run() {
// TODO Auto-generated method stub
for(int i = 0; i < 10; i++) {
System.out.println("run" + i);
}
}
}
public class Test {
public static void main(String[] args) {
Demo demo = new Demo();
demo.start();
for(int i = 0; i < 10; i++) {
System.out.println("main" + i);
}
}
}
运行结果:
Thread类的常用方法
继承Thread类重写run方法
1.getName
返回线程的名称
2.currentThread
返回当前正在执行的线程对象的引用
3.sleep
指定线程以毫秒为单位暂停
Runnable接口创造线程
实现Ruannable接口 重写run方法
创建Tread类
public class Demo implements Runnable{
public void run(){
System.out.println("Runnable线程被执行");
}
}
public static void main(String[] args){
Demo ra = new Demo();
Thread t = new Thread(ra,"Thread线程");
t.start();
}
同步代码块
synchronized(锁对象)
使多个线程同时抢一个通道,只有抢到的才能运行代码块里的代码
注意事项:
把共享代码提取到 synchronized 代码块里
Lock锁
Lock接口中的方法
1.lock 获取锁
2.unlock 释放锁
使用方法
1.创建一个ReentrantLock对象
2.在线程安全问题前用 lock
3.在线程安全问题后用unlock