百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

从零开始学习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...

取消回复欢迎 发表评论: