跟我一起学Linux系统编程006B-进程内存布局、mmap调用、环境变量

Linux系统编程006B-进程内存布局、mmap调用、环境变量

1 进程内存布局

 下图是一个32位Linux进程的内存空间分布图。

Linux系统编程006B-进程内存布局、mmap调用、环境变量

(1)保留区

从0开始到0x08048000这一段,属于保留区。实际上,这部分并不是个单一的内存区域,而是禁止用户进程访问的地址区域的总称,这段地址空间中受到操作系统保护。

如果这段内存区能操作的话,你的C代码中的空指针NULL也就合法了。所以,大多数操作系统中,极小的地址通常都是不允许访问的。C语言将无效指针赋值为0(NULL)也是出于这种考虑,因为0地址上正常情况下不会存放有效的可访问数据。

(2)代码段(text)

通常用于存放程序执行代码(即CPU执行的机器指令)。指令中包括操作码和操作对象(或对象地址引用),如果操作对象是立即数,直接会包含在本区代码段中;若是局部数据,将在栈区分配空间,然后引用该数据地址;若位于BSS段和数据段,指令会引用该数据地址。

(3)数据段(Data)

如果程序的数据是全局变量,并且定义的同时有初始化值。这样的变量,就存储在数据段。然后在进程在加载,这一段的内存就被复制到相应的内存。

当程序读取数据段的数据时,系统会触发缺页故障,从而分配相应的物理内存;当程序读取BSS段的数据时,内核会将其转到一个全零页面,不会发生缺页故障,也不会为其分配相应的物理内存。

(4)BSS段

没有初始化的全局变量会被加载到此段内存区。<

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
当然,我可以为您创建一个基本的设置页面,您可以使用 HTML、CSS 和 JavaScript 来实现。以下是示例代码: HTML 代码: ``` <!DOCTYPE html> <html> <head> <title>设置</title> <link rel="stylesheet" type="text/css" href="style.css"> </head> <body> <div class="container"> <h1>设置</h1> <form> <label for="name">姓名:</label> <input type="text" id="name" name="name"><br> <label for="email">邮箱:</label> <input type="email" id="email" name="email"><br> <label for="password">密码:</label> <input type="password" id="password" name="password"><br> <button type="submit" class="btn">保存</button> </form> <a href="index.html" class="btn">返回</a> </div> </body> </html> ``` CSS 代码: ``` .container { max-width: 500px; margin: 0 auto; text-align: center; } h1 { font-size: 36px; margin-bottom: 30px; } form { display: inline-block; text-align: left; } label { display: block; margin-bottom: 10px; } input[type="text"], input[type="email"], input[type="password"] { padding: 10px; font-size: 16px; border: 1px solid #ccc; border-radius: 4px; margin-bottom: 20px; width: 100%; } button { padding: 10px; background-color: #4CAF50; color: white; font-size: 16px; border: none; border-radius: 4px; cursor: pointer; } button:hover { background-color: #3e8e41; } .btn { display: inline-block; margin-top: 20px; margin-right: 10px; padding: 10px; background-color: #008CBA; color: white; font-size: 16px; border: none; border-radius: 4px; cursor: pointer; } .btn:hover { background-color: #006B9E; } ``` JavaScript 代码: ``` // 这里可以添加 JavaScript 代码来实现更复杂的功能 ``` 这个页面包含一个表单来输入用户信息,以及一个“保存”按钮和一个“返回”按钮。您可以使用 JavaScript 添加更多的功能,例如验证表单数据或将数据保存到服务器。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

虎哥的世界

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值