zoukankan      html  css  js  c++  java
  • 如何正确的创建线程

    一、什么是线程?

    在我们编写的程序中,代码从main函数一行一行的执行,这就是一个线程,而且是主线程。

    多线程就是同时存在多条路线进行执行,好比于百米赛跑,多个跑道上的运动员一起跑步争取冠军。

    二、创建线程的两种方式

    run方法会在调用start()方法之后被执行,为什么?(请告知),所以我们要继承重载run()方法。

    1、通过扩展Thread类来创建多线程(重载 run 方法)

     //创建Thread类的子类,是一个匿名类,重载run方法
             Thread thread1 =new Thread(){
                 @Override
                public void run() {
                    while(true){
                        try {
                            Thread.sleep(500);
                        } catch (Exception e) {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                        }
                        System.out.println(Thread.currentThread().getName());
                    }
                }
             };

    2、实现Runnalbe接口,重载Runnalbe接口中的run()方法。

    1、为什么要实现 Runnable  接口,我们看一段Thread的源代码:

     /* 内部定义了一个Runnable的变量:target. */
        private Runnable target;
    
    /*构造方法来初始化Runable类型的target变量 */
     public Thread(Runnable target) {
            init(null, target, "Thread-" + nextThreadNum(), 0);
        }
    /* 调用run 方法 */
      @Override
        public void run() {
            if (target != null) {
                target.run();
            }
        }

    2、如何实现呢?

             Thread thread2=new Thread(new Runnable() {
                @Override
                public void run() {
                    // TODO Auto-generated method stub
                    while(true){
                        try {
                            Thread.sleep(500);
                        } catch (Exception e) {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                        }
                        System.out.println(Thread.currentThread().getName());
                    }
                }
            });

    3、总结

    两种方法实现,选择自己喜欢的一种,大部分选择第二种,主要符合Java面向对象的思想

  • 相关阅读:
    康拓展开和康拓逆展开
    快速乘法(基于快速幂)
    扩展欧几里德 POJ 1061
    九度OJ 1552座位问题(dp)
    UVA-10462.Is There A Second Way Left(Kruskal+次小生成树)
    POJ-1679.The Unique MST.(Prim求次小生成树)
    次小生成树(Prim + Kruaskal)
    POJ-1287.Network(Kruskal + Prim + Prim堆优化)
    最小生成树基础算法(Prim + Krustal)
    POJ-2492.A Bug's Life(带权并查集)
  • 原文地址:https://www.cnblogs.com/lyajs/p/5638672.html
Copyright © 2011-2022 走看看