从零开始学习C语言丨构造类型——结构体
yuyutoo 2024-10-12 00:46 4 浏览 0 评论
通过前面的学习,已经知道了C语言当中一个变量也可以存储多个数据,如数组类型,可以存储多个相同类型的数据。
但有时候,我们需要在一个变量中存储多个不同类型的数据。例如一个学生,有姓名、年龄、性别等等。姓名和性别属于 char 字符类型,年龄则是 int 类型,使用数组显然是不能的。
接下来,就来学习一下C语言的构造数据类型——结构体。
1. 什么是结构体?
在C语言当中,变量是需要定义数据类型的。诸如 int、char、float 等数据类型,其所声明的变量,只能存储一个数据,被称之为基本数据类型。
一个变量可以存储多个数据的,如数组、结构体,这种被称为构造数据类型,也叫作复杂数据类型。
结构体,是一种程序员可以自定义的数据类型,可以用来存储多个相同或者不同类型的数据。
2. 结构体的定义
和其他类型一样,结构体类型也是需要初始化定义的。但不同的是,在此之前结构体还需要进行自定义类型结构的。
定义结构的语法:
struct tag{
Member_list;
} Variable_list;
struct 是定义一个结构体的关键字,缺少这 struct 这一段是不成立的。
tag 是结构体标签,也就是这个结构的名称。
Member_list 是结构体中的成员,每个成员以数据类型和变量名的形式存在。其中,成员的类型可以是基本数据类型,也可以是数组,指针,结构体等等其他类型。
Variable_list 是结构体声明的变量列表,必须在花括号之后,分号之前。和 tag 两者之间可以只存在一个。没有 tag 的结构体被称为匿名结构体。
在结构体中,花括号不是执行代码块,因此后面必须要跟上分号,表示这是一个完整的语句。如果不加上分号,编译是不会通过的。
3. 结构体变量的定义
第一种,在定义结构体的同时,声明变量。
struct Student{
char name[10];
int age;
char gender[10];
} s1, s2;
定义了 Student 学生结构体类型,其中成员包含了 char 数组类型的姓名和性别以及 int 类型的年龄。末尾声明了两个变量,s1,s2。
第二种,是在定义结构体之后,再声明变量。
struct Student{
...
};
struct Student s1, s2;
定义后的变量声明,必须要带上 struct 关键字。因为 Student 只是一个标签名,带上 struct 才是一个完整的结构体类型。
可以理解 struct Student 等同于 int、char 这类的数据类型,声明变量时必须要写全。
匿名结构体则必须在定义结构体的时候就声明变量,否则定义的结构就没有意义了。
struct{
...
} s1, s2;
一般是不建议这种写法,因为匿名结构体只有在定义的时候才能声明变量,也就只能使用这一次。之后就无法重新声明新的变量,是一种较为浪费资源的做法。
4. 变量初始化
作为一个数据类型,变量可以在声明的时候进行初始化。
第一种,在定义结构时声明变量,并进行初始化。
struct Student{
...
} s1 = {"张三", 15, "男性"};
匿名结构体的初始化方式也是如此,区别在于匿名结构体是不带上 tag 结构标签名称。
第二种,在定义结构后,声明变量时初始化。
struct Student{
...
};
struct s1 = {"李四", 18, "男性"};
5. typedef类型定义关键字
总是要在声明变量的时候使用 struct,看着就很讨厌,有没有办法将这 struct 省略掉呢?
办法是有的,这里介绍 C 语言中的一个关键字,typedef,类型定义。
C语言允许程序员使用 typedef 关键字重新命名自己习惯使用的数据类型名称,从而代替系统提供的基本数据类型、构造类型等等。
相当于给数据类型取一个别名,就可以用这个别名当作数据类型来声明变量。
例如,将 int 数据类型取个别名 ZHENGSHU,那我声明变量的时候可以直接使用 ZHENGSHU 来当作变量声明的数据类型,而不用 int。
typedef int ZHENGSHU;
ZHENGSHU a = 1;
因此,我们就可以通过 typdef 给结构体类型取一个别名。
typedef struct Student{
...
} Sstudent;
需要注意的是,这里花括号后面所跟随的是别名,而不再是变量名。
定义的 Sstudent 类型等同于 struct Student,接下来我们就可以直接使用这个别名来声明变量,而不再多写一个 struct 关键字。
Sstudent s1;
同时,typedef 这关键字还解决了匿名结构体只能使用一次的问题。
typedef struct{...} Student;
Student s1;
Student s2;
6. 访问结构中的成员
声明完结构体变量,那么就要把这个变量拿来用,或者对变量中的某个数据进行修改。
C语言提供给结构体一个运算符,成员访问运算符(.),可以通过 变量名.成员名 来进行访问。
Sstudent s1 = {"张三", 19, "男性"};
printf("%s是一位%d岁的%s。", s1.name, s1.age, s1.gender);
运行结果:张三是一位19岁的男性。
10 年后,开办了一次同学聚会,发现张三竟然变成了一个女人了。
那么,就要对变量中的数据进行修改校正。
如果左边的成员是基本数据类型的变量,可以直接使用赋值运算符(=)进行修改。
但如果左边是个字符数组,这里就需要引入外部的头文件(string.h),应用其中的 strcpy 的方法。
#include<string.h>
s1.age = 29;
strcpy(s1.gender, "女性");
printf("%s是一位%d岁的%s。", s1.name, s1.age, s1.gender);
运行结果:张三是一位29岁的女性。
总结
以上就是关于C语言结构体的基本内容。包括了结构体的含义和作用、结构体的定义使用、结构体变量的定义方式、变量初始化方式、类型定义关键词 typedef 以及访问结构体中成员的方法。
相关推荐
- 一篇文章认识JavaScript中的Web API
-
在了解webapi之前先要明白在我们声明变量三个关键字(var、let、const),我们到底该用哪一个?首先排除var,它是老牌的写法,会有很多问题,可以淘汰掉...我们在开发中建议const...
- html5大神结合js带你研究古老读心术,你的心思早被猜透
-
javascript/HTML5课题:javascript开发读心术游戏PS:大爆料!javascript解密读心术游戏背后故事知识点:读心术原理算法独家揭秘,HTML5最新选择器,...
- 纯CSS实现3个圆圈横向排列不断闪烁的Loading特效
-
这个纯CSS实现的Loading特效是一个非常简单而实用的选择,它由三个圆圈横向排列,并不断闪烁。这种动画效果很适合用于页面加载过程中,为用户提供一个愉悦的等待体验。在这个特效的设计中,使用了CSS的...
- 网站建设知识分享系列文章三:符合用户体验的网页设计应如何做?
-
上篇文章向各位讲述了网站建设知识分享系列文章二:如何选择建站公司,今天我们来讲述下建站公司选定后,网站制作流程是怎样的,有哪些需要注意的细节性问题。选定建站公司,签订正规劳务合同后,最先开始的是设计环...
- 「更新」微信小程序 Lottie 动画组件 lottiejs-miniapp V1.1.0 发布
-
lottiejs-miniapp当前版本号:1.1.0npm地址:...
- Web开发基础之jQuery javascript web开发
-
jQuery是一个JavaScript库。jQuery极大地简化了JavaScript编程。jQuery的语法设计可以使开发更加便捷,例如操作文档对象、选择DOM元素、制作动画效果、事件处理、使用Aj...
- Web前端:JavaScript最强总结,最全面的零基础入门教程
-
JavaScript是网景(Netscape)公司开发的一种基于客户端浏览器、面向(基于)对象、事件驱动式的网页脚本语言。JavaScript语言的前身叫作Livescript。JavaScript...
- jQuery 动画制作与特效 jquery的动画函数
-
使用show()和hide()方法在普通的javascript编程中,要实现元素的显示、隐藏通常是利用其CSS的display属性或者visibility属性。在jQuery中提供了show()和hi...
- JavaScript+css实现的登录注册页面web前端html源码
-
大家好,今天给大家介绍一款,JavaScript+css实现的登录注册页面web前端html源码(图1),布局合理。送给大家哦,获取方式在本文末尾。文本框获取焦点动画特效(图2)源码完整,需要的朋友可...
- CSS 3.0+HTML5.0制作各种网页特效
-
?1、C33实现点击图片渐渐放大特效??2、CSS3实现图片全屏背景特效?3、CSS3实现的鼠标移动到图片上不规则放大??3、jQuery+CSS3模拟苹果桌面系统??4、CSS3+jQuery照片...
- js+css实现的按钮悬停动画特效html前端源码,随机元素弹出效果
-
大家好,今天给大家介绍一款,js+css实现的按钮悬停动画特效html页面前端源码,随机元素弹出(图1)。送给大家哦,获取方式在本文末尾。鼠标经过按钮区域的时候,会随机从不同位置上弹出很多小元素,效果...
- Swiper - 免费开源、功能强大的触摸滑动js特效插件
-
简单配置就能实现手机、PC网页中滑动、焦点轮播图、tab切换和触摸导航等大部分功能。js滑动特效插件Swiper是一款纯javascript打造的滑动特效插件,主要用对移动端web开发...
- html5精选特效代码分享(收藏) html酷炫特效
-
在网页设计过程中,我们会经常用到一些HTML5特效代码,下面就是为大家整理分享的一些好看炫酷且实用的HTML5特效代码,可以放心在您的应用程序中使用。一、Canvas跟随鼠标光标动画特效演示、下载地址...
- 玩转Markdown(2)——抽象语法树的提取与操纵
-
上一篇玩转Markdown——数据的分离存储与组件的原生渲染发布,转眼已经鸽了大半年了。最近在操纵mdast生成md文件的时候,心血来潮,把玩转Markdown(2)给补上了。...
- 任由文字肆意流淌,更自由的开源 Markdown 编辑器
-
对于创作平台来说内容编辑器是十分重要的功能,强大的编辑器可以让创作者专注于创作“笔”下生花。而最好取悦程序员创作者的方法之一就是支持Markdown写作,因为大多数程序员都是用Markdown...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- 一篇文章认识JavaScript中的Web API
- html5大神结合js带你研究古老读心术,你的心思早被猜透
- 纯CSS实现3个圆圈横向排列不断闪烁的Loading特效
- 网站建设知识分享系列文章三:符合用户体验的网页设计应如何做?
- 「更新」微信小程序 Lottie 动画组件 lottiejs-miniapp V1.1.0 发布
- Web开发基础之jQuery javascript web开发
- Web前端:JavaScript最强总结,最全面的零基础入门教程
- jQuery 动画制作与特效 jquery的动画函数
- JavaScript+css实现的登录注册页面web前端html源码
- CSS 3.0+HTML5.0制作各种网页特效
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)