转自:http://www.itwendao.com/article/detail/404132.html

  • Linux应用程序运行出现错误,有时候并不会马上就体现出来。-_-可能是由于错误的条件还没触发把。
  • 但是发生的错误应该在哪里查找呢?—这时候,我们的Core Dump就派上用场了。

一、Core Dump——核心转存

    1. 定义

      • Core Dump又叫核心转存。当程序在运行过程中发生异常, 这时Linux系统可以把程序出错时的内存内容存储在一个core文件中, 这种过程叫Core Dump。
    2. 产生的原因
      • Linux应用程序在运行过程中,经常会遇到Segment fault(段错误) 这样的错误。产生这样错误的原因通常有:
        1. 数组访问越界
        2. 访问空指针
        3. 栈溢出
        4. 修改只读内存
    3. 开启和关闭
      1. 打开:ulimit -c ulimited
      2. 关闭:ulimit -c 0
      3. 查看:ulimit -c
    4. 分析命令
      用法 gdb 程序名 core文件名
      功能 发生core dump之后, 可以使用gdb进行查看core文件的内容, 以定位程序出错的位置
      gdb ./test core.12345
    5. 示例
      功能 这个程序在函数中访问了空指针导致异常的发生,查看core dump文件的具体过程
      步骤

      1、开启core dump功能;(ulimit -c ulimited)

      2、编写程序test.c文件,生成可执行文件test;(gcc -g test.c -o test)

      3、查看core dump文件,找出错误;(gdb ./test core.12345)

