博客
关于我
C语言:结构体——《手把手将你学C语言》
阅读量:248 次
发布时间:2019-03-01

本文共 2064 字,大约阅读时间需要 6 分钟。

C语言结构体

概论

结构体就是集成了若干不同组分的可自定义的数据类型。算是面向对象编程中类和对象的前身。例如一个学生机构体,可以包含一个学生的姓名,年龄,性别,学号,班级等信息。

结构体的定义和使用

结构体的声明

struct 机构体名{   成员列表};

最后的分号一定不要忘记加。

struct只是一个关键字,表明这是一个结构体,而结构体名才是真正的数据类型名,而且结构体名一般大写。

struct STUDENT{   	int age;	int grade;	char name[20];	char addr[30];};

上述代码中的STUDENT才是和int等价的东西。不过也就是说,上述代码仅仅是定义了一个结构体类型而已,还不能直接使用。

结构体类型变量

只有定义了结构体类型变量后,也就是相当于类有了实现对象后,才能发挥出功效。

struct STUDENT{   	int age;	int grade;	char name[20];	char addr[30];}stud;

stud才是具有内存空间的实际变量,而变量的对内部项的引用,有以下三种方式。

结构体对数据的引用

#include
#include
struct STUDENT{ int age; int grade; char name[20]; char addr[30];};int main(void){ struct STUDENT s1={ 12,100,"小明","北京"}; strcat(s1.name,"小刚"); s1.age=18; printf("%d\n",s1.age); printf("%s",s1.name); return 0;}

对于指针对结构体进行操作,指针指向就是结构体首元素的地址,但是要注意的是,虽然二者在内存是同一块内存,但是数据类型很可能不一致,一个是机构体型指针,另一个则是自己类型的指针,在使用区分使用。

结构体的初始化
对于结构体变量的初始化,最好在定义时就进行全部的赋值,否则未赋值数据只能在后续通过引用的方式一个个赋值。

结构体的字节对齐

对于结构体内数据的内存分配上,不会采取一个个对应分配累加的方式,而会采用一种看齐最高内存存储方式的形式。比如下列代码。

struct STUDENT{   	char a1;	char a2;	int b;	};

char a1和char a2的内存大小不分别是1,因为这个结构体中最大内存需要的是int的4个字节,所以第一个a1也是四个字节,而a2则跟在a1的四个字节中,也就是连个char共用四个字节。

但是顺序上必须是连续的,否则就实现不了共享。例如下面。

struct STUDENT{   	char a1;	int b;	char a2;	};

这样的话,总内存就是12个字节了。

所以我们在设计结构体时候要遵循一定的大小顺序去安排数据变量。

结构体数组

定义:struct STUDENT stu[10];

这个就以为着创立了一个十个机构体变量的数组。
同理对于机构体数组的初始化和使用和基本数组,结构体完全类似。

结构体指针

同样地,我们也可以使用指针的方式引用结构体的数据。

#include
#include
struct STUDENT{ int age; int grade; char name[20]; char addr[30];};int main(void){ struct STUDENT s1={ 12,100,"小明","北京"}; struct STUDENT *p=&s1; strcat((*p).name,"小刚"); (*p).age=18; printf("%d\n",(*p).age); printf("%s",(*p).name); return 0;}

而且*p的()是不可以省略的,因为.符号的运算优先度最高,所以省略括号就变成了*(p.name)

初此之外,我们还有一种更直观,更简洁,也是更加常用的表达形式。

p->name;

#include
#include
struct STUDENT{ int age; int grade; char name[20]; char addr[30];};int main(void){ struct STUDENT s1={ 12,100,"小明","北京"}; struct STUDENT *p=&s1; strcat(p->name,"小刚"); p->age=18; printf("%d\n",p->age); printf("%s",p->name); return 0;}

转载地址:http://lvux.baihongyu.com/

你可能感兴趣的文章
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>
mysql一个字段为空时使用另一个字段排序
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>
Mysql下载以及安装(新手入门,超详细)
查看>>
MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
查看>>
MySQL不同字符集及排序规则详解:业务场景下的最佳选
查看>>
Mysql不同官方版本对比
查看>>
MySQL与Informix数据库中的同义表创建:深入解析与比较
查看>>
mysql与mem_细说 MySQL 之 MEM_ROOT
查看>>
MySQL与Oracle的数据迁移注意事项,另附转换工具链接
查看>>
mysql丢失更新问题
查看>>
MySQL两千万数据优化&迁移
查看>>
MySql中 delimiter 详解
查看>>
MYSQL中 find_in_set() 函数用法详解
查看>>
MySQL中auto_increment有什么作用?(IT枫斗者)
查看>>