多线程1-简介

一、进程与线程

进程与线程的区别
  1. 程序运行时,即使自己没有创建线程,后台也会存在多个线程,如gc线程。
  2. 线程对同一份资源操作时,会存在资源抢夺问题,要加入并发控制。
  3. 线程会有额外开销,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();


实现Callable接口的类

更多参考://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

停止线程,不推荐使用。


线程停止
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 本文主要讲了java中多线程的使用方法、线程同步、线程数据传递、线程状态及相应的一些线程函数用法、概述等。 首先讲...
    李欣阳阅读 2,503评论 1 15
  • Java多线程学习 [-] 一扩展javalangThread类 二实现javalangRunnable接口 三T...
    影驰阅读 2,987评论 1 18
  • 一、认识多任务、多进程、单线程、多线程 要认识多线程就要从操作系统的原理说起。 以前古老的DOS操作系统(V 6....
    GT921阅读 1,032评论 0 3
  • 林炳文Evankaka原创作品。转载自http://blog.csdn.net/evankaka 本文主要讲了ja...
    ccq_inori阅读 670评论 0 4
  • 1 线程概念 1.1 进程 在现代的操作系统中,进程是资源分配的最小单位,而线程是CPU调度的基本单位。 一个进程...
    凯玲之恋阅读 996评论 0 0