前言
在现代软件开发中,多线程并发编程是提升应用性能的关键技术。本文将深入探讨Java并发编程的核心概念、常用工具类以及实战技巧,帮助你掌握高并发场景下的编程能力。
一、线程基础与生命周期
1.1 创建线程的三种方式
方式一:继承Thread类
publicclassMyThreadextendsThread{@Overridepublicvoidrun(){System.out.println("线程名称: "+Thread.currentThread().getName());System.out.println("线程正在执行...");}publicstaticvoidmain(String[]args){MyThreadthread=newMyThread();thread.start();// 启动线程}}方式二:实现Runnable接口(推荐)
publicclassMyRunnableimplementsRunnable{@Overridepublicvoidrun(){for(inti=0;i<5;i++){System.out.println(Thread.currentThread().getName()+" - "+i);}}publicstaticvoidmain(String[]args){MyRunnablerunnable=newMyRunnable();Threadthread1=newThread(runnable,"线程1");Threadthread2=newThread(runnable,"线程2");thread1.start();thread2.start();}}方式三:实现Callable接口(有返回值)
importjava.util.concurrent.*;publicclassMyCallableimplementsCallable<Integer>{@OverridepublicIntegercall()throwsException{intsum=0;for(inti=1;i<=100;i++){sum+=i;}returnsum;}publicstaticvoidmain(String[]args)throwsExecutionException,InterruptedException{MyCallablecallable=newMyCallable();FutureTask<Integer>futureTask=newFutureTask<>(callable);Threadthread=newThread(futureTask);thread.start();// 获取返回结果(会阻塞直到任务完成)Integerresult=futureTask.get();System.out.println("计算结果: "+result);}}1.2 线程生命周期
线程在其生命周期中会经历以下状态:
- NEW(新建):线程对象创建后的初始状态
- RUNNABLE(可运行):调用start()后,线程可能正在运行或等待CPU分配时间
- BLOCKED(阻塞):等待获取监视器锁
- WAITING(等待):无限期等待另一个线程执行特定操作
- TIMED_WAITING(超时等待):有时限的等待
- TERMINATED(终止):线程执行完毕
publicclassThreadStateDemo{publicstaticvoidmain(String[]args)throwsInterruptedException{Threadthread=newThread(()->{try{Thread.sleep(2000);}catch(InterruptedExceptione){e.printStackTrace();}})