线程
每一个分支都叫做一个线程,main()叫做主分支,也叫主线程。
程只是一个静态的概念,机器上的一个.class文件,机器上的一个.exe文件,这个叫做一个进程。程序的执行过程都是这样的:首先把程序的代码放到内存的代码区里面,代码放到代码区后并没有马上开始执行,但这时候说明了一个进程准备开始,进程已经产生了,但还没有开始执行,这就是进程,所以进程其实是一个静态的概念,它本身就不能动。平常所说的进程的执行指的是进程里面主线程开始执行了,也就是main()方法开始执行了。进程是一个静态的概念,在我们机器里面实际上运行的都是线程。
Windows操作系统是支持多线程的,它可以同时执行很多个线程,也支持多进程,因此Windows操作系统是支持多线程多进程的操作系统。Linux和Uinux也是支持多线程和多进程的操作系统。DOS就不是支持多线程和多进程了,它只支持单进程,在同一个时间点只能有一个进程在执行,这就叫单线程。
CPU难道真的很神通广大,能够同时执行那么多程序吗?不是的,CPU的执行是这样的:CPU的速度很快,一秒钟可以算好几亿次,因此CPU把自己的时间分成一个个小时间片,我这个时间片执行你一会,下一个时间片执行他一会,再下一个时间片又执行其他人一会,虽然有几十个线程,但一样可以在很短的时间内把他们通通都执行一遍,但对我们人来说,CPU的执行速度太快了,因此看起来就像是在同时执行一样,但实际上在一个时间点上,CPU只有一个线程在运行。
学习线程首先要理清楚三个概念:
什么才是真正的多线程?如果你的机器是双CPU,或者是双核,这确确实实是多线程。
创建一个新的线程
1 package cn.galc.test;
2
3 public class TestThread1{
4 public static void main(String args[]){
5 Runner1 r1 = new Runner1();//这里new了一个线程类的对象出来
6 //r1.run();//这个称为方法调用,方法调用的执行是等run()方法执行完之后才会继续执行main()方法
7 Thread t = new Thread(r1);//要启动一个新的线程就必须new一个Thread对象出来
8 //这里使用的是Thread(Runnable target) 这构造方法
9 t.start();//启动新开辟的线程,新线程执行的是run()方法,新线程与主线程会一起并行执行
10 for(int i=0;i<10;i++){
11 System.out.println("maintheod:"+i);
12 }
13 }
14 }
15 /*定义一个类用来实现Runnable接口,实现Runnable接口就表示这个类是一个线程类*/
16 class Runner1 implements Runnable{
17 public void run(){
18 for(int i=0;i<10;i++){
19 System.out.println("Runner1:"+i);
20 }
21 }
22 }
yield:让步(当前执行的线程就让出来让另一个在执行run()方法的线程来优先执行)
参考:https://www.cnblogs.com/xdp-gacl/p/3633936.html
优质内容筛选与推荐>>