一、进程与线程
- 程序运行时,即使自己没有创建线程,后台也会存在多个线程,如gc线程。
- 线程对同一份资源操作时,会存在资源抢夺问题,要加入并发控制。
- 线程会有额外开销,cpu调度,并发控制开销。
二、三种创建方式
1. 继承Thread类
(1) 构造方法
Thread()
Thread(String name)
Thread(Runnable target)
Thread(Runnable target, String name)
Thread(ThreadGroup group, Runnable target)
(2) start()和run()
线程必须调用start(),加入调度器,此时不一定立即执行
直接调用run()不是开启多线程,是普通方法调用
2.实现Runnable接口
(1) 使用Thread类的构造方法传入
(2) 调用start方法
3. 实现Callable接口(可以获取线程执行结果)
(1) 创建目标对象: CDownloader cd =new CDownloader("图片地址","baidu.png");
(2) 创建执行服务: ExecutorService ser=Executors.newFixedThreadPool(1);
(3) 提交执行: Future<Boolean> result1 =ser.submit(cd1) ;
(4) 获取结果: boolean r1 =result1.get();
(5) 关闭服务: ser.shutdownNow();
更多参考://www.greatytc.com/p/c1199e0ded73
https://blog.csdn.net/tongdanping/article/details/79604637
https://blog.csdn.net/weixin_40304387/article/details/80508236
三、推荐使用Runnable接口
1. 摆脱单继承的局限性
2. 可以共享资源,一个实现Runnable的资源,多个线程执行
四、线程的状态
创建、就绪、运行、阻塞、结束
五、线程方法
1. sleep
使线程停止运行一段时间,将处于阻塞状态 ,如果调用了sleep方法之后,没有其他等待执行的线程,这个时候当前线程不会马上恢复执行
2. join
指定线程执行,当前线程要等到指定线程执行完。如:main方法中线程t.join(),这是t执行完后,main才继续。
3. yield
让当前正在执行线程暂停,不是阻塞线程,而是将线程转入就绪状态;调用了yield方法之后,如果没有其他等待执行的线程,此时当前线程就会马上恢复执行。
4. setDaemon
可以将指定的线程设置成后台线程,守护线程;创建用户线程的线程结束时,后台线程也随之消亡;只能在线程启动之前把它设为后台线程;一般用做操作日记、监控内存使用等,jvm不用等待守护线程执行完毕。
5. setPriority,getPriority
设置、得到线程优先级,1-10,默认5。
5. stop
停止线程,不推荐使用。