多线程中run()方法和start()方法的区别

       通常,系统通过调用线程类的start()方法来启动一个线程,此时线程处于就绪状态而非运行状态,也就意味着这个线程可以被JVM来调度执行。在调度过程中,JVM通过调用线程类的run()方法来完成实际的操作,当run()方法结束后,此线程就会终止。
       如果直接调用线程的run()方法,这会被当做一个普通函数的调用,程序中仍然只有主程序这一个线程,也就是说,start()方法能够异步地调用run()方法,但是直接调用run()却是同步的;因此也就无法达到多线程的目的。
       一句话,只有调用线程类的start()方法才能够达到多线程的目的。

package fromBook;
class threadDemo extends Thread{
	public void run() {
		System.out.println("ThreadDemo:begin");
		try {
			Thread.sleep(1000);
		}catch(Exception e) {
			e.printStackTrace();
		}
		System.out.println("ThreadDemo:end");
	}
}


public class Test {
	public static void test1() {
		System.out.println("test1:begin");
		Thread t1 = new threadDemo();
		t1.start();
		System.out.println("test1:end");
	}
	public static void test2() {
		System.out.println("test2:begin");
		Thread t2 = new threadDemo();
		t2.run();
		System.out.println("test2:end");
	}
	public static void main(String[] args) {
		test1();
		try {
			Thread.sleep(5000);
		}catch(Exception e) {
			e.printStackTrace();
		}
		test2();
	}
	
}

运行结果为:

test1:begin
test1:end
ThreadDemo:begin
ThreadDemo:end

test2:begin
ThreadDemo:begin
ThreadDemo:end
test2:end

总结:
       从test1中可以看出,线程 t1 在 test1 方法执行结束后执行 的(System.out.println(“test1:end”),语句不需要等t1.start()运行结果就可以执行),因此,在test1中调用start()方法是异步的,所以main线程与t1线程是异步执行的。
       从 test2 的运行结果可以看出,调用t1.run()是同步的调用方法,因为System.out.println(“test2:end”)只有等t1.run()调用结束后才能执行。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值