资讯专栏INFORMATION COLUMN

Java多线程的创建和状态信息|乐字节

linkFly / 1572人阅读

摘要:大家好,我是乐字节的小乐,好看好学的干货又来了上一篇我们说到了多线程的概念以及优缺点,本文将接着说多线程的创建,以及多线程的状态。

大家好,我是乐字节的小乐,好看好学的Java干货又来了!上一篇我们说到了Java多线程的概念以及优缺点,本文将接着说Java多线程的创建,以及多线程的状态。

一、创建线程 1、创建 Thread 的子类

创建: 继承 Thread +重写 run

启动: 创建子类对象 对象.start()

创建 Thread 子类的一个实例并重写 run 方法,run 方法会在调用 start()方法之后被执行,示例如下:

</>复制代码

  1. public class MyThread extends Thread {
  2. public void run(){
  3. for(int i=0;i<10;i++){
  4. try {
  5. Thread.sleep(20); //模拟延时
  6. } catch (InterruptedException e) {
  7. e.printStackTrace();
  8. }
  9. System.out.println("一边学习多线程");
  10. }
  11. }
  12. public static void main(String[] args) {
  13. //创建子类对象
  14. MyThread myThread = new MyThread();
  15. //启动线程
  16. myThread.start();
  17. //也可以创建匿名子类
  18. Thread thread = new Thread(){
  19. public void run(){
  20. for(int i=0;i<10;i++){
  21. try {
  22. Thread.sleep(20);//模拟延时
  23. } catch (InterruptedException e) {
  24. e.printStackTrace();
  25. }
  26. System.out.println("一边玩QQ");
  27. }
  28. }
  29. };
  30. thread.start();
  31. for(int i=0;i<10;i++){
  32. try {
  33. Thread.sleep(20); //模拟延时
  34. } catch (InterruptedException e) {
  35. e.printStackTrace();
  36. }
  37. System.out.println("一边玩微信...");
  38. }
  39. }
  40. }
2、实现 Runnable 接口(推荐)

面向接口编程,避免单继承局限

创建: 实现 Runnable +重写 run

启动:静态代理 Thread

a)、创建真实角色 实现类对象
b)、创建代理角色 Thread 对象+真实角色的引用
c)、代理角色.start()
此方式是新建一个实现了 java.lang.Runnable 接口的类的实例,实例中的方法可以被

线程调用。

缺点: 根据重写规则,run 方法不能对外声明异常,不能有返回值

</>复制代码

  1. public class MyRunnable implements Runnable {
  2. public void run(){
  3. for(int i=0;i<10;i++){
  4. try {
  5. Thread.sleep(20); //模拟延时
  6. } catch (InterruptedException e) {
  7. e.printStackTrace();
  8. }
  9. System.out.println("一边学习多线程");
  10. }
  11. }
  12. public static void main(String[] args) {
  13. //使用代理创建线程
  14. Thread thread = new Thread(new MyRunnable());
  15. //启动线程
  16. thread.start();
  17. //也可以创建一个实现了Runnable接口的匿名类
  18. Runnable myRunnable = new Runnable(){
  19. public void run(){
  20. for(int i=0;i<10;i++){
  21. try {
  22. Thread.sleep(20);//模拟延时
  23. } catch (InterruptedException e) {
  24. e.printStackTrace();
  25. }
  26. System.out.println("一边玩QQ");
  27. }
  28. }
  29. };
  30. Thread t = new Thread(myRunnable);
  31. t.start();
  32. for(int i=0;i<10;i++){
  33. try {
  34. Thread.sleep(20); //模拟延时
  35. } catch (InterruptedException e) {
  36. e.printStackTrace();
  37. }
  38. System.out.println("一边玩微信...");
  39. }
  40. }
  41. }

优点: 能声明异常,能有返回值 缺点: 编写复杂麻烦

</>复制代码

  1. public class Call {
  2. public static void main(String[] args) throws InterruptedException, ExecutionException {
  3. //创建线程
  4. ExecutorService ser=Executors.newFixedThreadPool(2);
  5. Race tortoise = new Race("老不死",1000);
  6. Race rabbit = new Race("小兔子",500);
  7. //获取值
  8. Future result1 =ser.submit(tortoise) ;
  9. Future result2 =ser.submit(rabbit) ;
  10. Thread.sleep(2000); //2秒
  11. tortoise.setFlag(false); //停止线程体循环
  12. rabbit.setFlag(false);
  13. int num1 =result1.get();
  14. int num2 =result2.get();
  15. System.out.println("乌龟跑了-->"+num1+"步");
  16. System.out.println("小兔子跑了-->"+num2+"步");
  17. //停止服务
  18. ser.shutdownNow();
  19. }
  20. }
  21. class Race implements Callable{
  22. private String name ; //名称
  23. private long time; //延时时间
  24. private boolean flag =true;
  25. private int step =0; //步
  26. public Race() {
  27. }
  28. public Race(String name) {
  29. super();
  30. this.name = name;
  31. }
  32. public Race(String name,long time) {
  33. super();
  34. this.name = name;
  35. this.time =time;
  36. }
  37. @Override
  38. public Integer call() throws Exception {
  39. while(flag){
  40. Thread.sleep(time); //延时
  41. step++;
  42. }
  43. return step;
  44. }
  45. public String getName() {
  46. return name;
  47. }
  48. public void setName(String name) {
  49. this.name = name;
  50. }
  51. public long getTime() {
  52. return time;
  53. }
  54. public void setTime(long time) {
  55. this.time = time;
  56. }
  57. public boolean isFlag() {
  58. return flag;
  59. }
  60. public void setFlag(boolean flag) {
  61. this.flag = flag;
  62. }
  63. public int getStep() {
  64. return step;
  65. }
  66. public void setStep(int step) {
  67. this.step = step;
  68. }
  69. }
