【C语言】结构体、枚举、联合体

2024-09-08 06:04
文章标签 语言 结构 枚举 联合体

本文主要是介绍【C语言】结构体、枚举、联合体,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【C语言】结构体、枚举、联合体


文章目录

    • @[TOC](文章目录)
  • 前言
  • 一、结构体声明
    • 1.一般格式
    • 2.typedef 重命名结构体类型定义变量
  • 二、结构体数组
  • 三、结构体与指针及函数传参
  • 四、结构体传参
  • 五.结构体在内存的存储
  • 六、参考文献
  • 总结

前言

使用工具:
1.编译器:VScode
2.C Primer Plus 第六版-1


提示:以下是本篇文章正文内容,下面案例可供参考

一、结构体声明

1.一般格式

结构体标签+结构体变量名=结构体类型=
struct +stu
结构体标签+结构体变量名+定义变量=
struct +stu +s

struct stu s
struct stu
{char name[20];char gender[10];int age;float score;
};int main()
{struct stu s={"王二麻子", "男", 22, 98.8};printf("%s %s %d %0.2lf\n",s.name,s.gender,s.age,s.score);return 0;
}
王二麻子 男 22 98.80

2.typedef 重命名结构体类型定义变量

typedef +结构体标签+结构体变量名=结构体类型=新结构体变量名

typedef+struct +stu=stu1

typedef struct stu
{
}stu1;

将struct stu重定义为stu1,此时,stu1可代替struct stu创建变量
新结构体类型+定义变量
stu1+s

stu1 s
typedef struct stu
{char name[20];char gender[10];int age;float score;
}stu1;int main()
{stu1 s={"王二麻子", "男", 22, 98.8};printf("%s %s %d %0.2lf\n",s.name,s.gender,s.age,s.score);return 0;
}
王二麻子 男 22 98.80

二、结构体数组

typedef +结构体标签+结构体变量名=结构体类型=新结构体变量名
typedef+struct+stu=stu1

结构体类型+数组元素类型=结构体数组类型
stu1+stu[3]

typedef struct stu
{char name[20];char gender[10];int age;float score;
}stu1;int main()
{int i;stu1 stu[3]={{"李四", "男", 22, 98.8},{"张三","男",21,95.5},{ "翠花", "女", 20, 99} };int sz=sizeof(stu)/sizeof(stu[0]);printf("%s %s %s %s\n","姓名","性别","年龄","得分");for(i=0; i<sz; i++){printf("%s  %s  %d  %0.2lf\n",stu[i].name,stu[i].gender,stu[i].age,stu[i].score);}return 0;
}
姓名 性别 年龄 得分
李四  男  22  98.80
张三  男  21  95.50
翠花  女  20  99.00

三、结构体与指针及函数传参

指针访问成员变量 一般使用 -> 操作符
即通过地址访问成员变量使用->
通过值访问成员变量使用.

typedef struct stu
{char name[20];char gender[10];int age;float score;
}stu1;int main()
{stu1 s={"王二麻子", "男", 22, 98.8};stu1 *p=&s; printf("%s %s %d %0.2lf\n",					p->name,(&s)->gender,(*p).age,s.score);return 0;
}
王二麻子 男 22 98.80

四、结构体传参

值传递:形参是实参的一份临时拷贝,函数执行完成时,分配给形参的内存自动销毁。
址传递:传的是变量的地址,通过地址可以访问,并且可以修改变量的值。
建议结构体传参,不管是用来访问结构体成员,还是修改结构体成员都建议传地址过去

typedef struct stu
{char name[20];char gender[10];int age;float score;
}stu1;void print1(stu1  s)
{printf("%s\n",s.name);printf("%s\n",s.gender);printf("%d\n",s.age);printf("%0.2lf\n",s.score);
}
void print2(stu1* p)
{printf("%s\n",p->name);printf("%s\n",p->gender);printf("%d\n",p->age);printf("%0.2lf\n",p->score);
}
int main()
{stu1 s={"王二麻子", "男", 22, 98.8};print1(s);print2(&s);return 0;
}
王二麻子
男
22
98.80
王二麻子
男
22
98.80

五.结构体在内存的存储

六、参考文献

自定义类型-结构体详解

总结

本文仅仅简单介绍了【C语言】结构体、枚举、联合体验证,评论区欢迎讨论。

这篇关于【C语言】结构体、枚举、联合体的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1147318

相关文章

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

hdu 2489 (dfs枚举 + prim)

题意: 对于一棵顶点和边都有权值的树,使用下面的等式来计算Ratio 给定一个n 个顶点的完全图及它所有顶点和边的权值,找到一个该图含有m 个顶点的子图,并且让这个子图的Ratio 值在所有m 个顶点的树中最小。 解析: 因为数据量不大,先用dfs枚举搭配出m个子节点,算出点和,然后套个prim算出边和,每次比较大小即可。 dfs没有写好,A的老泪纵横。 错在把index在d

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

hdu 6198 dfs枚举找规律+矩阵乘法

number number number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Problem Description We define a sequence  F : ⋅   F0=0,F1=1 ; ⋅   Fn=Fn

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

如何确定 Go 语言中 HTTP 连接池的最佳参数?

确定 Go 语言中 HTTP 连接池的最佳参数可以通过以下几种方式: 一、分析应用场景和需求 并发请求量: 确定应用程序在特定时间段内可能同时发起的 HTTP 请求数量。如果并发请求量很高,需要设置较大的连接池参数以满足需求。例如,对于一个高并发的 Web 服务,可能同时有数百个请求在处理,此时需要较大的连接池大小。可以通过压力测试工具模拟高并发场景,观察系统在不同并发请求下的性能表现,从而

C语言:柔性数组

数组定义 柔性数组 err int arr[0] = {0}; // ERROR 柔性数组 // 常见struct Test{int len;char arr[1024];} // 柔性数组struct Test{int len;char arr[0];}struct Test *t;t = malloc(sizeof(Test) + 11);strcpy(t->arr,