什么是同步、异步、并行、并发
两件事,先做第一件,才能做第二件,这是同步
两件事,可以同时做,这是异步 异步有两种实现方式: 并行、并发
并行: 依赖多核CPU,每个核,运行一件事
并发: 利用了CPU核中的时间分片机制,在同一个核上,随机运行时间片
线程与进程的区别
进程之间,资源不共享 线程之间,资源共享
程序启动时,启动一个进程,这个进程叫主进程 进程启动时,启动一个线程,这个线程叫主线程
多线程
Thread创建线程
定要在主线程阻塞以前,启动新线程
Runnable创建线程
要创建一个线程任务,必须创建一个自定义类 但是因为Java不支持多继承。假如任务已经有了父类了,就不能再继承Thread类 所以用接口来解决
Runnable不过是一个接口,内部没有封装任何的开辟线程的行为 所以Runnable创建出的对象,不能直接执行run方法。如果执行了run方法,那不过只是简单调用而已。并不会开辟线程
需要结合Thread对象,将一个Runnable类型的对象,传给Thread对象的某一个方法。那么Thread的这个方法,就会开辟线程,并且在新线程内部,运行Runnable对象的run方法
线程同步
解锁的关键字: synchronized
在Java中使用的最多的关键字
public static void main(String[] args) throws InterruptedException {
List<String> list = new ArrayList<>();
Lock lock = new ReentrantLock();
Runnable run1 = new Runnable() {
@Override
public void run() {
for (int i = 0; i < 1000; ++i) {
synchronized (lock) {
list.add("hello");
}
}
}
};
Runnable run2 = new Runnable() {
@Override
public void run() {
for (int i = 0; i < 1000; ++i) {
synchronized (lock) {
list.add("world");
}
}
}
};
Thread thread1 = new Thread(run1);
Thread thread2 = new Thread(run2);
thread1.start();
thread2.start();
Thread.sleep(1000);
System.out.println(list);
}
}