二维数组
例如:int arr[3][4]={0};
行数: sizeof(arr)/sizeof(arr[0]) 首先获全部数据的内存空间,再除以一行数据的内存空间得到行数
列数: sizeof(arr[0])/siaeof(arr[0][0]) 获得一行数据的内存空间,在初除以一个数据的内存空间得到列数
二维数组的存储空间在内存上是连续存储的。
二维数组在进行初始化的时,行上的索引可以省略,列上的不可以省略。int arr[][4]={0};
结构体
struct stu{
char name;
int age;
}
我们可以通过 struct stu s 创建一个对象s,我们可以通过 s.name s.age 对结构体的内容进行访问
若我们把s的地址赋值给指针*p int* p = &s; 我们可以通过p->name p->age 对结构体内容进行访问
公用体
结构体和共用体的区别在于:结构体的各个成员会占用不同的内存,互相之间没有影响;而共用体的所有成员占用同一段内存,修改一个成员会影响其余所有成员。
结构体占用的内存大于等于所有成员占用的内存的总和(成员之间可能会存在缝隙),共用体占用的内存等于最长的成员占用的内存。共用体使用了内存覆盖技术,同一时刻只能保存一个成员的值,如果对新的成员赋值,就会把原来成员的值覆盖掉。
共用体内存空间共同使用
union stu{
常量/或者变量
}
指针
两个指针在指向同一内存空间时,指针 - 指针 = 中间元素的个数。
指针在进行关系运算的时候:允许往后越界,不允许往前越界。
野指针:
没有指向具体空间的指针 。 注意:野指针不能正常使用
指针的运算:
*p++ :可以看成 * (p++) :对地址经行+ 1.
(*p)++ : 可以看成 对该地址对应的值经行 + 1
指针数组
:int * parr={&a,&b,&c,&d} 将地址存放在一个二维数组。目前并没有太大的意义
插播(scanf 在读取输入的数据是有返回值的,返回值等于输入的数据的数量,若没有读取到的数据有误返回 EOF)
二级指针:
二级指针存放的时一级指针的地址
int a =10;
int * pa=&a; 一级指针
int ** ppa = &pa;二级指针
二级指针中 int * 代表 ppa指向的对象类型是int * 类型
* ppa 代表ppa是指针
枚举:
enum stu{
常量1,
常量2,
常量3
}
枚举相当于定义一系列常量:为了后期对数据进行更好的维护。