C语言-结构体

一. 结构体

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

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

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

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

注意:在对结构体中的name[20]进行赋值时,不能使用=赋值,而应该使用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;
}
相关推荐
爱编码的小八嘎1 小时前
C语言完美演绎9-29
c语言
qq_296553271 小时前
矩阵对角线遍历:从暴力到最优的优雅解法
数据结构·线性代数·算法·青少年编程·矩阵·深度优先遍历
浅念-9 小时前
递归解题指南:LeetCode经典题全解析
数据结构·算法·leetcode·职场和发展·排序算法·深度优先·递归
Dlrb121113 小时前
C语言-指针数组与数组指针
c语言·数据结构·算法·指针·数组指针·指针数组·二级指针
坚果派·白晓明13 小时前
【鸿蒙PC三方库移植适配框架解读系列】第一篇:Lycium C/C++ 三方库适配 — 概述与环境配置
c语言·开发语言·c++·harmonyos·开源鸿蒙·三方库·c/c++三方库
谙弆悕博士17 小时前
快速学C语言——第19章:C语言常用开发库
c语言·开发语言·算法·业界资讯·常用函数
如竟没有火炬18 小时前
接雨水22
数据结构·python·算法·leetcode·散列表
ʚ希希ɞ ྀ18 小时前
二叉树的锯齿层序遍历
数据结构·算法
tyung19 小时前
用 Go 实现一个生产级 Ring Buffer Queue:环形数组、位运算取模、批量操作全拆解
数据结构·go