当前位置:首页 > 第一章:C语言关键字 - 图文
1. 大端模式(Big_endian):字数据的高字节存储在低地址中,而字数据的低字节则
存放在高地址中。
2. 小端模式(Little_endian):字数据的高字节存储在高地址中,而字数据的低字节
则存放在低地址中。
union 型数据所占的空间等于其最大的成员所占的空间。对union 型的成员的存取都是相对于该联合体基地址的偏移量为0 处开始,也就是联合体的访问不论对哪个变量的存取都是从union 的首地址位置开始。如此一解释,上面的问题是否已经有了答案呢?
二、如何用程序确认当前系统的存储模式?
上述问题似乎还比较简单,那来个有技术含量的:请写一个C 函数,若处理器是Big_endian 的,则返回0;若是Little_endian 的,则返回1。
先分析一下,按照上面关于大小端模式的定义,假设int 类型变量i 被初始化为1。
以大端模式存储,其内存布局如下图:
以小端模式存储,其内存布局如下图:
变量i 占4 个字节,但只有一个字节的值为1,另外三个字节的值都为0。如果取出低地址上的值为0,毫无疑问,这是大端模式;如果取出低地址上的值为1,毫无疑问,这是小端模式。既然如此,我们完全可以利用union 类型数据的特点:所有成员的起始地址一致。
到现在,应该知道怎么写了吧?参考答案如下: int checkSystem( ) {
union check { int i; char ch; } c; c.i = 1;
return (c.ch ==1); }
现在你可以用这个函数来测试你当前系统的存储模式了。当然你也可以不用函数而直接去查看内存来确定当前系统的存储模式。如下图:
图中0x01 的值存在低地址上,说明当前系统为小端模式。
不过要说明的一点是,某些系统可能同时支持这两种存储模式,你可以用硬件跳线或在编译器的选项中设置其存储模式。
留个问题:在x86 系统下,输出的值为多少?
#include
int a[5]={1,2,3,4,5}; int *ptr1=(int *)(&a+1); int *ptr2=(int *)((int)a+1); printf(\ return 0; }
19. C语言enum关键字
很多初学者对枚举(enum)感到迷惑,或者认为没什么用,其实枚举(enum)是个很有用的数据类型。
一、枚举类型的使用方法
一般的定义方式如下: enum enum_type_name {
ENUM_CONST_1, ENUM_CONST_2, ...
ENUM_CONST_n } enum_variable_name;
注意:enum_type_name 是自定义的一种数据数据类型名,而enum_variable_name 为enum_type_name类型的一个变量,也就是我们平时常说的枚举变量。实际上enum_type_name类型是对一个变量取值范围的限定,而花括号内是它的取值范围,即enum_type_name 类型的变量enum_variable_name 只能取值为花括号内的任何一个值,如果赋给该类型变量的值不在列表中,则会报错或者警告。ENUM_CONST_1、ENUM_CONST_2、...、ENUM_CONST_n,这些成员都是常量,也就是我们平时所说的枚举常量(常量一般用大写)。
enum 变量类型还可以给其中的常量符号赋值,如果不赋值则会从被赋初值的那个常量开始依次加1,如果都没有赋值,它们的值从0 开始依次递增1。如分别用一个常数表示不同颜色: enum Color {
GREEN = 1, RED, BLUE,
GREEN_RED = 10, GREEN_BLUE }ColorVal;
其中各常量名代表的数值分别为: GREEN = 1 RED = 2 BLUE = 3
GREEN_RED = 10 GREEN_BLUE = 11
二、枚举与#define 宏的区别
下面再看看枚举与#define 宏的区别:
1)#define 宏常量是在预编译阶段进行简单替换。枚举常量则是在编译的时候确定其值。 2)一般在编译器里,可以调试枚举常量,但是不能调试宏常量。 3)枚举可以一次定义大量相关的常量,而#define 宏一次只能定义一个。
留两个问题:
A),枚举能做到事,#define 宏能不能都做到?如果能,那为什么还需要枚举? B),sizeof(ColorVal)的值为多少?为什么?
20. C语言typedef关键字—伟大的缝纫师
关于马甲的笑话。有这样一个笑话:一个猎人在河边抓捕一条蛇,蛇逃进了水里。过一会,一个乌龟爬到岸边。猎人一把抓住这个乌龟,大声的说道:小样,别你为你穿了个马甲我就
共分享92篇相关文档