• 线程运行的内存图


    话不多说,看以下两部分代码

    public class ThreadTest {
        
        public static void main(String[] args) {
            //创建并开启线程
            new MyThread().start();
            //循环遍历
            for(int i=0;i<100;i++) {
                System.out.println("main"+ i );
            }
            
        }
    }
    public class MyThread extends Thread{
    
        public void run() {
            //遍历0-99
            for(int i=0;i<100;i++) {
                System.out.println(this.getName() + i);
            }
            
        }
        
    }

      >接着我们运行main方法,控制台打印一部分结果如下:

       现在我们可以得出一些结论:

        1.main主线程在执行start()方法时会开启一条新的线程,而这条线程专门来运行run方法,不会去执行main里的代码块

        2.main主线程执行start()后不需要等待开启的线程执行完run(),会一直往下执行

        3.线程间的执行任务是互不干扰的

    那这个过程中,线程的内存图是怎么样的呢?如图:

       当执行start后,run不会进入main所在的栈内存的,因为这样会导致一个问题,先进去的方法是后出来的,所以会存在先执行run,后执行run后面的main代码,这样就不是多线程同时执行了。

      而看到这个图,可以发现每当开启一条线程,在JVM内存中,会单独为每条线程开辟一块栈内存用于使用

  • 相关阅读:
    centos配置WordPress(Apache+mysql+php)
    sublime text3配置Python2、Python3的编译环境
    Python3——字典
    Python3基础——函数
    Python3基础——递归
    Python3基础——字符串类型
    activiti会签直接写死人员
    delete执行速度优化
    C盘空间满了怎么办
    python运算符
  • 原文地址:https://www.cnblogs.com/ibcdwx/p/13729869.html
Copyright © 2020-2023  润新知