1柔性数组 flexible array
C99中,结构中的最后一个元素允许是未知大小的数组,这就叫柔性数组成员,但结构中的柔性数组成员前面必须至少一个其他成员。柔性数组成员允许结构中包含一个大小可变的数组。sizeof返回的这种结构大小不包括柔性数组的内存。包含柔性数组成员的结构用malloc函数进行内存的动态分配,并且分配的内存应该大于结构的大小,以适应柔性数组的预期大小。如:
typedef struct st_type
{
int i;
int a[];
}type_a;
type_a *p = (type_a *)malloc(sizeof(type_a) + (sizeof(int ))*100);
2如何用程序确认当前系统的存储模式(大端模式、小端模式)?
用一个C函数,若处理器是Big_endian的,则返回0;若是Little_endian的,则返回1。
int checkSystem()
{
union chech
{
int i;
char ch;
}c;
C99中,结构中的最后一个元素允许是未知大小的数组,这就叫柔性数组成员,但结构中的柔性数组成员前面必须至少一个其他成员。柔性数组成员允许结构中包含一个大小可变的数组。sizeof返回的这种结构大小不包括柔性数组的内存。包含柔性数组成员的结构用malloc函数进行内存的动态分配,并且分配的内存应该大于结构的大小,以适应柔性数组的预期大小。如:
typedef struct st_type
{
int i;
int a[];
}type_a;
type_a *p = (type_a *)malloc(sizeof(type_a) + (sizeof(int ))*100);
2如何用程序确认当前系统的存储模式(大端模式、小端模式)?
用一个C函数,若处理器是Big_endian的,则返回0;若是Little_endian的,则返回1。
int checkSystem()
{
union chech
{
int i;
char ch;
}c;