结构体初阶

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
//struct B
//{
//	char c;
//	short s;
//	double d;
//};
//struct Stu
//{
//	//成员变量
//	struct B sb;
//	char name[20];//名字
//	int age;//年龄
//	char id[20];//学号
//	//结构的成员可以是标量,数组,指针,甚至是其他结构体
//};

//struct Stu
//{
//	//成员变量
//	char name[20];//名字
//	int age;//年龄
//	char id[20];//学号
//
//} s1,s2;//s1和s2也是结构体变量
s1,s2是全局变量

//结构体传参的时候,要传结构体的地址
//void print1(struct Stu t)
//{
//	printf("%c %d %lf %s %d %s\n", t.sb.c, t.sb.s, t.sb.d, t.name, t.age, t.id);
//}
//void print2(struct Stu* ps)
//{
//	printf("%c %d %lf %s %d %s\n", ps->sb.c, ps->sb.s, ps->sb.d, ps->name, ps->age, ps->id);
//}
//void print3(struct Stu* ps)
//{
//	printf("%c %d %lf %s %d %s\n", (*ps).sb.c, (*ps).sb.s, (*ps).sb.d, (*ps).name, (*ps).age, (*ps).id);
//}
//
//int main()
//{	//s是局部变量	
//	struct Stu s = { {'w',20,3.14},"何俊才",40,"20220507"};//对象//初始化
//	
//	//. -->
//	//printf("%c\n", s.sb.c);
//	//printf("%d\n", s.sb.s);
//	//printf("%lf\n", s.sb.d);
//	//printf("%d\n", s.age);
//	//printf("%s\n", s.id);
//	//printf("%s\n", s.name);
//
//	//struct Stu* ps = &s;
//	//printf("%c\n", (*ps).sb.c);
//	//printf("%c\n", ps->sb.c);
//
//	//写一个函数打印s的内容
//	print1(s);//w 20 3.140000 何俊才 40 20220507 传值调用 空间和时间都有浪费
//	print2(&s);//w 20 3.140000 何俊才 40 20220507 传址调用 传参效率高,只传了一个指针变量大小的空间
//	print3(&s);//w 20 3.140000 何俊才 40 20220507
//	return 0;
//}

//int Add(int x, int y)
//{
//	int z = 0;
//	z = x + y;
//	return z;
//}
每一个函数的调用都会在内存的栈区上开辟一块空间!
//int main()
//{
//	int a = 3;
//	int b = 5;
//	int c = 0;
//	c = Add(a, b);//大部分编译器函数传参是从右往左传的,先传b,再传a
//	//函数传参也叫压栈操作
//	return 0;
//}

 函数压栈图解

                                                                                                                                                                                                 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值