C语言结构体定义的方法汇总
什么是结构体?
在C语言中,结构体(struct)指的是一种数据结构,是C语言中聚合数据类型(aggregate data type)的一类。结构体可以被声明为变量、指针或数组等,用以实现较复杂的数据结构。结构体同时也是一些元素的集合,这些元素称为结构体的成员(member),且这些成员可以为不同的类型,成员一般用名字访问。
结构体与数组的比较
(1) 都由多个元素组成
(2) 各个元素在内存中的存储空间是连续的
(3) 数组中各个元素的数据类型相同,而结构体中的各个元素的数据类型可以不相同
结构体的定义:
C语言结构体类型的定义模板大概为:
struct 类型名{ 成员表列 } 变量;
在成员表列中可以是几种基本数据类型,也可以是结构体类型。
struct 类型名{} 变量;后的分号不能漏
下面给出定义结构体类型的几种方法
1. 先定义结构体类型,再定义结构体变量。
struct student{ char no[20]; //学号 char name[20]; //姓名 char sex[5]; //性别 int age; //年龄 }; struct student stu1,stu2; //此时stu1,stu2为student结构体变量
2. 定义结构体类型的同时定义结构体变量。
struct student{ char no[20]; //学号 char name[20]; //姓名 char sex[5]; //性别 int age; //年龄 } stu1,stu2;
此时还可以继续定义student结构体变量如:
struct student stu3;
3.直接定义结构体变量。
struct{ char no[20]; //学号 char name[20]; //姓名 char sex[5]; //性别 int age; //年龄 } stu1,stu2;
一般不会使用第三种定义方法,因为直接定义结构体变量stu1,stu2后就不能再继续定义该类型的变量。
注意:
在C语言中使用struct定义结构体类型后定义结构体变量时struct不能省略,在C++中允许省略struct。
在c中:
struct student{ ... }; struct student stu1; //struct不可省略
在c++中:
struct student{ ... }; student stu1; //struct可省略
在C中定义结构体类型后每次定义变量时都要使用struct,如果嫌麻烦,我们可以这样:
typedef struct student{ ... }STUDENT; STUDENT stu1;
使用typedef给struct student取一个"别名"STUDENT
在某些情况下还可以使用#define来实现更简化的结构体定义与变量的定义,但可能会牺牲部分可读性。
#define STUDENT struct student; STUDENT{ ... }; STUDENT stu1;
typedef和#define用法不同,甚至可以结合起来灵活使用,使用时一定要注意两者的不同之处。
总结
以上所述是小编给大家介绍的C语言结构体定义的方法汇总,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!
相关推荐
-
c语言实现基数排序解析及代码示例
1. 基数排序(radixsort)属于"分配式排序"(distributionsort),又称"桶子法"(bucketsort)或binsort,顾名思义,它是透过键值的部份资讯,将要排序的元素分配至某些"桶"中,藉以达到排序的作用. 2.基数排序的实现方法分为两种: 最高位优先(MostSignificantDigitfirst)法,简称MSD法:先按k1排序分组,同一组中记录,关键码k1相等,再对各组按k2排序分成子组,之后,对后面的关键码
-
利用C语言实现“百马百担”问题方法示例
前言 百马百担问题,有100匹马,驮100担货,大马驮3担,中马驮2担,两匹小马驮1担,问共有多少种驮法?且各种驮法中大.中.小马各多少匹? [分析] 1.定义整型变量m.n.k分别存放大马匹数.中马匹数.小马匹数: 2.定义整型变量sum存放共有几种驮法,且sum赋初值为0: 3.根据题意,大马.中马.小马共100匹:大马.中马.小马驮100担货满足如下关系: m+n+k=100(匹) 3*m+2*n+1/2*k=100(担) 4.三个未知数,两个方程,此题有若干组解: 5.计算机求解此类问题
-
C语言中输入函数(scanf()、fgets()和gets())的区别详解
前言 大家都知道在C语言中,有三种主要的输入函数:scanf(),fgets()以及gets().他们的使用方法及注意事项如下: 1.scanf() 它是一种格式化的输入方式,可一次性按照规定的格式输入多个数据域. scanf函数是一个标准库函数,它的函数原型在头文件"stdio.h"中.与printf函数相同,C语言也允许在使用scanf函数之前不必包含stdio.h文件. scanf函数的一般形式为: scanf("格式控制字符串", 地址表列); 其中,格式控
-
c语言通过opencv实现轮廓处理与切割
注意在寻找轮廓时要选择中寻找外层轮廓 RETR_EXTERNAL #include "opencv/cv.h" #include "opencv/highgui.h" using namespace std; using namespace cv; int main() { Mat srcimg=imread("./22.jpg"); Mat dst; cvtColor(srcimg,dst,CV_BGR2GRAY); threshold(dst
-
C语言创建动态dll和调用dll(visual studio 2013环境下)
第一部分:创建动态dll库. 1.打开visual studio 创建一个控制台应用程序. 2.选择DLL,空项目. 3.点击源文件,创建一个main.c文件 4.在main.c中写入一个简单的函数,内容如下: __declspec(dllexport) int mymax(int a,int b){ return a + b; } 5.编译生成. 6.在项目的目录有dll和lib两个生成好的文件. 第二部分:在新建项目中使用dll. 7.新建一个c的控制台应用程序UseDll,把Dll.dll
-
利用C语言玩转魔方阵实例教程
魔方阵 魔方阵,古代又称"纵横图",是指组成元素为自然数1.2-n的平方的n×n的方阵,其中每个元素值都不相等,且每行.每列以及主.副对角线上各n个元素之和都相等. 如3×3的魔方阵: 8 1 6 3 5 7 4 9 2 魔方阵的排列规律如下: (1)将1放在第一行中间一列: (2)从2开始直到n×n止各数依次按下列规则存放:每一个数存放的行比前一个数的行数减1,列数加1(例如上面的三阶魔方阵,5在4的上一行后一列): (3)如果上一个数的行数为1,则下一个数的行数为n(指最下一行);
-
C语言实现二叉树的基本操作
二叉树是一种非常重要的数据结构.本文总结了二叉树的常见操作:二叉树的构建,查找,删除,二叉树的遍历(包括前序遍历.中序遍历.后序遍历.层次遍历),二叉搜索树的构造等. 1. 二叉树的构建 二叉树的基本构建方式为:添加一个节点,如果这是一棵空树,则将该节点作为根节点:否则按照从左到右.先左子树后右子树的顺序逐个添加节点.比如依次添加节点:1,6,10,2,7,11,则得到的二叉树为: 在这里,我们需要借助一个链表来保存节点,以实现二叉树的顺序插入,具体做法如下: 1.0 初始化一个用来保存二叉树节
-
C语言数据结构之学生信息管理系统课程设计
本文实例为大家分享了学生信息管理系统设计的具体代码,供大家参考,具体内容如下 建立一个动态链表,链表中每一结点包括:学号.姓名.性别.年龄.成绩.程序能实现以下功能: 建立链表 显示链表 查找链表中是否存在某个元素,并显示这个元素的所有信息,若没有这个元素则显示"无此记录!"的信息. 删除链表中指定学号的结点. 在链表中指定的位置插入一个新结点(学号不能和其他结点重复). 要求:程序运行中,先显示实现以上功能所构成的菜单,然后根据选项调用相应程序
-
C语言结构体定义的方法汇总
什么是结构体? 在C语言中,结构体(struct)指的是一种数据结构,是C语言中聚合数据类型(aggregate data type)的一类.结构体可以被声明为变量.指针或数组等,用以实现较复杂的数据结构.结构体同时也是一些元素的集合,这些元素称为结构体的成员(member),且这些成员可以为不同的类型,成员一般用名字访问. 结构体与数组的比较 (1) 都由多个元素组成 (2) 各个元素在内存中的存储空间是连续的 (3) 数组中各个元素的数据类型相同,而结构体中的各个元素的数据类型可以不相同 结
-
Go语言结构体定义和使用方法
本文实例讲述了Go语言结构体定义和使用方法.分享给大家供大家参考.具体分析如下: 一个结构体(struct)就是一个字段的集合. (而 type 定义跟其字面意思相符.) 复制代码 代码如下: package main import "fmt" type Vertex struct { X int Y int } func main() { fmt.Println(Vertex{1, 2}) } 结构体字段使用点号来访问. 复制代码 代码如下: package
-
C 语言结构体的使用方法
目录 C 语言结构体使用 1. 结构体的声明和定义 1.1 介绍 1.2定义的几种类型 2. 结构体初始化 3. 结构体成员访问 3.1 成员介绍 4. 结构体传参 C 语言结构体使用 1. 结构体的声明和定义 1.1 介绍 我们知道数组是同种类型值的集合,而结构就是可以将不同类型的值放在一起. 结构是一些值的集合,这些值称为成员变量.结构的每个成员可以是不同类型的变量. 结构的成员可以是标量.数组.指针,甚至是其他结构体. 如我们可以将一个学生的一些属性放在一起 struct stu//定义一
-
C语言结构体(struct)的详细讲解
目录 引言 1. 动态内存管理 2. 结构体 2.1 定义语法 2.2 定义示例 2.3 初始化 2.4 结构体赋值 2.5 结构体数组 2.6 结构体指针赋值 3. 学生管理系统 附:结构体变量的存储原理 总结 引言 当前文章介绍动态堆空间内存分配与释放,C语言结构体定义.初始化.赋值.结构体数组.结构体指针的相关知识点,最后通过一个学生管理系统综合练习结构体数组的使用. 1. 动态内存管理 C语言代码----->编译----->链接------>可执行的二进制文件(windows下x
-
C语言结构体(struct)常见使用方法(细节问题)
基本定义:结构体,通俗讲就像是打包封装,把一些有共同特征(比如同属于某一类事物的属性,往往是某种业务相关属性的聚合)的变量封装在内部,通过一定方法访问修改内部变量. 结构体定义: 第一种:只有结构体定义 struct stuff{ char job[20]; int age; float height; }; 第二种:附加该结构体类型的"结构体变量"的初始化的结构体定义 //直接带变量名Huqinwei struct stuff{ char job[20]; int age; floa
-
c语言结构体字节对齐的实现方法
目录 1.什么是字节对齐 2.为什么要有字节对齐 3.手动设置对齐 4.结构体比较方法 1.什么是字节对齐 在c语言的结构体里面一般会按照某种规则去进行字节对齐. 我们先看一段代码: struct st1 { char name; double age; char sex; }; //32位下 sizeof(struct st1) = 16 //64位下 sizeof(struct st1) = 24 struct st2 { char a; char b; char c; }; //32位和6
-
C语言结构体数组的定义和使用详解
目录 介绍 结构体数组定义时初始化 补充 介绍 一个结构体变量可以存放一个学生的一组信息,可是如果有 10 个学生呢?难道要定义 10 个结构体变量吗?难道上面的程序要复制和粘贴 10 次吗? 很明显不可能,这时就要使用数组.结构体中也有数组,称为结构体数组.它与前面讲的数值型数组几乎是一模一样的,只不过需要注意的是,结构体数组的每一个元素都是一个结构体类型的变量,都包含结构体中所有的成员项. 定义结构体数组的方法很简单,同定义结构体变量是一样的,只不过将变量改成数组.或者说同前面介绍的普通数组
-
C语言结构体数组常用的三种赋值方法(包含字符串)
目录 一.按照成员变量进行赋值(麻烦,好理解,字符串赋值需要strcpy) 二.对数组整体进行赋值.(一次性需要把所有的都添加进去,不需要strcpy) (1) 在声明数组的时候,进行赋值 (2)对有规律的数据赋值,比如学生结构体的学号是有规律的. 三.使用输入进行赋值 总结 一.按照成员变量进行赋值(麻烦,好理解,字符串赋值需要strcpy) 这里使用了一个Init函数,为了在进一步说明传参的使用.实际上赋值按照需要放在主函数就行. (使用strcpy函数需要添加头文件string.h) #i
-
C语言结构体的具体使用方法
目录 初识C语言结构体 1.为什么要有结构体 2.结构体的定义 2.1结构体类型的定义 2.2定义结构体普通变量及访问 2.3定义结构体指针变量及访问 初识C语言结构体 1.为什么要有结构体 (1)之前int.char等类型描述的结构体非常单一,只可描述一种类型. (2)数组也是描述同一类型的集合,只可描述一种类型. (3)而结构体使得C语言可以描述复杂类型,比如学生类型( 包含学生的名字.年龄.性别.电话号等信息). 结构体和数组的区别: ·结构体:用来描述相同/不同数据元素类型的集合. ·数
-
C语言结构体的一些理解
前言 最忙碌的一周已然结束,疲惫之余想和大家聊一聊对C语言中结构体的认识.水平不足,如有问题请大家指正. 一.对结构体的理解 我们知道C语言中有基本数据类型: 1.整(数)型: int:基本整型,用于存储整数,占4个字节,默认值为0 short:短整型,占2个字节 long:长整型,占4个字节 long long:双长整型,占8个字节,比较少用 2.浮点型 float:单精度浮点型,占4个字节 double:双精度浮点型,占8个字节 3.字符型 char:字符型,用于存储单字符,占1个字节. (
随机推荐
- Nginx的使用经验小结
- 让Json更懂中文(JSON_UNESCAPED_UNICODE)
- tomcat共享多个web应用会话的实现方法
- Basic求10000以内的完美数
- flex实现DataGrid高亮显示数据功能的解决方案
- VB.NET 中删除DataGridView中所选行的小例子
- PHP 远程文件管理,可以给表格排序,遍历目录,时间排序
- php实现zip文件解压操作
- javascript比较两个日期相差天数的方法
- 抛弃Nginx使用nodejs做反向代理服务器
- 详解php中反射的应用
- 纯JavaScript实现HTML5 Canvas六种特效滤镜示例
- js+csss实现的一个带复选框的下拉框
- JS命令模式例子之菜单程序
- ubuntu16.04下安装openssh-server报依赖错误的完美解决方法(非常不错)
- 知己知彼 Windows系统目录功能
- 个性化blog的方法集锦
- 基于Mybaits映射的一点心得(分享)
- vue 项目常用加载器及配置详解
- nodejs简单读写excel内容的方法示例