• 线程运行机制


      进程是指运行中的应用程序,每一个进程都有自己独立的内存空间。一个应用程序可以同时启动多个进程。每次执行JDK的java.exe程序,就启动一个独立的java虚拟机进程,该进程的任务是解析并执行java程序代码。

      线程是指进程中的一个执行流程,同时也称为执行情景。一个进程可以由多个线程组成,即在一个进程中可以同时运行多个不同的线程,它们分别执行不同的任务。当进程内的多个线程同时运行,这种运行方式称为并发运行。许多服务器程序,如数据库服务器和Web服务器,都支持并发运行,这些服务器能同时响应来自不同客户的请求。

      线程与进程区别:每个进程都需要操作系统为其分配的独立内存地址空间,而同一进程中的所有线程在同一块地址空间中工作,这些线程可以共享同一块内存和系统资源,比如共享一个对象或者共享已经打开的一个文件。

      Java虚拟机进程中,执行程序代码任务是由线程来完成的。每个线程都有独立的程序计数器和方法调用栈。(method invocation stack)

      程序计数器:又称PC寄存器,当线程执行一个方法时,程序计数器指向方法区中下一条要执行的字节码指令。

      方法调用栈:简称方法栈,用来跟踪线程运行中一系列方法的调用过程,栈中的元素称为栈桢。每当线程调用一个方法的时候,就会向方法栈压入一个新帧。帧用来存储方法的参数、局部变量和运算过程中的临时数据。

       栈桢由三部分组成:

      (1)局部变量区:存放局部变量和方法参数;

      (2)操作数栈:是线程的工作区,用来存放运算过程中生成的临时数据;

      (3)栈数据区:为线程执行指令提供相关的信息,包括如何定位到位于堆区和方法区的特定数据,以及如何正常退出方法或者异常中断方法。

     一下Sample类介绍了线程运行的过程:

    package first;
    
    public class Sample {
        private int a; //实例变量
        public int method(){
            int b=0; //局部变量
            a++;
            b=a;
            return b;
        }
        public static void main(String[] args) {
            Sample s=null; //局部变量
            int a=0; //局部变量
            s=new Sample();
            a=s.method();
            System.out.println(a);
        }    
    }

     

     当主线程执行“a++”操作时,它能根据method()方法的栈帧的栈数据区中的有关信息,正确定位到堆区的Sample对象的实例变量a,并把它的值加1.

    当method()方法执行完毕后,它的栈桢就会从方法栈中弹出,它的局部变量b结束生命周期。main()方法的栈帧成为当前帧,主线程继续执行main()方法。

     

  • 相关阅读:
    python3实现感知器,简单神经网络
    jupyter快捷键
    吴恩实验(神经网络和深度学习)第一课第三周,代码和数据集,亲测可运行
    windows下安装PyTorch0.4.0
    IDEA上传码云报错Push rejected: Push to origin/master was rejected
    IDEA常见设置
    pycharm同级目录导入问题
    解决jupyter中无自己创建的虚拟环境
    tensorflow_mmp
    python GUI
  • 原文地址:https://www.cnblogs.com/taray/p/5366287.html
Copyright © 2020-2023  润新知