您的位置:首页 > 编程语言 > C语言/C++

C语言笔记之关键字(二)

2016-03-10 18:54 260 查看
柔性数组

结构中的最后一个元素是未知大小的数组,这就叫做柔性数组成员,但结构体中的柔性数组成员之前必须至少一个其他成员。sizeof返回的这种结构的大小是不包括柔性数组的内存。包含柔性数组成员的结构用malloc()函数进行内存的动态分配,并且分配的内存应该大于结构的大小,以适应柔性数组的预期大小。

typedef struct st_type
{
int i;
int a[];
}type_a;


用sizeof(type_a)得到的结果是4,0个元素的数组没有占内存空间,而后就可以进行变长操作。通过下列狮子为结构体分配内存。

type_a *p=(type_a*)malloc(type_a)+100*sizeof(int);


这样用p->a[]就能简单访问可变长元素,这时候再用sizeof(*p)测试结构体的大小,发现仍然为4.柔性数组只是编外成员,不占结构体的编制,只是说在使用柔性数组时把它当作结构体的一个成员。

struct与class

默认属性一个是共有的一个是私有的。

union

union中所有的数据成员共用一个空间,同一时间只能存储其中一个数据成员,所有的数据成员具有相同的其实地址,成员默认属性为public,主要用来压缩空间。大小端模式对union类型数据的影响:

union

{

int i;

char a[2];

}*p,a;

p = &a;

p->a[0] = 0x39;

p->a[1] = 0x38;


大端模式:子数据的高字节存放在低地址中,低字节存放在高地址中,小端模式则相反。

union类型所占的空间等于其最大空间所占的空间。对union型的成员的存取都是相对于该联合体基地址的偏移量从0处开始,也就是联合体的访问不论从哪个变量的都是从union的首地址位置开始。

如何确认当前系统的存储模式,变量i占4个字节,但只有一个字节的值为1,另外三个字节的值都为0,如果取出低地址上的值为0,则是大端模式。

int checkSystem()
{
union check
{
int i;
char ch;
}c;
c.i = 1;
return (c.ch==1);
}


enum

enum Color
{
GREEN = 1,
RED,
BLUE,
GREEN_REN = 10,
GREEN_BLUE = 11
}ColorVal;
int main()
{
int i =sizeof(ColorVal);
}


实际上ColorVal是Color类型的饿一个变量,调试知ColorVal = 0,i = 4,Color类型是对一个变量取值范围的限定,而花括号是它的取值范围,如果赋给该类型变量的值不在该列表中就会报错。

枚举与#define的区别:

#define宏常量实在预编译阶段进行替换,枚举常量是在编译的时候确定其值;

一般在编译器里,可以调试枚举常量,但是不能调试宏常量;

枚举可以一次定义大量相关的常量,而#define只能一次定义一个。

typedef:

给一个已经存在的数据类型取一个别名。

typedef struct student
{
//
}Stu_st,*Stu_pst;


把struct student看成一个整体,typedef就是给这个整体取了个别名叫做Stu_st,同时给它取了个别名叫做Stu_pst,只不过这两个名字同时取而已。用const修饰时?

typedef int INT32;
unsigned INT32 i =10;


编译会出错,typedef取的别名不支持这种类型扩展。

define a int [10]与typedef int a【10】;

待续—啦啦啦明天见
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: