为什么开启线程的时候要使用start()方法,而不直接调用run方法(附代码)----多线程学习笔记1

public class ThreadDemo extends Thread{
	@Override
	public void run() {
		for (int i=0;i<10;i++){
			System.out.println(Thread.currentThread().getName()+"run()"+i);
		}
	}
	public static void main(String[] args) {
		ThreadDemo threadDemo = new ThreadDemo();
		threadDemo.setName("程序中的run方法");
		threadDemo.start();
		threadDemo.run();


	}
}

通俗点解释:

如果直接使用threadDemo.run();那就不叫多线程,因为程序中只有主线程一个线程,何来的多线程,直接使用主线程去执行run方法中的内容,其程序执行路径还是只有一条,还是要顺序执行,还是要等待run方法体执行完毕后才可继续执行下面的代码,这样就没有达到多线程的目的。

如果使用threadDemo.start();这时无需等待run方法体代码执行完毕而直接继续执行下面的代码。通过调用Thread类的 start()方法来启动一个线程,这时当前线程处于就绪(可运行)状态,但是并没有立即运行(因为被主线程占用),一旦得到cpu时间片,就开始执行run()方法,run方法中就是写这个线程究竟要执行什么

附属上述代码执行的结果打印,可以看到我们虽然先执行threadDemo.start();方法,后调用的run方法,但是结果却是先输出的主线程的内容,由此可以验证上述内容。

mainrun()0
mainrun()1
mainrun()2
mainrun()3
mainrun()4
mainrun()5
mainrun()6
mainrun()7
mainrun()8
mainrun()9
程序中的run方法run()0
程序中的run方法run()1
程序中的run方法run()2
程序中的run方法run()3
程序中的run方法run()4
程序中的run方法run()5
程序中的run方法run()6
程序中的run方法run()7
程序中的run方法run()8
程序中的run方法run()9

猜你喜欢

转载自blog.csdn.net/qq_42584411/article/details/104670439