热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

结构体初识

目录结构体的基础知识结构体类型的声明类型一:类型二:二者区别结构体的初始化结构体成员访问结构体传参总结:结构体的基础知识结构是一些值的集合

目录

结构体的基础知识

结构体类型的声明

 类型一:

 类型二:

二者区别

结构体的初始化

结构体成员访问

结构体传参

总结:



结构体的基础知识

    结构是一些值的集合,这些值称为成员变量。结构的每个成员可以是不同类型的变量。

结构体类型的声明

 类型一:

struct    tag     -----struct为结构体关键字      -----tag为结构体结构体标签(是我们自己定的)

{

member-list;     -----------结构成员 

}s1,s2,s3;  -----------此处分号不可少   -----s1,s2,s3是定义的三个全局变量,此处可不定义

                      struct  tag-----结构体类型名称

eg:

struct student
{//成员变量char name[20];//一个字符串表示student的题目short age; //一个短整型表示student的题目char tele[12];//一字符串表示student的电话号char sex[5];//一个字符串表示student的性别
};

类型二:

typedf struct    tag    

{

member-list;

}va;

在struct前加一个typedf作用是将原来的结构体名称struct  tag 改为了va

二者区别


结构体的初始化

结构体的初始化有很多需要注意的地方,这里我们说明下
首先是几种初始化的方法

struct student
{//成员变量char name[20];short age; char tele[12];char sex[5];
};
int main()
{//方法一,按照成员声名的顺序初始化struct student s1 = { "张三",18,"12345678989","男" };//方法二,指定初始化,成员顺序可以不定struct student s2 = {.name = "张三",.age = 18,.tele = "12345678989",.sex = "男"};

typedef struct student
{//成员变量char name[20];short age; char tele[12];char sex[5];
}stu;
int main()
{//方法一,按照成员声名的顺序初始化stu s1 = { "张三",18,"12345678989","男" };//方法二,指定初始化,成员顺序可以不定stu s2 = {.name = "张三",.age = 18,.tele = "12345678989",.sex = "男"};

ps:在使用方法一在对结构体变量初始化时,要对结构体成员一一赋值,不能跳过前面成员变量,而直接给后面成员赋初值,但是可以只赋值前面几个,对与后面未赋值的变量,如果是数值型,则会自动赋值为0,对于字符型,会自动赋初值为NULL,即‘\0’  

结构体成员访问

.和->的使用

定义结构体指针,访问成员时就用->
定义结构体变量,访问成员时就用.

比如:

struct A q; 访问成员就用:q.a;
struct A *p; 访问成员就用:p->a;

结构体传参

案例分析:

用  .

typedef struct student
{//成员变量char name[20];short age; char tele[11];char sex[5];
}stu;
void Printf(stu tmp)
{printf("name:%s\n", tmp.name);printf("age:%d\n", tmp.age);printf("tele:%s\n", tmp.tele);printf("sex:%s\n", tmp.sex);
}
int main()
{
stu s1 = { "张三",18,"12345678989","男" };
Printf(s1)
}

用  ->

typedef struct student
{//成员变量char name[20];short age; char tele[11];char sex[5];
}stu;
void Printf(stu* tmp)
{printf("name:%s\n", tmp->name);printf("age:%d\n", tmp->age);printf("tele:%s\n", tmp->tele);printf("sex:%s\n", tmp->sex);}
int main()
{
stu s1 = { "张三",18,"12345678989","男" };
Printf(s1)
}

结果都是:

 分析这两种方法:方法二比较好

         函数传参的时候,参数是需要压栈的。如果传递一个结构体对象的时候,结构体过大,参数压栈所需的系统开销较大,从而导致性能的下降。


总结:

结构体传参时,要传结构体的地址。


推荐阅读
  • 本文介绍了为什么要使用多进程处理TCP服务端,多进程的好处包括可靠性高和处理大量数据时速度快。然而,多进程不能共享进程空间,因此有一些变量不能共享。文章还提供了使用多进程实现TCP服务端的代码,并对代码进行了详细注释。 ... [详细]
  • eclipse学习(第三章:ssh中的Hibernate)——11.Hibernate的缓存(2级缓存,get和load)
    本文介绍了eclipse学习中的第三章内容,主要讲解了ssh中的Hibernate的缓存,包括2级缓存和get方法、load方法的区别。文章还涉及了项目实践和相关知识点的讲解。 ... [详细]
  • c语言\n不换行,c语言printf不换行
    本文目录一览:1、C语言不换行输入2、c语言的 ... [详细]
  • 本文介绍了解决二叉树层序创建问题的方法。通过使用队列结构体和二叉树结构体,实现了入队和出队操作,并提供了判断队列是否为空的函数。详细介绍了解决该问题的步骤和流程。 ... [详细]
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文介绍了基于c语言的mcs51单片机定时器计数器的应用教程,包括定时器的设置和计数方法,以及中断函数的使用。同时介绍了定时器应用的举例,包括定时器中断函数的编写和频率值的计算方法。主函数中设置了T0模式和T1计数的初值,并开启了T0和T1的中断,最后启动了CPU中断。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • 本文介绍了一种划分和计数油田地块的方法。根据给定的条件,通过遍历和DFS算法,将符合条件的地块标记为不符合条件的地块,并进行计数。同时,还介绍了如何判断点是否在给定范围内的方法。 ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • 本文介绍了汉诺塔问题的迭代算法实现,通过递归的方式将盘子从一个地方搬到另一个地方,并打印出移动的顺序。详细介绍了算法的思路和步骤,以及示例代码的运行结果。 ... [详细]
  • 猜字母游戏
    猜字母游戏猜字母游戏——设计数据结构猜字母游戏——设计程序结构猜字母游戏——实现字母生成方法猜字母游戏——实现字母检测方法猜字母游戏——实现主方法1猜字母游戏——设计数据结构1.1 ... [详细]
author-avatar
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有