C语言-结构体

一. 结构体

结构体是一种自定义数据类型。

结构体在声明是不开辟内存空间,在定义时才开辟内存空间。

结构体运算符:.:结构体成员运算符,左侧是一个结构体变量。

->:结构体成员运算符,左侧是一个结构体指针。

注意:在对结构体中的name20进行赋值时,不能使用=赋值,而应该使用strcpy函数。

cpp 复制代码
struct per{
    char name[20];
    int age;
    float height;
    char phone[20];
};//声明结构体类型,不会开辟内存空间

int	main(int argc, char **argv)
{
     struct per per1 = {"zhangsan", 20, 175.5, "110"};//定义结构体类型,会开辟空间
     struct per per2 = {.name = "lisi", .height = 180.5};//gcc支持的语法

     printf("name:%s,age:%d,height:%.2f,phone:%s\n",per1.name,per1.age,per1.height,per1.phone);

     printf("name:%s,height:%.2f\n",per2.name,per2.height);//.:结构体成员运算符

     strcpy(per2.name, "wangmazi");//这里是一个字符类型的数组,不可使用=赋值,必须使用strcpy函数进行赋值
     per2.age = 18;
     per2.height = 170.0;
     strcpy(per2.phone,"120");

     printf("name:%s,age:%d,height:%.2f,phone:%s\n",per2.name,per2.age,per2.height,per2.phone);

    struct per per3;
    struct per *pper = &per3;
    scanf("%s %d %f %s",per3.name,&per3.age,&per3.height,per3.phone);
    
    printf("name:%s,age:%d,height:%.2f,phone:%s\n",per3.name,per3.age,per3.height,per3.phone);
    printf("name:%s,age:%d,height:%.2f,phone:%s\n",pper->name,pper->age,pper->height,pper->phone);

    return 0;
}

二. 结构体的内存对齐

内存对齐的原因:

结构体大小计算规则:

  1. 第一个成员在与结构体变量偏移量为0的地址处。

  2. 其他成员变量要对齐到某个数字(对齐数)的整数倍的地址处。

对齐数 = 编译器默认的一个对齐数 与 该成员大小的较小值。

  1. 结构体总大小为最大对齐数(每个成员变量都有一个对齐数)的整数倍。

  2. 如果嵌套了结构体的情况,嵌套的结构体对齐到自己的最大对齐数的整数倍处,结构体的整体大小就是所有最大对齐数(含嵌套结构体的对齐数)的整数倍。

cpp 复制代码
struct per{
    char name[20];
    int age;
    float height;
    char phone[20];
};//声明结构体类型,不会开辟内存空间

int	main(int argc, char **argv)
{
    struct per per1 = {"zhangsan", 20, 175.5, "110"};//定义结构体类型,会开辟空间
    struct per per2 = {.name = "lisi", .height = 180.5};//gcc支持的语法

    printf("name:%s,age:%d,height:%.2f,phone:%s\n",per1.name,per1.age,per1.height,per1.phone);

    printf("name:%s,height:%.2f\n",per2.name,per2.height);//.:结构体成员运算符

    strcpy(per2.name, "wangmazi");//这里是一个字符类型的数组,不可使用=赋值,必须使用strcpy函数进行赋值
    per2.age = 18;
    per2.height = 170.0;
    strcpy(per2.phone,"120");

    printf("name:%s,age:%d,height:%.2f,phone:%s\n",per2.name,per2.age,per2.height,per2.phone);

    struct per per3;
    struct per *pper = &per3;
    scanf("%s %d %f %s",per3.name,&per3.age,&per3.height,per3.phone);
    
    printf("name:%s,age:%d,height:%.2f,phone:%s\n",per3.name,per3.age,per3.height,per3.phone);
    printf("name:%s,age:%d,height:%.2f,phone:%s\n",pper->name,pper->age,pper->height,pper->phone);

    return 0;
}
相关推荐
刘马想放假2 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠3 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦10 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
LDR00611 天前
Type-C 快充全面升级!LDR6601 赋能个人护理便携电机,重塑剃须刀 / 理发器新体验
c语言·开发语言
小小工匠11 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
Luminous.11 天前
C语言--day30
c语言·开发语言
玖玥拾11 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
謓泽11 天前
C语言不是语法,是通往机器的地图。
c语言·开发语言
不会C语言的男孩11 天前
Linux 系统编程 · 第 8 章:进程基础
linux·c语言
Qres82111 天前
算法复键——树状数组
数据结构·算法