笔试之内存分配问题

2023-05-16

 

需要知道的概念:

  1、程序:包括代码和数据,是静态的概念

  2、进程:程序的执行过程,是指一个程序中的代码在一个数据集合中的运行过程,所以说相同代码在不同的数据集合上运行,乃至在同样的数据集合上的多次运行都是不同的进程。进程是一个动态概念

  3、线程:可以理解为进程中的一个代码片段的执行。故常说一个进程包含多个线程,多个线程共享数据空间。操作系统不会单独为线程分配资源(存储空间)

  程序是静态的,进程是动态的;进程是操作系统分配资源的最小单位,线程是操作系统调度的最小单位。

  一个程序在运行起来以后,就成为的进程,此时操作系统要为该进程分配虚拟存储空间,这个存储空间就包括了:栈区(stack),堆区(heap),全局区(静态区)(static),文字常量区,代码区。至于这些存储区的使用情况,就取决于我们程序员的代码实现了!举例说明:

  栈区(stack):人们说:栈区是由编译器自动分配的,我认为这种说法是不准确的,只是说在编译阶段,栈区的分配情况就已经是确定好了的(也就是不管进程的接收参数如何,或是执行多少次,栈区变量一定是那样一个地址),毕竟内存的分配是由操作系统内核的内存管理机制来完成的。OK!不钻牛角,就说是编译器在编译时分配。我的理解是:在编译阶段,编译器会根据代码中变量的定义情况,依据字节对齐原理进行分配(具体方法会在后续的《栈区内存分配详解》中介绍)。但要注意,进程的执行进入函数体以后(自动变量所在的函数体),变量才和栈区地址对应起来了,这时&a(a是一个栈区变量)才是有值的,但这个时候变量不能使用,其值可能是一个不确定数。当程序运行到达该变量的定义语句时,作用域开始,并且变量中有了确定的值,当函数体结束,作用域结束,空间有操作系统回收。

  堆区(heap):堆区是由程序员分配释放的。我的理解是:堆区是进程执行过程中,由操作系统根据进程的运行情况,动态分配的;释放和回收需要程序员写代码来实现,而不是自动回收。

  这就解释了为什么,int a[n]--这样的栈区数组定义方式有错,因为在编译阶段,程序没有运行,故不知道变量n的值为多少,所以产生错误!!而动态分配的存储空间就可以这样定义 int *p = new a[n],因为动态分配存储空间是堆上分配,属于运行时分配,程序运行到动态分配存储空间这条语句时,n的值已经计算出来了。而且不同的运行过程,或是多次执行,n的值可能不一样(例如进程的接收参数不同),也就是空间大小也就不一样,操作系统需要在堆区二叉树中寻找一个满足该大小的空间,所以起始地址也会不一样。再次印证了动态的含义。

  全局(静态)区:1.全局变量:编译阶段 由编译器分配(确定)地址,但是在进程开始时才与该地址对应,但此时变量有一不确定值,处于不可使用状态,一直到改全局变量的定义语句,作用域开始,一直到进程结束。2.static静态变量:在整个进程过程中,只能被赋初值一次。

  文字常量区:用于存放常量字符串。

  代码区:存放程序的二进制代码。

 示例:


 1 #include <iostream>
 2 using namespace std;
 3 
 4 int a = 0; /*全局区*/
 5 char *p;  /*全局区*/
 6 
 7 int main(void)
 8 {
 9     int b = 10;  /*栈区*/
10     char s[] = "abc";  /*abc在常量区,s在栈区*/
11     char *p1;  /*栈区*/
12 
13     static int c = 0; /*全局(静态区)*/
14     
15     p = (char*)malloc(b);  /*变量p在全局区,指向的分配得来的b个存储空间在堆区*/
16     p1 = new char[b];   /*变量p1在栈区,指向的分配得来的b个存储空间在堆区*/
17     return 0;
18 }  

 

 

 

转载于:https://www.cnblogs.com/goaheadnohesitate/archive/2012/10/20/2732128.html

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

