最近在看函数 ,英文名称 stack frame ,我看了国内和一些国外的文章,发现讲的都不是很清楚,今天就来说说,我不喜欢纯粹说理的文章。废话不多说,coding them首先新建一个c 文件,姑且命名为 main.c#include <stdio.h>int NUM=100;int n;static int m= 36;int sum(int _a,int _b){ i
原创 2023-01-16 06:51:35
97阅读
在CPU中,通常有通用寄存器,如指令寄存器IR;而push的意思是压,即这里
原创 2023-01-16 09:37:48
110阅读
1.java虚拟机   线程私有的,它的生命周期与线程相同(随线程而生,随线程而灭)深度大于虚拟机所允许的深度,将抛出StackOverflowError异常;无法申请到足够的内存,就会抛出OutOfMemoryError异常;  (当前大部分JVM都可以动态扩展,只不过JVM规范也允许固定长度的虚拟机。 stack内存,就是虚拟机中局部变量表部分。2.(Stack F
转载 2023-06-21 22:55:43
158阅读
[注]此文是《程序员的自我修养》的读书总结,其中掺杂着一些个人的理解,若有不对,欢迎拍砖。程序的内存布局现代的应用程序都运行在一个虚拟内存空间里,在32位的系统里,这个内存空间拥有4GB的寻址能力。现代的应用程序可以直接使用32位的地址进行寻址,整个内存是一个统一的地址空间,用户可以使用一个32位的指针访问任意内存位置。 【关于虚拟地址空间的介绍,看这里】 在进程的不同地址区间上有着不同的地位,W
写在前面的话:Java虚拟机是一门学问,是众多Java大神们的杰作,由于我个人水平有限,精力有限,不能保证所有的东西都是正确的,这里内容都是经过深思熟虑的,部分引用原著的内容,讲的已经很好了,不在累述。当然在这里,不可能所有细节都深层次的分析,只讲到一些比较重要的概念,由于对计算机组成原理理解不深,绝大部分只能采取黑盒理论来分析。 运行时的结构(什么是?)  &nbsp
分析建立函数以及函数
原创 2016-04-05 18:03:34
640阅读
# Java函数调用过程 在Java中,函数调用是用来管理函数调用的一种数据结构。当一个函数被调用时,会在调用中创建一个新的来存储函数的局部变量、参数和返回值等信息。函数调用的创建和销毁过程对于理解Java程序的执行流程和内存管理是非常重要的。 ## 函数调用的结构 一个函数调用通常包含以下几个部分: 1. 局部变量表(Local Variable Table):
原创 11月前
45阅读
浅谈函数很抱歉我用的是vs19,这个笔记本不可以装两个vs,性能不够,不是什么好电脑,但vs19只有调用main函数的那个“东西”看不到,其他的还是可以看到很多的,在开辟空间上优化很多。废话不多说直接上错误的地方本文有的地方ebp写成edp由于修改地方太多就不改了,基本是写到一半才发现哎什么叫可以直接说他就是一个空间,再准确点是存储空间。该明白的一点知识1.ebp(底指针),esp(
原创 2021-12-29 08:35:08
208阅读
1点赞
虚拟机这一部分真的很重要,内容也比较多,一起来看一下吧。Java虚拟机概述是管方法的,基本单位是,一个就是一个方法,只有两个操作:入和出,执行一个方法,这个代表这个方法的,作为顶,这个方法是当前方法,执行结束,是线程私有的,生命周期与线程一致。中是没有垃圾回收的,但是有OOM(内存溢出)。这是因为的大小可以是固定的,也可以是动态的,这个是程序员可以设置
先给大家看一段程序:在Linux上运行此程序时会发生虚拟机重启,可是在main函数里并没有调用使虚拟机重启的函数fun,那他为什么会重启呢?这就用到了这个知识点。一、也叫过程活动记录,是编译器用来实现过程/函数调用的一种数据结构。首先必须要明确的一点是也是非常重要的一点,是向下生长的,所谓的向下生长是指从高地址->低地址的路径延伸,顶和底,那么顶的地址要比底的地址低
原创 2016-06-11 12:06:36
464阅读
由三部分组成:局部变量区,操作数找和帧数据区。局部变量区和操作数的大小要 视对应的方法而定,它们是按字长计算的。编译器在编译时就确定了这些值并放在class文件中。 而帧数据区的大小依赖于具体的实现。当虚拟机调用一个Java方法时,它从对应类的类型信息中得到此方法的局部变量区和操作数 的大小,并据此分配内存,然后压人Java中。局部变量区Java的局部变量区被组织为一个以字长为单
代码编译的结果从本地机器码转变为字节码,是存储格式发展的一小步,却是编程语言发展的一大步。概述(Stack Frame)是用于支持虚拟机进行方法调用和方法执行的数据结构。它是虚拟机运行时数据区中的虚拟机元素。存储了方法的局部变量表、操作数、动态连接和方法返回地址等信息。每一个方法从调用开始至执行完成的过程,都对应着一个在虚拟机里面从入到出的过程。在编译程序代码的时候,
如图所示,下面是高地址,上面是低地址,main函数中调用fun1的时候,压入了实参a,b,这个实参a,b与main函数中的数据a,b是不样的,实参a,b是一份拷贝,在fun1函数中,定义了指针p,p指向a的地址,这里a的地址是实参a的地址,p--指向main函数下一条命令的地址,*p=fun;将main函数下一条命令的地址改为了fun函数的地址,故在程序运行的时候,main函数没有调用fun函数
原创 2016-06-11 13:34:37
604阅读
一个方法对应一块内存区域
转载 2019-08-21 21:38:00
86阅读
2评论
首先应该明白,是从高地址向低地址延伸的。每个函数的每次调用,都有它自己独立的一个,这个中维持着所需要的各种信息。寄存器ebp指向当前的的底部(高地址),寄存器esp指向当前的的顶部(地址地)。下图为典型的存取器安排,观察在其中的位置 入操作:push eax; 等价于 esp=esp-4,eax->[esp];如下图出操作:pop eax; 等价于 [esp]-&gt
转载 2017-02-27 19:38:00
173阅读
2评论
 一、 (Frame)是用来存储数据和部分过程结果的数据结构,同时也被用来处理动态链接(Dynamic Linking)、方法返回值和异常分派(Dispatch Exception)。 随着方法调用而创建,随着方法结束而销毁——无论方法是正常完成还是异常完成(抛出了在方法内未被捕获的异常)都算作方法结束。的存储空间分配在Java虚拟机之中,每一个
转载 2023-08-25 17:48:00
0阅读
这次来看看PowerPC体系架构CPU的布局和操作方法。PowerPC用得不多,有不对的地方大家拍砖啊~~ 1.  PowerPC的     先来看看PowerPC的布局图:          上图描述的是PowerPC的布局方式,PowerPC的生长方向也是由高到
转载 2023-08-24 15:20:46
97阅读
基础知识备用:的定义:为单个过程分配的那部分的作用:传递过程参数;存储返回信息;保存寄存器内容用于以后恢复;本地存储。底指针(指针):ebp寄存器。顶指针(指针):esp寄存器。的生长方向:向低地址方向增长。 调用者的存储内容: A:被调用者的参数。 B:调用者的返回地址。 被调用者的存储内容是: A:从保存ebp
一:叫活动记录,是编译器用来实现函数调用的一种数据结构。也可以说就是存储在用户上(内核)每一次函数调用涉及的相关信息的记录单元。二:对的了解(用户和内核作为一种特殊的数据结构而存在(和“队列”相反的记录结构和操作规则),是一种只能在一端进行插入和删除操作的特殊线性表。按照后进先出的原则存储数据,先进入的数据被压入底,最后的数据在顶,需要读数据的时候从顶开始弹出数据(最
:1、又名堆栈,它是一种运算受限的线性表。其限制是仅允许在表的一端进行插入和删除运算。这一端被称为顶,相对地,把 另一端称为底。其特性是先进后出。2、是线程私有的,生命周期跟线程相同,当创建一个线程时,同时会创建一个的大小和深度都是固定的。3、方法参数列表中的变量,方法体中的基本数据类型的变量和引用数据类型的引用都存放在中,成员变量和对象本身不存放在中。运行时,成员函数的局部变
  • 1
  • 2
  • 3
  • 4
  • 5