zoukankan      html  css  js  c++  java
  • java thread start() 和 run() 区别

    1.start()

    public static void main(String[] args) {
    		// TODO 自动生成的方法存根
    		Thread t = new Thread() {
                public void run() {
                    pong();
                }
    		};
    
            t.start();
            System.out.print("ping");
    
        }
      static void pong() {
        System.out.print("pong");
    	
    	}
    
    }
    

     执行结果:pingpong

    2.run()

    public static void main(String[] args) {
    		// TODO 自动生成的方法存根
    		Thread t = new Thread() {
                public void run() {
                    pong();
                }
    		};
    
            t.run();
            System.out.print("ping");
    
        }
      static void pong() {
        System.out.print("pong");
    	
    	}
    
    }
    

     执行结果:pongping

    原因:1) start:
      用start方法来启动线程,真正实现了多线程运行,这时无需等待run方法体代码执行完毕而直接继续执行下面的代码。通 过调用Thread类的start()方法来启动一个线程,这时此线程处于就绪(可运行)状态,并没有运行,一旦得到cpu时间片,就开始执行run() 方法,这里方法 run()称为线程体,它包含了要执行的这个线程的内容,Run方法运行结束,此线程随即终止。
      2) run:
       run()方法只是类的一个普通方法而已,如果直接调用Run方法,程序中依然只有主线程这一个线程,其程序执行路径还是只有一条,还是要顺序执行,还是 要等待run方法体执行完毕后才可继续执行下面的代码,这样就没有达到写线程的目的。总结:调用start方法方可启动线程,而run方法只是 thread的一个普通方法调用,还是在主线程里执行。这两个方法应该都比较熟悉,把需要并行处理的代码放在run()方法中,start()方法启动线程将自动调用 run()方法,这是由jvm的内存机制规定的。并且run()方法必须是public访问权限,返回值类型为void.。

  • 相关阅读:
    换个角度认识大数据(上)——何为元数据
    如何优雅地停止Spark Streaming Job
    split("\,")引起的java.lang.ArrayIndexOutOfBoundsException异常解决方案
    spark streaming整合kafka
    Kafka相关命令
    Hive性能调优(二)----数据倾斜
    Hive SQL编译过程(转)
    Hive性能调优(一)----文件存储格式及压缩方式选择
    Hive表的几种存储格式
    spring框架之javaconfig
  • 原文地址:https://www.cnblogs.com/PopShow/p/5206696.html
Copyright © 2011-2022 走看看