笔试之内存分配问题 的相关文章

  • 仅仅有走过的路 才懂她的内容

    年少初遇常在我心 傻傻的站在十一教门前一排高高的杨树下伫立 xff0c 独念风凉 叶落肩头 我该用什么去聆听这走过的两个月 明年的枝头 xff0c 依然会看到今日的灿烂 想想磕磕绊绊的两个月 xff0c 学习的故事轮番上演 一个比一个精彩
  • 关于 来源: volmgr Event ID: 46 故障转储初始化未成功 的问题

    最近笔记本电脑硬件有点问题 xff0c 查看系统日记 xff0c 如下 xff1a volmgr Event ID 46 故障转储初始化未成功 最后找到了一个解决方案 xff1a 网上查了一下 volmgr 错误 故障转储初始化未成功的解决
  • Weka中数据挖掘与机器学习系列之Weka Package Manager安装所需WEKA的附加算法包出错问题解决方案总结(八)...

    不多说 xff0c 直接上干货 xff01 Weka中数据挖掘与机器学习系列之Weka系统安装 xff08 四 xff09 Weka中数据挖掘与机器学习系列之Weka3 7和3 9不同版本共存 xff08 七 xff09 情况1 对于在We
  • 数据恢复软件如何换机使用?

    作为好用的数据恢复软件 xff0c EasyRecovery易恢复可以用来恢复文件 文件夹 照片 视频等丢失的文件 xff0c 而且支持换机使用 xff0c 如果要换电脑的话 xff0c 记得一定要按以下步骤操作哦 xff01 EasyRe
  • SQL server修改字段名,属性

    修改字段名 exec sp rename 表名 列名 新列名 修改字段属性 alter table 表名 alter column 列名 nvarchar 100 null 修改默认值 alter table 表名 add constrai
  • 手把手教你启用Win10的Linux子系统(超详细)

    原文 手把手教你启用Win10的Linux子系统 xff08 超详细 xff09 版权声明 xff1a 转载请保留出处 xff0c 谢谢 xff01 https blog csdn net zhangdongren article deta
  • 不要再被骗了------QQ盗号原理大揭秘

    前言 相信大家在懵懂无知的时候都有被盗号的经历吧 xff0c QQ胡乱的加好友 xff0c 突然有个好友传了个文件给你 xff0c 打开以后发现QQ竟然显示强制下线 xff0c 然后再也上不去了QAQ xff0c 很明显 xff0c QQ号
  • 移动端唤起键盘时取消position:fixed定位

    当在移动端按钮position fixed 底部bottom 0 固定定位后 xff0c 当唤起键盘输入数据时就会出现很头疼的问题 xff1a 固定在底部的按钮会被系统自带的键盘挤上去 xff0c 占用输入框位置 xff1b 如图 xff1
  • nginx根据访问的url参数或者是请求 头部做判断转发

    在http请求后端时 xff0c token是一种非常常见的使用方式 xff0c 但是如果url请求参数不带token xff0c 或者请求头部不带token这样的请求应当直接返回401 xff0c 而不要代理给后端服务器做处理了 可以有效
  • java 获取HttpRequest Header 的几种方法 & 请求request的所有参数实现方法

    2019独角兽企业重金招聘Python工程师标准 gt gt gt 在开发应用程序的过程中 xff0c 如果有多个应用 xff0c 通常会通过一个portal 门户来集成 xff0c 这个portal 是所有应用程序的入口 xff0c 用户
  • CISCO路由器license激活图解教程

    此次也是一台CISCO 3945E K9路由器 xff0c 新设备启动后执行show version命令查看版本信息 xff1a 以下为show version中license信息 License Info License UDI Devi
  • 动态创建HTML内容

    document write xff08 xff09 方法 document write方法可以方便快捷的把字符串插入到文档里 它最大的缺点是违背了 分离javascript 原则 即使把document write语句挪到外部函数里 xf
  • Linux练习(write写入)

    include lt unistd h gt include lt stdlib h gt int main if write 1 34 here is some data n 34 18 61 18 write 2 34 write er
  • matlab练习程序(随机游走图像)

    随机游走类似布朗运动 xff0c 就是随机的向各个方向走吧 虽然代码没什么技术含量 xff0c 不过产生的图像实在太漂亮了 xff0c 所以还是贴上来吧 产生的图像 xff1a matlab代码如下 xff1a clear all clos
  • [翻译完成] 树莓派搭建Google TV

    为什么80 的码农都做不了架构师 xff1f gt gt gt Google TV是啥玩意 Google TV是支持自选图像 宽带网络 传统电视信号的综合平台 xff0c 更附带电视节目搜索功能 谷歌公布了其新版电视的两个版本 第一个叫做B
  • jdk17.0.1安装教程

    1 解压到某文件夹 2 在此电脑 gt 属性 gt 高级系统设置 gt 环境变量 gt 系统变量 加一条JAVA HOME 3 在系统变量Path里 xff0c 加一条 JAVA HOME bin xff08 不能放在第一条 xff09 4
  • 推荐几本GIS专业书籍

    对于开设GIS专业的高校 xff0c 基本上都会有自己的专业教材 xff0c 用的比较多的像邬伦的 地理信息系统 xff1a 原理 方法和应用 和中科院陈述彭院士的 地理信息系统导论 在当初考研的时候 xff0c 自己也买了不少教材 xff
  • Linux 通过命令发送udp 数据

    2019独角兽企业重金招聘Python工程师标准 gt gt gt 如果往本地UDP端口發送數據 xff0c 那麼可以使用以下命令 xff1a echo hello gt dev udp 192 168 1 81 5060 意思是往本地19
  • Qt学习之路(17): Qt标准对话框之QMessageBox

    好久没有更新博客 xff0c 主要是公司里面还在验收一些东西 xff0c 所以没有及时更新 而且也在写一个基于Qt的画图程序 xff0c 基本上类似于PS的东西 xff0c 主要用到的是Qt Graphics View Framework
  • 2019年开发者必读!20位阿里技术大牛们帮你列了一份经典书单! ...

    导读 xff1a 寒冬中 xff0c 最值得投资的是学习 xff0c 是增厚的知识储备 下面就是20位阿里技术大牛们为我们推荐的经典书籍 书籍类型涉及技术 管理 哲学等方面 xff0c 希望这些书籍陪伴你度过这个漫长的寒冬 书单之外 xff

