1、打印二进制机器码,程序内存分析,大端序小端序,指针数组,数组指针,数组的三种访问方式,typedef,#if-0-#endif,求数组大小,括号表达式



1.打印二进制机器码(分别表示32位的和64位的)

#include <stdio.h>

/*按照8位的长度打印一个数值*/

void dis8bit(char val)

{

int bit = 8;

while(bit--)

{

if(1<<bit&val){

printf("1");

} else {

printf("0");

}

if(!(bit%4))

printf(" ");

}

putchar(10);

}

/*按照32位长度打印数值的机器码*/

void dis32bit(int val){

int bit = 32;

while(bit--){

if(1<<bit&val){

printf("1");

} else {

printf("0");

}

if(!(bit % 4))

printf(" ");

}

putchar(10);

}

int main(void)

{

int a = -1,b = -128,c = 127,d = 0;

dis8bit(a);

dis8bit(b);

dis8bit(c);

dis8bit(d);

int e = 127;

dis32bit(e);

return 0;

}

2.关于程序内存。

Bss区的生命周期是从程序的开始到程序的结束。

3.关于数据在内存中的存储

int a;全局变量,并且未初始化,所在在数据段的bss区。被初始化为0

static int b;
静态全局变量,数据段的bss段,在bss区。

int c[10] = {1,2,3,4}; 
全局的数组在data段,这里的数据在运行的时候会被拷贝来的。

4.大端存储和小端存储引起的问题

在内存中的分析如下:

5.数据类型  
*    指针变量

指针变量,本质同普通变量。

*
指明后面的变量为指针变量

数据类型指明,从该变量存放的地址处的寻址能力。

char *p;  代表了从p这个地址处的寻址能力是1个字节,(因为char
*类型的寻址能力为1个字节)。

指针的一个重要概念  
步长 = 
数据类型的大小

int a[10]等价于==》int[10] 
a;

6.关于typedef关键字

typedef int ARRAY[10];  
给数组定义别名

给参数起别名的步骤:

再如:

void (*p)(int,int);的别名为:typedefvoid (*pp)(int,int);这个时候pp就是指针函数的别名。

7.数组:

数组访问的方式有:

A:下标法,特例列举:

这里说明,如果想得到一个数组的值也可以通过i[a]è下标[数组名]的方式得到

B:偏移法的方式取数值,举例:

C:指针法

*p++ 《==》*(p++)

8.数组局部初始化

9.#if-0-#endif排除某段代码影响

10.数组求大小

求作为函数参数传递的数组名的大小:

11.括号表达式

分析:int xx[3][2] = {(1,2),(3,4),(5,6)};实际上等价于:intxx[3][2]={2,4,6};

内存分析:

1、打印二进制机器码,程序内存分析,大端序小端序,指针数组,数组指针,数组的三种访问方式,typedef,#if-0-#endif,求数组大小,括号表达式,布布扣,bubuko.com

时间: 2024-10-04 06:27:23

1、打印二进制机器码,程序内存分析,大端序小端序,指针数组,数组指针,数组的三种访问方式,typedef,#if-0-#endif,求数组大小,括号表达式的相关文章

Java程序内存分析:使用mat工具分析内存占用

在工作中可能会遇到内存溢出这种灾难性的问题,那么程序肯定是存在问题,找出问题至关重要,上一篇文章讲了jmap命令的使用方法,当然用jmap导出的文件我们也看不懂啊,那就交给memory analyzer(mat)这个工具,让他帮助我们来观察程序的内存分布情况吧. 1. 用jmap生成堆信息 2. 将堆信息导入到mat中分析 3. 生成分析报告 Histogram Dominator Tree Top consumers Leak Suspects MAT 不是一个万能工具,它并不能处理所有类型的

变量在内存中的存储方式-----“大端”和“小端”

