C++中struct的用法
来源:互联网 发布:德怀特霍华德生涯数据 编辑:程序博客网 时间:2024/06/07 04:44
1 struct概述
C++的内置简单数据类型,如int、float等只能存储一种类型的数据。但现实世界更为复杂,几乎任何我们能够想到的物理对象,即使是进行最低限度的描述,也都需要好几项数据才行。
可以使用关键字struct定义一种复杂的数据类型来包含多种信息,这就是结构。
2 struct语法
结构sturct中定义元素的每一行都以分号结束,右大括号后面也有一个分号。
3 struct初始化
将数据存入结构成员的方法,是在声明语句中为结构成员定义初始值。这些初始值位于大括号内,互相之间以逗号分开,初始值的顺序显然必须与结构定义中成员的顺序相同。
4 struct成员的访问
为了访问结构的各个成员,可以使用成员选择操作符“.”。要引用某个具体成员,必须写出结构变量名,后面是“.”和希望访问的成员名。
5 struct例子
在CSDN论坛上有帖子问到
struct A {int a;float b;};struct B {int b;float a;};struct C {A a; B b;}; int main(){C c1 = { 1,2,3,4 };C c2 = { 5,6,7,8 };c1.b.a + c2.a.b; return 0;}
c1.b.a + c2.a.b的值是多少,在“3 struct初始化”中提到,struct结构的初始值顺序与结构定义中成员的顺序相同,因此在c1对应的内存结构如图1所示
图1 c1的内存值
红框内的数据时c1的数据,两个绿框内的数据分别对应的是c1.a和c1.b;用黄色分割的数据分别是c1.a.a、c1.a.b、c1.b.b和c1.b.a,即c1.b.a的值是0x00008040,由于它的类型是float,所以转换的值是4.00000000;
c2对应的内存结构如图2所示
图2 c2的内存值
同理, 红框内是c2的数据,c2.a.b的值是0x0000c040,转换后的值是6.00000000。
所以,c1.b.a + c2.a.b的值是float类型,为10.00000000
阅读全文
0 0
- C/C++中typedef struct和struct的用法
- C/C++中typedef struct和struct的用法
- C/C++中typedef struct和struct的用法
- C中结构体struct的用法
- C++--struct的用法
- C#-Struct简单的用法
- typedef struct 在C和C++中用法的区别
- C/C++中typedef struct和struct的用法[转。不知出自何处]
- struct 中 typedef的用法
- C++中struct的用法
- C语言中struct用法笔记
- C语言struct中冒号用法
- C语言struct中冒号用法
- C++中typedef struct和struct的用法
- c语言struct用法
- python中struct.unpack的用法
- python中struct.unpack的用法
- python中struct.unpack的用法
- 1_ case表达式 和限制行数,随机返回行数
- 拷贝构造函数
- hibernate实体类映射不到的问题
- idea中快捷main方法
- wordpress网站迁移
- C++中struct的用法
- 神经网络设计_学习规则总结
- window 下上传项目到git 和插件上传
- 手把手教你用Strace诊断问题
- hadoop环境变量配置及启动
- stanford Protege 4.3 ERROR: Bundle org.protege.common 解决方法
- equals变量在前面和后面的区别
- 如何查看MySQL的当前存储引擎?
- CDH5 部署步骤