随机推荐

  • 发表一篇顶会论文的经验分享

    背景 xff1a 最近半个月 xff0c 对之前发表的一篇顶会论文进行了修改 xff0c 并重新提交了 这篇论文是一篇计算机领域的A会文章 本篇文章主要对计算机领域论文写作及发表过程中的相关经验做一个总结 希望可以对研究生小白们有点用 刚刚
  • jQuery的md5加密插件及其它js md5加密代码

    jQuery MD5 hash algorithm function lt code gt Calculate the md5 hash of a String String md5 String str lt code gt Calcul
  • matlab双目相机标定校正_基于双目视觉的无人机避障算法(一)

    讲述在10月到12月所做的所有工作 对于一个无人机自主避障来说 xff0c 存在着以下流程 xff1a 感知 xff1a 障碍物检测 行人检测 目标检测SLAM xff1a 为无人机提供位置估计 xff0c 构建稀疏环境地图路径规划 xff
  • pdf文件显示白色

    主要原因是pdf默认关联应用 xff0c 在版本更替时出现了错误 xff0c 重新给pdf设置一下默认关联应用即可 window10步骤如下 xff1a 1 打开我的电脑 选择计算机 打开设置 2 点 应用 3 选择 默认应用 中的 按文件
  • mysql数据库想要保持固定条数数据的操作

    2019独角兽企业重金招聘Python工程师标准 gt gt gt 限定数据库数据条数 xff1a SELECT FROM 表名 order by 字段 desc limit 条数 这样查询到的是倒数几条数据 xff0c 保证了最新的数据
  • Docker容器的创建、启动、和停止

    1 容器是独立运行的一个或一组应用 xff0c 及他们的运行环境 容器是Docker中的一个重要的概念 2 docker容器的启动有三种方式 a 交互方式 xff0c 基于镜像新建容器并启动 例如我们可以启动一个容器 xff0c 打印出当前
  • 每天一个linux命令(4):mkdir命令

    linux mkdir 命令用来 创建指定的 名称的 目录 xff0c 要求创建目录的用户在当前目录中具有写权限 xff0c 并且指定的目录名不能是当前目录中已有的目录 1 xff0e 命令格式 xff1a mkdir 选项 目录 2 xf
  • ansible报错:Failed to connect to the host via ssh: Permission denied

    原因 xff1a 没有在ansible管理节点 xff08 即安装ansible的节点 xff09 上添加目标节点 xff08 即需要管理的节点 xff09 的ssh认证信息 解决办法 xff1a 1 在管理节点生成公钥 ssh keyge
  • 值传递和引用传递-----函数参数传递的两种方式

    回顾 xff1a 在定义函数时函数括号中的变量名成为形式参数 xff0c 简称形参或虚拟参数 xff1b 在主调函数中调用一个函数时 xff0c 该函数括号中的参数名称为实际参数 xff0c 简称实参 xff0c 实参可以是常量 变量或表达
  • Andriod监听支付宝收款实现个人支付宝支付接口!附安卓App

    首先呢 xff0c 我不会开发安卓App xff0c 这款APP是我在酷安网看到的 xff0c 非常简单的一款APP xff0c 安装后填写我们的后端接口 xff08 用于接收收款通知的 xff09 就可以接收收款通知了 所以就算我们没有这
  • 记一次异常排查过程:druid连接池抛出DataSourceDisableException

    为什么80 的码农都做不了架构师 xff1f gt gt gt 先交待下项目背景 xff0c 项目中有个功能是从mysql中获取数据库信息来创建数据库连接 xff0c 用的连接池是druid xff0c jar包版本是1 0 9 1 异常的
  • 3389、135、137、138、139、445等端口解释和关闭方法

    3389端口 xff1a 在服务器中 xff0c 3389端口的开放是必需的 xff0c 因为任何服务器的管理员如果想很好地管理自己的服务器 xff0c 都需要开启这种方便的网络管理服务 不过3389端口一旦开启 xff0c 必然会引来无数
  • 同一个mock 连续多次调用返回不同结果实现方式

    2019独角兽企业重金招聘Python工程师标准 gt gt gt 同一个mock 连续多次调用返回不同结果实现方式 Mockito when methodCall thenReturn 1x thenReturn 2x thenRetur
  • 特别策划:大学毕业生自主创业分析

    转 特别策划 大学毕业生自主创业分析 本期特别策划以 大学毕业生自主创业 为题 xff0c 主要分为两个部分 xff0c 第一部分对大学毕业生自主创业的分布与特点进行了研究分析 xff0c 第二部分为有意向自主创业的大学生提供建议 PART
  • vscode界面上最左边那一栏不见了

    查看 gt 外观 gt 显示活动栏
  • 论文下载&论文阅读方法(吴恩达教你读论文)

    标题 一 论文下载二 吴恩达读论文方法2 1 主体2 2 Math2 3 Coding 三 职业生涯四 给出的建议五 参考 一 论文下载 Source of paper twitter ML subreddit NIPS ICML ICLR
  • 基于有向距离场(SDF)的地图碰撞系统 | Cocos 技术派第15期

    近日 xff0c ID 为 kx dz 的开发者在 Cocos 中文社区分享了一篇名为 介绍一个基于有向距离场 SDF 的地图碰撞系统 的技术文章 xff0c 获得诸多好评 C姐第一时间联系到了作者 xff0c 在获得转载授权的同时 xff
  • SQL 查询当天,本月,本周的记录

    SELECT FROM 表 WHERE CONVERT Nvarchar dateandtime 111 61 CONVERT Nvarchar GETDATE 111 ORDER BY dateandtime DESC 本月记录 SELE
  • VC查找网页源码指定内容

    查找网页源码 xff0c 这段代码也可以作为获取外网IP xff0c 不过获取外网IP只需要前面一部分就行了 xff0c 把网页源码读到缓冲区就行了 CString SiteInfo SiteName 61 http www ip138 c
  • 笔试之内存分配问题

    需要知道的概念 xff1a 1 程序 xff1a 包括代码和数据 xff0c 是静态的概念 2 进程 xff1a 程序的执行过程 xff0c 是指一个程序中的代码在一个数据集合中的运行过程 xff0c 所以说相同代码在不同的数据集合上运行