"大端"和"小端"可以追溯到1726年的Jonathan Swift的<格列佛游记>,其中一篇讲到有两个国家因为吃鸡蛋究竟是先打破较大的一端还是先打破较小的一端而争执不休,甚至爆发了战争.1981年10月,Danny Cohen的文章<论圣战以及对和平的祈祷>(On holy wars and a plea for peace)将这一对词语引入了计算机界(<程序设计实践>第9章).这么看来,所谓大端和小端,也就是big-endia

[小知识]如果使用union判断机器内存是大端序存储还是小端序存储 @ C

比如int i = 1,如果是小端序存储,那么在内存中应该是这样的:0x01 0x00 0x00 0x00:如果是大端序存储的,在内存中应该是:0x00 0x00 0x00 0x01. 那么如何编程来判断机器是大端序存储呢还是小端序存储呢? 上代码: #include <stdio.h> int isBigEndian() { union { int i; char c; }test; test.c = 1; return test.i != 1; } int main() { printf(

写程序判断系统是大端序还是小端序

大端是高位字节先存储(低地址) 小端是低位字节先存储(低地址) 网络字节序是大端的,也就是高位字节先传输 而int--char的强制转换,是将低地址的数值截断赋给char,利用这个准则可以判断系统是大端序还是小端序 #include <iostream> using namespace std; int main() { int a = 0x1234; char c = static_cast<char>(a); if (c == 0x12) cout << "

大端和小端(big endian little endian)

一.大端和小端的问题 对于整型.长整型等数据类型,Big endian 认为第一个字节是最高位字节(按照从低地址到高地址的顺序存放数据的高位字节到低位字节):而 Little endian 则相反,它认为第一个字节是最低位字节(按照从低地址到高地址的顺序存放据的低位字节到高位字节). 例如,假设从内存地址 0x0000 开始有以下数据:  0x0000         0x0001       0x0002       0x0003  0x12            0x34          

大端和小端(Big endian and Little endian)

一.大端和小端的问题 对于整型.长整型等数据类型,Big endian 认为第一个字节是最高位字节(按照从低地址到高地址的顺序存放数据的高位字节到低位字节):而 Little endian 则相反,它认为第一个字节是最低位字节(按照从低地址到高地址的顺序存放据的低位字节到高位字节). 例如,假设从内存地址 0x0000 开始有以下数据:  0x0000         0x0001       0x0002       0x0003  0x12            0x34          

我如何确定一个机器的字节顺序是大端还是小端?

通常的技巧是使用一个指针: int x = 1; if(*(char *)&x == 1) printf("little-endian\n"); else printf("big-endian\n"); 或者一个union: union { int i; char c[sizeof(int)]; } x; x.i = 1; if(x.c[0] == 1) printf("little-endian\n"); else printf(&qu

【转】轻松记住大端小端的含义(附对大端和小端的解释)

原文网址:http://www.cnblogs.com/wuyuegb2312/archive/2013/06/08/3126510.html 或许你曾经仔细了解过什么是大端小端,也动手编写了测试手头上的机器上是大端还是小端的程序,甚至还编写了大端小端转换程序:但过了一段时间之后,当你再看到大端和小端这两个字眼,你的脑中很快浮起了自己曾经做过的工作,却总是想不起究竟哪种是大端.哪种是小端,然后又去查以前写的记录?更让人不快的是,这种经历反反复复,让你十分困扰.如果你和以前的笔者一样,有过这种不快

判断机器大端序和小端序

//若处理器是Big_endian的,则返回0:若是Little_endian的,则返回1 //联合体union的存放顺序是所有成员都从低地址开始存放 //一个联合变量的长度等于各成员中最长的长度. //应该说明的是,这里所谓的共享不是指把多个成员同时装入一个联合变量内, //而是指该联合变量可被赋予任一成员值,但每次只能赋一种值,赋入新值则冲去旧值. int checkCPU( ) { union w { int a; char b; } c; c.a = 1; return(c.b ==1)