结构体的定义:结构体是一些值的集合,这些值称为成员变量,结构体的每个成员可以是不同类型的变量。
举例:
//定义结构体类型
struct tag//struct结构体关键字 tag结构体标签 struct tag结构体类型
{
//成员变量
char name[20];
short age;
char telphone[12];
char sex[5];
}s1,s2,s3;//s1,s2,s3是三个全局结构体变量
int main()
{
struct tag s;//s是局部变量
return 0;
}
小tips:结构体类型是不占内存空间的,-相当于int在C语言中也是不占内存的,而int a(定义a变量后就会占据内存)
使用typedef定义一个单独的变量,因为我们在编写代码的过程中,重复的书写struct会感觉很繁琐,这样定义之后就可以直接使用改变量作为结构体类型。
举例:
typedef struct tag//定义tag为结构体别名,tag等价于struct tag
{
char name[20];
short age;
char telphone[12];
char sex[5];
}tag;//tag指的是类型,而不是变量
int main()
{
struct tag s1;
tag s2;//struct tag==tag,因此tag可以直接使用
return 0;
}
结构体成员的类型可以是标量,数组,指针。其他结构体。
#include <stdio.h>
typedef struct tag
{
//结构体成员类型的定义
char name[20];
short age;
char telphone[12];
char sex[5];
}tag;
int main()
{
tag s1={"张三",20,"15372842487"};//结构体变量的初始化
printf("%s的年龄是%d,手机号码为%s\n", s1.name, s1.age, s1.telphone);//输出有关该成员的信息,通过结构体变量找对应的成员变量
struct tag s2={"lisa",19,"8725111"};
printf("%s的年龄是%d,手机号码为%s", s2.name, s2.age, s2.telphone);
return 0;
}
结
结构体变量访问成员:结构体变量的成员是通过点操作符(.)访问的,点操作符接受两个操作数。
例如:
struct stu
{
char name[20];
int age;
}s1={"张三",19};
int main()
{
printf("%s的年龄是%d", s1.name, s1.age);//s1.name和s1.age就是 通过点操作符访问结构体成员
}
张三的年龄是19
结构体传参数的时候,要传结构体的地址,其原因是函数传参的时候,参数是需要压栈的,如果传递一个结构体对象的时候,结构体过大,参数压栈的系统开销比较大,因此会导致性能下降。
举例:
typedef struct stu
{
char name[20];
int age;
}stu;
void print1(stu tmp)//传递结构体的值
{
printf("name:%s\n", tmp.name);
printf("age:%d\n", tmp.age);
}
void print2(stu* ps)//传递结构体的地址,开辟的空间为一个指针的大小(4/8个字节)
{
printf("name:%s\n", ps->name);
printf("age:%d\n", ps->age);
}
int main()
{
stu s = { "张三",19 };
print1(s);
print2(&s);
return 0;
}
name:张三
age:19
name:张三
age:19
这里插播一点数据结构的知识:数据结构分为线性数据结构(顺序表,链表,栈,队列)和树形数据结构(二叉树,图)。
顺序表:按照一定的顺序将元素储存起来。
举例:
链表:用一条线将元素连接起来,不要求元素都在同一条线上。
举例:
栈:元素先进后出,后进先出,元素的出入方式类似于手电筒中的电池一样,向一个不含任何元素的栈中放入一个元素的过程叫压栈,删除栈中的一个元素的过程,叫出栈,栈中元素的删除也是由栈顶乡下进行删除,因此如果想删除栈中元素,不能直接删除,必须将在该元素后面放入的元素都进行删除。
举例:
实例分析:
int add(int x, int y)
{
int z = 0;
z = x + y;
return z;
}
int main()
{
int a = 10;
int b = 20;
int ret = 0;
ret = add(a, b);
printf("%d\n",ret);
return 0;
}
30
函数在调用的时候,实参的传递顺序是从右到左,将a,b放入x,y的过程叫压栈。