__c语言__结构体、共用体、枚举__笔记
2017-09-16 21:14:09
结构体,共用体,枚举
1.结构体
把不同的类型整合成一个有机的整体,以便于引用,这个类型就叫做结构体
1)结构体变量的定义方式(3种)和引用成员变量;
定义一个结构体的一般形式为
struct 结构体名
{
成员表列(成员类型 成员名);
};
!!!成员名可以和变量名重名!!!
可以采取三种方式定义结构体类型变量
a.先声明结构体类型再定义变量名
struct student
{
int num;
char name[20];
float score;
char address[30];
};
struct student stu1,stu2;
***************************************************
b.在声明类型的同时定义变量
一般形式为:
struct 结构体名
{
成员表列;
}变量名;
struct student
{
int num;
char name[20];
float score;
char address[30];
}stu1,stu2;
struct student stu3;
***************************************************
c.直接定义结构体类型变量
一般形式为:
struct
{
成员表列;
}变量名表列;
struct
{
int num;
char name[20];
float score;
char address[30];
}stu1,stu2;
struct stu3; 错误
"." 引用成员变量
***************************************************
2)结构体成员的内存布局问题及字节对其问题;
a.结构体的数据成员,第一个数据保存在offset为0的地方,以后每个数据成员存储的起始地址要从
该成员大小的整数倍或者是4的整数倍开始(取两者中的最小值);
b.如果一个结构体里面有某些结构体成员,则结构体成员要从其内部最大元素大小的整数倍开始
或者是4的整数倍开始(取两者中的最小值);
c.结构体总大小,必须是内部最大成员的整数倍或者是4的整数倍(取两者中的最小值);
3)柔性数组与指向结构体类型的指针
#include<stdio.h>
#include<stdlib.h>
int main(int argc,char *argv[])
{
struct soft_array
{
int len;
int array[];//占座位
}; /*
struct student stu1;
stu1.len = 10;
stu1.array[0] = 'a'; struct student *p = &stu1; printf("%d\t%c\n",(*p).len,(*p).array[0]);
printf("%d\t%c\n",p->len,p->array[0]);
//printf("%d\n",stu1->len); 错误
//
*/
int n;
scanf("%d",&n);//单元个数
struct soft_array *p = (struct soft_array *)malloc(sizeof(int)*n);
if(p == NULL)
{
perror("malloc error");
return -;
}
p->len = n; int i;
for(i = ;i < n -;i++)//len 已经占用了一个int,所以array占用的int个数为n-1
{
p->array[i] = +i;
printf("%d\t",p->array[i]);
}
return ;
}
->(指向运算符) 只能是指针使用
4)结构体数组
struct student
{
int num;
char name[20];
float score;
char address[30];
}struct student stu[10];
5)结构体做函数参数
#include<stdio.h> struct student
{
int num;
char name[];
float score;
char address[];
}; void func(struct student *a)
{
printf("%d %s\n",a[].num,a[].name);
} int main(int argc,char *argv[])
{
struct student stu1[] = {,"xiaoming",,"BeiJing"};
func(stu1);
return ;
}
------------------------------------------------------------------------
2.共用体
所有成员共用同一段内存空间,空间有多大,视其中最大成员而定,
他们的首地址都相同!!!
定义共用体的方式和结构体前两种方式一样!!!
union 共用体名
{
成员表列;
};
大端模式(Big-endian),是指数据的高字节,保存在内存的低地址中,
而数据的低字节,保存在内存的高地址中,这样的存储模式有点儿类似于把数据当作字符串顺序处理:
地址由小向大增加,而数据从高位往低位放;
小端模式(Little-endian),是指数据的高字节保存在内存的高地址中,
而数据的低字节保存在内存的低地址中,这种存储模式将地址的高低和数据位权有效地结合起来,
高地址部分权值高,低地址部分权值低,和我们的逻辑方法一致。
判断是小端模式还是大端模式:
#include<stdio.h>
int main(int argc,char *argv[])
{
union test
{
int a;
char b;
}; union test t;
t.a = 0x12345678;
//printf("%p %p",&t.a,&t.b);
printf("%x\n",t.b);
return ;
}
------------------------------------------------------------------------
3.枚举
enum 枚举名 {成员}
枚举类型在内存中间占据4字节的unsigned int !!!
#include<stdio.h>
int main(int argc,char *argv[])
{
enum day {Monday=,Friday=, Sunday};
enum day Tuesday = ; //要求赋值是给到的枚举出来的类型
printf("%d %d %d %d\n",Monday,Tuesday ,Friday,Sunday); return ;
}
__c语言__结构体、共用体、枚举__笔记的更多相关文章
- C语言高级-结构,共用体,文件,链表
C语言结构 标准声明方式 struct student{ int age; char sex; }; 这个可以在main函数中定义: struct student ...
- 5、数组&字符串&结构体&共用体&枚举
程序中内存从哪里来 三种内存来源:栈(stack).堆(heap).数据区(.date): 栈(stack) 运行自动分配.自动回收,不需要程序员手工干预: 栈内存可以反复使用: 栈反复使用后,程序不 ...
- C++结构、共用体、枚举
一.结构 结构是C++OOP的基石.学习有关结构的知识僵尸我们离C++的核心OOP更近. 结构是用户定义的类型,同一个结构可以存储多种类型数据,这使得将一个事物的不同属性构成一个对象成为了可能.另外C ...
- C语言-10-位域与共用体
位域 在某种特定情况下,一个结构体中的多个变量只使用各自存储空间的几位,而其他位从来不使用.这种情况下,可以使用位域来限定每个变量的用来存储数据的位宽. 作用 限定结构体中变量用来存放数据的位宽,即使 ...
- 瘋子C语言笔记(结构体/共用体/枚举篇)
(一)结构体类型 1.简介: 例: struct date { int month; int day; int year; }; struct student { int num; char name ...
- C语言基础 (11) 结构体 ,共用体 枚举 typedef
1 课堂回顾 作用域与生命周期 2 static 局部变量 2 打字游戏 3 内存分区代码分析 4 结构体基本操作 (复合类型[自定义类型 #include <stdio.h> #incl ...
- C++复合类型(结构,共用体,枚举)
•结构是用户定义的类型,而结构的声明定义了这种类型的数据属性. 一.关键字struct声明: 定义了一种新类型 struct inflatable{ char name[20];//结构成员 fl ...
- C语言中结构、联合、枚举的说明
复杂的数据类型 一般的步骤: 1.声明模板 2.定义变量,分配内存空间 3.初始化 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...
- 不可或缺 Windows Native (8) - C 语言: 结构体,共用体,枚举,类型定义符
[源码下载] 不可或缺 Windows Native (8) - C 语言: 结构体,共用体,枚举,类型定义符 作者:webabcd 介绍不可或缺 Windows Native 之 C 语言 结构体 ...
- C语言------结构体和共用体
仅供借鉴.仅供借鉴.仅供借鉴(整理了一下大一C语言每个章节的练习题.没得题目.只有程序了) 文章目录 1 .实训名称 2 .实训目的及要求 3.源代码及运行截图 4 .小结 1 .实训名称 实训8:结 ...
随机推荐
- 【转】ArcGIS10的附件功能
转自:http://blog.csdn.net/linghe301/article/details/6386176 老是忘记怎么使用这个ArcGIS10的附件功能,这次就做个记录吧. 在项目应用过程中 ...
- md5爆破工具
http://www.myhack58.com/Article/html/3/8/2015/65021.htm http://xlixli.net/?p=410 http://blog.csdn.ne ...
- tomcat配置介绍
第一节java的介绍 java需要一个java的运行环境 JDK:包含了好几个java组件,包含类库(API) 开发工具(java) jvm(java虚拟机)JRE(类库) tomcat:开源 企业 ...
- Codechef CHSIGN Change the Signs(May Challenge 2018) 动态规划
原文链接http://www.cnblogs.com/zhouzhendong/p/9004583.html 题目传送门 - Codechef CHSIGN 题意 第一行,一个数$T$,表示数据组数. ...
- ELK安装(windows)
一.安装JAVA环境 在Oracle官网获取最新版的Java版本,官网:http://www.oracle.com/ 安装完成后,配置JAVA_HOME和JRE_HOME. 二.下载安装ELK htt ...
- 最短路径(给定一个包含非负整数的 m x n 网格,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。 说明:每次只能向下或者向右移动一步。)
给定一个包含非负整数的 m x n 网格,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小. 说明:每次只能向下或者向右移动一步. 例: 输入: [ [1,3,1], [1,5,1], [ ...
- Editor HDU - 4699 (栈)
Problem Description Sample Input 8 I 2 I -1 I 1 Q 3 L D R Q 2 Sample Output 2 3 Hint The followi ...
- hexo添加404公益界面
http://hellolb.top/2018/08/16/hexo添加404公益界面/ hexo个人博客添加404公益界面,这里我使用的腾讯404公益界面 我的博客主题是hexo+yilia,其实所 ...
- poj 3067 Japan 【树状数组】
<题目链接> 题目大意: 有两个点集,这两个点集从上至下分别从1~n,1~m编号,现在给出n组数据,(x,y),表示左边点集编号为x的点与右边点集编号为y的点相连,现在要求计算这些线段的交 ...
- SpringMVC(二四) 视图解析流程
目标方法无论返回的是string.ModelAndView.View,最终都被解析成modelAndView 关键的实现代码是在springmvc.xml配置文件中定义解析器. 参考代码如下: < ...