二、线程的状态及信息 1、五种状态

1)、新生状态: new
2)、就绪状态: runnable
3)、运行状态: running
4)、阻塞状态: blocked
5)、执行完毕: dead

类似于运动员赛跑,

1)、新生状态:选出运动员
2)、就绪状态:走到起跑线,做好跑的动作,枪响后,不是马上就跑,得有反应时间。
3)、运行状态:反应完成后,开始跑
4)、阻塞状态:路边一个石头绊倒了,马上跑起来,嘟囔几句,踢踢石头, 不是马上跑,重新反应进入就 绪。
5)、终止状态:跑完了,结束了,慢慢的走几步停下来。

2、阻塞: sleep

模拟网络延时,每个对象 都有一把排他锁,不会释放锁

</>复制代码

  1. class Web12306 implements Runnable {
  2. private int tickets =20; //假设20张票
  3. private boolean flag =true;
  4. @Override
  5. public void run() {
  6. while(flag){
  7. if(tickets>=0){
  8. try {
  9. //模拟延时
  10. Thread.sleep(200);
  11. } catch (InterruptedException e) {
  12. e.printStackTrace();
  13. }
  14. System.out.println(Thread.currentThread().getName()+"-->抢票"+tickets--);
  15. }else{
  16. flag =false;
  17. }
  18. }
  19. }
  20. public static void main(String[] args) {
  21. //真实角色 目标
  22. Runnable target =new Web12306();
  23. //代理角色 Thread +真实角色的引用
  24. Thread proxy1 =new Thread(target,"黄牛A");
  25. Thread proxy2 =new Thread(target,"路人甲");
  26. //代理行为
  27. proxy1.start(); //启动线程
  28. proxy2.start(); //线程不安全,数据有问题
  29. }
  30. }
3、终止

不要调用 stop destory 方法 ,太暴力,一盆冷水让其停止。

a、正常执行完毕,循环 次数已经到达

b、外部干涉

1)、线程中加入标识 -->属性
2)、线程体中 使用改标识 -->死循环
3)、对外提供改变改标识的方法 setXxx() terminate() a()...
4)、外部根据适当的时机调用该方法

4、当前线程

Thread.currentThread()

5、优先级

只代表概率,不代表绝对先后顺序

MIN_PRIORITY : 1

NORM_PRIORITY :5 默认优先级

MAX_PRIORITY :10

getPriority() setPriority()

关于多线程的创建和状态就介绍到这里,下次我们再说多线程的同步和线程通信,请关注乐字节,原创文章,转载请注明出处。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/75975.html

相关文章

  • Java线程概念以及优缺点、线程地位

    摘要:注意很多多线程是模拟出来的,真正的多线程是指有多个,即多核如服务器。对于目前的大家来说,线程掌握以下即可创建线程的方式停止线程简单的关于多线程的概念和优缺点就介绍到这,下一篇将会讲讲如何创建多线程。 大家好,乐字节小乐有来咯,上次说完了Java网络编程探究|乐字节,这次我们来看看线程相关的吧。 Java线程主要讲述的内容有:showImg(https://segmentfault.co...

    gitmilk 评论0 收藏0
  • Java网络编程探究|字节

    摘要:换句话说,套接字起到通信端点的作用。单个套接字是一个端点,而一对套接字则构成一个双向通信信道,使非关联进程可以在本地或通过网络进行数据交换。 大家好,我是乐字节小乐,上次给大家讲述了Java中的IO流之输出流|乐字节,本文将会给大家讲述网络编程。 主要内容如下: 网络 网络分层 列表项目 IP位置 端口port 网络编程 showImg(https://segmentfault.c...

    Kahn 评论0 收藏0
  • Java线程-同步:synchronized 线程通信:生产者消费者模式

    摘要:上次是说到了多线程的创建和状态乐字节,接下来,我们再来接着说多线程同步和线程通信生产者消费者模式。另一方面,线程通信使线程能够等待其他线程的信号。 大家伙周末愉快,小乐又来给大家献上技术大餐。上次是说到了Java多线程的创建和状态|乐字节,接下来,我们再来接着说Java多线程-同步:synchronized 和线程通信:生产者消费者模式。 一、同步:synchronized 多个线程同...

    wemallshop 评论0 收藏0
  • 字节Java反射之一:反射概念与获取反射源头class

    摘要:一反射机制概念程序运行时,允许改变程序结构或变量类型,这种语言称为动态语言,如,是动态语言显然,,不是动态语言,但是有着一个非常突出的动态相关机制。相关的为二获取源头重点打开权限所有类的对象其实都是的实例。 一、Java反射机制概念 程序运行时,允许改变程序结构或变量类型,这种语言称为动态语言,如Python, Ruby是动态语言;显然C++,Java,C#不是动态语言,但是JAVA有...

    caikeal 评论0 收藏0
  • 字节-Java8新特性之Date API

    摘要:上一篇文章,小乐给大家带来了新特性之,接下来本文将会给大家介绍新特性之前言通过发布新的来进一步加强对日期与时间的处理。 上一篇文章,小乐给大家带来了Java8新特性之Optional,接下来本文将会给大家介绍Java8新特性之Date API 前言: Java 8通过发布新的Date-Time API来进一步加强对日期与时间的处理。 旧版的 Java 中,日期时间 API 存在诸多问题...

    suemi 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<