#include <stdio.h>
int main( int argc , char **argv ) {
char *p ;
*p = 250 ;
return 0 ;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

二、Linux程序地址分析

  • 程序构成

    在Linux应用程序中,函数代码中的变量、方法等都有其存储空间,下面就介绍下这几个存储空间:

    数据存放 内存布局

    当Linux应用程序在内存中运行的时候,以上组成部分在内存中又是如何布局的呢?

    代码段: 代码,全局常量(const)、字符串常量;

    1.从低地址到高地址分别为:代码段、数据段、BSS段、堆、栈;

    2.堆向高内存地址生长;

    3.栈向低内存地址生长;

    数据段: 全局变量(初始化以及未初始化的)、静态变量(全局的和局部的、初始化的以及未初始化的);
    BSS段(Block Started by Symbol,

    又名:未初始化数据段):

    这里其实是数据段中的一个子分区而已;
    堆(heap): 动态分配的区域;
    栈(stack): 局部变量(初始化以及未初始化的,但不包含静态变量)、局部只读变量(const);
    编写程序查看数据的内存地址分布:

    1、编写程序chen.c(代码如下);

    2、生成可执行程序chen(gcc -g chen.c -o chen);

    3、执行程序;

    4、开启另外一个终端,使用命令(ps aux)查看程序的执行pid123;

    5、cat /proc/pid123/maps/即可看到程序占用的内存地址;

    注意:

    1、每个程序的内存起始地址都是0x8048000;

    2、每个程序在内存中都占用同一块代码区和数据区;

1、Linux的执行程序格式都是elf的;可以使用命令readelf -S 可执行程序查看程序的地址分布情况;
2、命令file可以查看文件的格式;

include <stdio.h>
int main ( int argc , char **argv ) {
int a ;
scanf("please don't enter number :%d\n",&a) ;
return 0 ;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

01-Coredump核心转存&&Linux程序地址分析【转】的更多相关文章

  1. linux应用程序地址布局,王明学learn

    linux应用程序地址布局 在学习Linux应用程序开发时,经常会遇到如下概念:代码段.数据段.BSS段(Block Started by Symbol,又名:未初始化数据段).堆(heap)和栈(s ...

  2. 如何实现在Windows上运行Linux程序,附示例代码

    微软在去年发布了Bash On Windows, 这项技术允许在Windows上运行Linux程序, 我相信已经有很多文章解释过Bash On Windows的原理, 而今天的这篇文章将会讲解如何自己 ...

  3. 编写出色的GNU/Linux程序

    http://advancedlinuxprogramming.com提供了本书电子版的免费下载. 1 与执行环境交互 关于参数 C语言程序的main()函数使用两个参数和执行环境交互--(int)a ...

  4. linux程序自启动和新建linux服务的方法

    1 linux创建自启动程序    自启动的两种方法,都经过自己测试.1.1 自启动程序方法1:    在etc/rc.local在里面加入/home/robin/code/autoruntest & ...

  5. 应用 Valgrind 发现 Linux 程序的内存问题(转)

    Valgrind 概述 体系结构 Valgrind 是一套Linux下,开放源代码(GPL V2)的仿真调试工具的集合.Valgrind由内核(core)以及基于内核的其他调试工具组成.内核类似于一个 ...

  6. Linux程序包管理rpm与yum

    Linux程序包管理 Linux中软件的安装主要有两种形式:一种是直接下载源代码包自行编译后安装,另一种直接获取rpm软件包进行安装. 程序的组成部分: 二进制程序:程序的主体文件,比如我们运行一个l ...

  7. [转载]应用 Valgrind 发现 Linux 程序的内存问题

    应用 Valgrind 发现 Linux 程序的内存问题 如何定位应用程序开发中的内存问题,一直是 inux 应用程序开发中的瓶颈所在.有一款非常优秀的 linux 下开源的内存问题检测工具:valg ...

  8. 操作系统-存储管理(5)IA-32/Linux的地址转换

    IA-32/Linux按字节编址:在保护模式下,IA-32采用段页式虚拟存储管理方式,存储地址采用逻辑地址.线性地址和物理地址来进行描述. 逻辑地址由48位组成,包含16位段选择符(高13位为段表项的 ...

  9. Linux程序包管理之yum及源代码安装

    第十六章.Linux程序包管理之yum及源代码安装 目录 yum介绍 yum配置文件 yum的repo配置文件中可用的变量 yum命令的使用 使用光盘作为本地yum仓库 如何创建yum仓库 编译安装的 ...

随机推荐

  1. Python 变量(下)

    列表 列表是可修改的序列类型.所以列表不可以作为字典的键. >>> a = [1] >>> hash(a) Traceback (most recent call ...

  2. SQLServer 重建索引前后对比 (转)

    https://www.cnblogs.com/mingl12/p/5730178.html

  3. Android性能优化:手把手带你全面了解 内存泄露 & 解决方案

    . 简介 即 ML (Memory Leak)指 程序在申请内存后,当该内存不需再使用 但 却无法被释放 & 归还给 程序的现象2. 对应用程序的影响 容易使得应用程序发生内存溢出,即 OOM ...

  4. [UVALive 3902] Network

    图片加载可能有点慢,请跳过题面先看题解,谢谢 一道简单的贪心题,而且根节点已经给你了(\(S\)),这就很好做了. 显然,深度小于等于 \(k\) 的都不用管了(\(S\) 深度为0),那么我们只需要 ...

  5. 【转】关于在vim中的查找和替换

    1,查找 在normal模式下按下/即可进入查找模式,输入要查找的字符串并按下回车. Vim会跳转到第一个匹配.按下n查找下一个,按下N查找上一个. Vim查找支持正则表达式,例如/vim$匹配行尾的 ...

  6. Linux内核分析实验五

    一.给MenuOS增加time和time-asm命令 1. 克隆并自动编译MenuOS rm menu -rf 强制删除原menu文件 git clone http: cd menumake root ...

  7. 第七周linux学习

    <Linux内核分析> 一.可执行程序是怎么得来的? 编译器预处理(负责把include的文件包含进来及宏替换等工作):编译成汇编代码:编译器编译成目标代码:再链接成可执行文件:操作系统加 ...

  8. 如何在低速率网络中测试 Web 应用

    大家看到标题后的第一个问题可能是:“我们需要这样做吗?” 如果我们开发的是局域网 Web 应用的话,可能没有必要这样做.但如果我们的 Web 应用面向的是互联网上的成千上万的用户,这样做就很必要了.因 ...

  9. java之初学线程

    线程 学习线程相关的笔记,前面写过关于很多线程的使用,有兴趣的可以去了解下 线程 概念理解 并发 : 指两个或多个事件在同一个时间段内发生(交替执行). 并行 : 指两个或多个事件在同一时刻发生(同时 ...

  10. 【cdq分治】【P4390】[BOI2007]Mokia 摩基亚

    Description 给你一个 \(W~\times~W\) 的矩阵,每个点有权值,每次进行单点修改或者求某子矩阵内权值和,允许离线 Input 第一行是两个数字 \(0\) 和矩阵大小 \(W\) ...