首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

浅谈textdata和bss

一般情况,一个程序本质上都是由 bssdata、text三个组成——这是计算机程序设计中重要的基本概念。...比如,在C语言程序编译完成之后,已初始化的全局变量保存在.data 中,未初始化的全局变量保存在.bss 中。 text: 用于存放程序代码的区域, 编译时确定, 只读。...区别很明显,程序1位于bss,程序2位于data,两者的区别在于: 全局的未初始化变量存在于bss中,具体体现为一个占位符,全局的已初始化变量存于data中,而函数内的自动变量都在栈上分配空间。...data(已手动初始化的数据)为数据分配空间,数据保存在目标文件中。 data包含经过初始化的全局变量以及它们的值。...BSS的大小从可执行文件中得到,然后链接器得到这个大小的内存块,紧跟在数据后面。当这个内存区进入程序的地址空间后全部清零,包含data和bss的整个区段此时通常称为数据区。

2.3K11
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    浅谈Linux dirty data配置

    pages, the number of pages at which the background kernel flusher threads will start writing out dirty data...dirty_background_ratio为变量计算出来的门限值的一半((thresh+bg_thresh)*available/2)时,除了会唤醒内核per-bdi 刷新线程触发回写脏页外,进程进入休眠等待一时间...vm_dirty_ratio*available_memory+dirty_background_ratio*available_memory)/100值的一半的条件时,进程设置为TASK_KILLABLE状态后休眠等待一时间...vm.dirty_writeback_centisecs The kernel flusher threads will periodically wake up and write `old' data...的字符作为线程名创建内核rescuer线程,在这里是"writeback",只有kworker线程不足以处理work时才会被启用,具体实现参考https://www.binss.me/blog/analysis-of-linux-workqueue

    3.9K100

    Linux从头学03:如何告诉 CPU,代码、数据、栈在内存中什么位置?

    就拿学习 Linux 操作系统来说,作为一个长期的学习计划,不太可能一上来就阅读最新的 Linux 5.13 版本的代码。...在之前的一篇文章中,演示了 ELF 格式的可执行文件中,具体包含了哪些Linux系统中编译、链接的基石-ELF文件:扒开它的层层外衣,从字节码的粒度来探索》: ?...在 Linux 2.6 代码中,由于 Linux 把整个 4 GB 的地址空间当做一个“扁平”的结果来处理(的基地址是 0x0000_0000,偏移地址的最大值是 4GB),因此虚拟地址(逻辑地址)在数值上等于线性地址...这张图的意思是:在 Linux 2.6 中,用户代码的开始地址是 0,最大范围是 4 GB;用户数据的开始地址是 0,最大范围也是 4 GB;内核的数据和代码也是如此。 ?...Linux 之所以要这样安排,是因为它不想过多的利用 x86 提供的机制来进行内存地址的管理,而是想充分利用分页机制来进行更加灵活的地址管理。

    2.2K40

    尘封的中国 Linux 往事

    按照章文嵩对Julian的描述的说法,Julian写程序非常厉害,但也很神秘,两个人一直通过邮件联系,即便时间已经过去二十多年,两人至今仍然没见过面,却始终维持着一基于开源信仰的珍贵友谊。...他也不是凡人,而是Linux中文化最积极的推动者,也是水木清华BBS的 Linux斑竹(即版主),名叫方汉。...年轻的方汉很喜欢玩这个游戏,喜欢到自己上手研发,因此开始自学Linux架服务器。结果他发现Linux比MUD还好玩,兴趣自然转向了Linux。...为了专注研究Linux中文化,方汉当时还有了一个小团队,成员包括他高能物理所的两个师兄陈向阳、于明俭。 他们一起解决了很多Linux中文化的问题,在圈内一时有了“中文Linux三剑客”的名头。...魏永明带着几个研究生基于Linux重新设计了数控系统的架构,并利用业余时间为Linux系统重写MiniGUI。 在Linux上重写后的MiniGUI功能更丰富,用户体验更好。

    1.4K10

    linux有一时间后

    linux有一时间后该知道的细节 1、wrx各个权限在文件和文件夹的不同。...TED-WNAG/g或:1,$s/Ted-Wnag/TED-WNAG/gc 8、区块选择、多文件编辑、多窗口编辑、环境设定、断行字符、语系转换待补充 9、跳脱[Enter] ---- ---- ---- 用linux...有一时间后该知道的命令 1、chgrp、chown、chmod和mkdir、rmdir的递归参数 2、ls -al和ls -alS 3、cp -i和cp -l(硬连结)/cp -S(符号连结) 4、rm...『$(指令)』 『version=(uname -r)』『echo version』->『3.10.0-229.el7.x86_64』 版权所有:可定博客 © WNAG.COM.CN 本文标题:《用linux...有一时间后》 本文链接:https://wnag.com.cn/28.html 特别声明:除特别标注,本站文章均为原创,本站文章原则上禁止转载,如确实要转载,请电联:wangyeuuu@qq.com,

    1.6K20

    GOTlinux系统中实现代码动态加载的作用和其他的说明

    动态加载,也就是在调用系统函数时再去确认所调用的函数地址的技术需要使用两个,一个是.plt,一个是.got.plt。...后者其实是.got的一种特定形式,.got在程序的加载和执行过程中还有其他形式和作用,在后续章节我们再研究。 上一节我们以调研系统函数puts为例描述了动态加载的基本过程。...由于.text设置为不可写,如果可写,那么就可能让人直接修改其中代码指令了。.got.plt属于数据,因此里面的数据可以修改,绕这个弯的目的就是防止代码被他人直接修改。...除了.got.plt外,还需要理解的是.got,后者的作用主要在于访问共享代码库到处的变量。两者区别在于.got.plt包含了代码,而.got会直接包含共享库到处的变量地址而不是包含代码。...我们再看其他一些重要的。在后面二进制分析中,我们还需了解.rel.或.rela.这类重定向。他们的类型属于SHT_RELA,这些的作用在于帮助链接器实现代码重定向。

    2.3K20

    如何在Linux上获得错误的核心转储

    今天小编要跟大家分享的文章是关于Linux上错误的核心转储问题。喜欢Linux操作系统,对Linux感兴趣的小伙伴快来看一看吧,希望通过本篇文章能够有所收获。 首先我们来说一说什么是错误?...这个“C++ 虚表指针”是我的程序发生错误的情况。我可能会在未来的博客中解释这个,因为我最初并不知道任何关于 C++ 的知识,并且这种虚表查找导致程序错误的情况也是我所不了解的。...当您的程序出现错误,Linux 的内核有时会把一个核心转储写到磁盘。 当我最初试图获得一个核心转储时,我很长一时间非常沮丧,因为 – Linux 没有生成核心转储!我的核心转储在哪里?...Max data size unlimited unlimited bytes 6. Max stack size 8388608 unlimited bytes 7....kernel.core_pattern:核心转储保存在哪里 kernel.core_pattern 是一个内核参数,或者叫 “sysctl 设置”,它控制 Linux 内核将核心转储文件写到磁盘的哪里。

    4K20

    Linux错误(核心已转储)(core dumped)问题的分析方法

    前言 在Linux系统中,程序运行时可能会遇到错误(Segmentation Fault),这是一种常见的运行时错误,通常由于程序试图访问其内存空间中未分配(或不允许)的部分时发生。...当错误发生时,系统可能会生成一个核心转储(core dump),它是一个包含程序终止时的内存映像的文件,可以用于后续的调试和问题分析。 本文将探讨如何分析错误,并利用核心转储文件定位问题。...一、错误概述 错误发生的原因可能包括但不限于: 指针访问无效的内存地址。 栈溢出,例如递归调用太深。 违反了内存保护规则。 内存越界(数组越界,变量类型不一致等) 访问到不属于你的内存区域。...cpu中的运行级别,指向 的gdt是由以64位为一个单位的表,在这张表中就保存着程序运行的代码以及数据的 一旦一个程序发生了越界访问,cpu就会产生相应的保护,于是segmentation fault...echo /data/coredump/core.%e.

    2.4K10

    Linux学习26-linux查看某个时间的日志(sed -n)-史上最详细

    前言 在linux上查找日志的时候,如果我想找出某个时间的日志,比如查找今天早上8点到下午2点的日志。...GET /api/config_list/1/ HTTP/1.1" 200 19532 比如我要查找上面的从 2019-10-24 22:16:21 到 2019-10-24 22:16:59 这个时间的日志...sed -n ‘/2019-10-24 22:16:21/,/2019-10-24 22:16:58/p’ all.log 模糊查询 如果不知道日志的开始时间,不能精确到秒,可以用模糊查询,比如查询时间2019...也可以按小时模糊查询 sed -n ‘/2019-10-24 21*/,/2019-10-24 22*/p’ all.log 结合grep查询 sed 也可以结合 grep 使用,比如我查询上面日志某个时间的带有...log_message] [INFO]- "POST /api/add_case/ HTTP/1.1" 200 0 [root@VM_0_2_centos logs]# 日志导出 我们可以查询某个时间的日志

    4.5K10
    领券