并发编程技术是互联网应用开发中必须掌握的知识,从本篇文章开始笔者将从线程知识开始学习,一步一步了解Java领域并发编程知识。以问题的形式来介绍线程相关的知识点。
一、Java线程是什么?
一个运行的程序就是一个进程,一个进程中可以有多个线程(线程是程序执行的最小单元)。
二、定义并开启Java线程的方法
1、继承Thread,重写run方法
//定义线程
public class MyThread extends Thread {
@Override
public void run() {
//业务逻辑
}
}
//开启线程
new MyThread().start();
2、实现Runnable,重写run方法
class MyRunnable implements Runnable{
@Override
public void run() {
//业务逻辑
}
}
//开启线程
new Thread(new MyRunnable()).start();
3、FutureTask 实现Callable接口,重写call方法, 实现有返回结果的线程 通过自旋 get方法通过自旋等待执行完成或者异常
class MyCallableTask extends Callable {
@Override
public Object call() throws Exception {
//业务逻辑
return null;
}
}
//提交一个FutureTask对象到线程池执行,并拿到结果
ThreadPoolExecutor executor = new ThreadPoolExecutor(2,5,2, TimeUnit.SECONDS,new ArrayBlockingQueue<>(10));
Future<?> result = executor.submit(new FutureTask(new MyCallableTask()));
4、线程池
ThreadPoolExecutor executor = new ThreadPoolExecutor(2,5,2, TimeUnit.SECONDS,new ArrayBlockingQueue<>(10));
//提交一个Runnable任务到线程池
executor.execute(new Runnable() {
@Override
public void run() {
//业务逻辑
}
});
三、使用线程的目的?
1、多核心cpu的场景下,真正实现并行的计算,
2、提高程序吞吐量,最大化利用硬件的性能能力。
3、异步处理
四、