嵌入式学习第十四天!(结构体、共用体、枚举、位运算)

2024-02-01 06:04

本文主要是介绍嵌入式学习第十四天!(结构体、共用体、枚举、位运算),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 结构体:

    1. 结构体类型定义:

嵌入式学习第十三天!(const指针、函数指针和指针函数、构造数据类型)-CSDN博客

    2. 结构体变量的定义:

嵌入式学习第十三天!(const指针、函数指针和指针函数、构造数据类型)-CSDN博客

    3. 结构体元素的访问:

嵌入式学习第十三天!(const指针、函数指针和指针函数、构造数据类型)-CSDN博客

    4. 结构体的存储:

        内存对齐:

            char      按照1字节对齐

            short     按照2字节对齐

            int         按照4字节对齐

            double  按照4字节对齐

        结构体整体的大小必须为最大基本类型长度的整数倍

    5. 结构体作为函数参数:

struct student stu;GetAllStuInfo(&stu);
int GetAllStuInfo(struct student *pstu);

    6. 结构体数组:

        练习:定义一个学生的类型,封装一个函数GetStuInfo获得学生信息放入结构体中,再封装一个函数PutStuInfo打印学生信息

#include <stdio.h>struct student
{char name[100];char sex;int age;int score;
};int GetAllStuInfo(struct student *pstu, int maxlen)
{int i = 0;int curlen = 0;printf("请输入学生个数:\n");scanf("%d",&curlen);	for(i = 0; i < curlen; i++){scanf("%s", pstu[i].name);scanf(" %c", &pstu[i].sex);scanf("%d", &pstu[i].age);scanf("%d", &pstu[i].score);}return curlen;
}int PutAllStuInfo(struct student *pstu, int len)
{int i = 0;for(i = 0; i < len; i++){printf("姓名:%s\n", pstu[i].name);printf("性别:%c\n", pstu[i].sex);printf("年龄:%d\n", pstu[i].age);printf("分数:%d\n", pstu[i].score);}
}int main(void)
{struct student s[100];int n = 0;n = GetAllStuInfo(s, 100);PutAllStuInfo(s, n);return 0;
}

2. 共用体:

union 共用体名
{数据类型1 成员变量1;数据类型2 成员变量2;数据类型3 成员变量3;...
};

    共同体所有成员变量共享同一片空间

    内存大小端:

        1. 内存小端:

            内存低地址存放低数据位

            内存高地址存放高数据位

        2. 内存大端:

            内存低地址存放高数据位

            内存高地址存放低数据位

        举例应用:

#include <stdio.h>union s
{char a;int b;
};int main(void)
{union s s1;s1.b = 1;if(s1.a){printf("小端\n");}else{printf("大端\n");}#if 0int num = 0x11223344;char *p = NULL;p = (char *)&num;if(*p == 0x11){printf("大端\n");}else{printf("小端\n");}
#endifreturn 0;
}

3.枚举

enum 枚举类型名
{枚举常量1,枚举常量2,枚举常量3,    };

    1. 枚举类型一般说明将来变量的值在给定的常量中选择其一作为它的值

    2. 枚举常量的值总是前一个枚举常量的值+1,第一个默认为0值

    3. 枚举常量默认为int类型,可以直接在程序中使用

4. 位运算运算符:

&按位与与0得0
|按位或或1置1
^按位异或相同为0,相异为1
~按位取反
>>右移右移n位,等价于让该数 /2^n
<<左移z左移n位,等价于让该数 *2^n

    按位异或实现数据交换:

a = a ^ b;  
b = a ^ b;   //b = a ^ b ^ b = a ^ 0 = a;
a = a ^ b;   //a = a ^ b ^ (a ^ b ^ b) = a ^ b ^ a ^ b ^ b = a ^ b ^ a ^ 0//  = a ^ b ^ a = a ^ a ^ b = 0 ^ b = b

    将变量的第n位置0:

 num = num & ~(1 << n)

    将变量的第n位置1:

num = num | (1 << n)

作业:

        有一个班的5个学生,有3门课程。

                1、求第一门课的平均分;

                2、找出有两门以上课程不及格的学生,输出他们的学号和全部课程成绩及平均分

                3、找出平均分在90分以上或全部课程成绩在85分以上的学生。

                分别编写三个函数来实现以上三个要求

#include <stdio.h>
#include <string.h>struct student
{char name[32];int no;int score[3];
};double GetAvgScore(struct student *pstu, int len)
{int i = 0;int sum = 0;for(i = 0; i < len; i++){sum += pstu[i].score[0];}return sum / (len+0.0);
}int OutputFailStuInfo(struct student *pstu, int len, int num)
{int i = 0;int j = 0;int k = 0;int cnt = 0;double sum = 0;printf("\n两门以上不及格学生为:\n");for(j = 0; j < len; j++){for(i = 0; i < num; i++){if(pstu[j].score[i] < 60){cnt++;}sum += pstu[j].score[i];}if(cnt >= 2){printf("姓名:%s\n", pstu[j].name);printf("学号:%d\n", pstu[j].no);for(k = 0; k < num; k++){printf("第%d门分数为:%d\n", k+2, pstu[j].score[k]);}printf("平均分数为:%.2lf\n", sum/(num+0.0));printf("\n");}cnt = 0;sum = 0;}return 0;
}int OutputBestStuInfo(struct student *pstu, int len, int num)
{int i = 0;int j = 0;int k = 0;int cnt = 0;int sum = 0;printf("平均分在90分以上或全部成绩在85分以上的学生为:\n");for(j = 0; j < len; j++){for(i = 0; i < num; i++){sum += pstu[j].score[i];if(pstu[j].score[i] > 85){cnt++;}}if(cnt == 3 || sum/num > 90){printf("%s\n", pstu[j].name);}cnt = 0;sum = 0;}
}int main(void)
{struct student stu[5]={{"zhangsan", 202401, {78, 69, 81}},{"lisi", 202402, {49, 57, 73}},{"wangwu", 202403, {32, 53, 67}},{"maliu", 202404, {95, 94, 99}},{"zhaoqi", 202405, {87, 91, 86}}};double avg = 0;avg = GetAvgScore(stu, 5);printf("所有学生第一门课的平均分为: %.2lf\n", avg);OutputFailStuInfo(stu, 5, 3);OutputBestStuInfo(stu, 5, 3);return 0;
}

这篇关于嵌入式学习第十四天!(结构体、共用体、枚举、位运算)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/666276

相关文章

SQLite3 在嵌入式C环境中存储音频/视频文件的最优方案

《SQLite3在嵌入式C环境中存储音频/视频文件的最优方案》本文探讨了SQLite3在嵌入式C环境中存储音视频文件的优化方案,推荐采用文件路径存储结合元数据管理,兼顾效率与资源限制,小文件可使用B... 目录SQLite3 在嵌入式C环境中存储音频/视频文件的专业方案一、存储策略选择1. 直接存储 vs

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

C++11作用域枚举(Scoped Enums)的实现示例

《C++11作用域枚举(ScopedEnums)的实现示例》枚举类型是一种非常实用的工具,C++11标准引入了作用域枚举,也称为强类型枚举,本文主要介绍了C++11作用域枚举(ScopedEnums... 目录一、引言二、传统枚举类型的局限性2.1 命名空间污染2.2 整型提升问题2.3 类型转换问题三、C

MySQL中的索引结构和分类实战案例详解

《MySQL中的索引结构和分类实战案例详解》本文详解MySQL索引结构与分类,涵盖B树、B+树、哈希及全文索引,分析其原理与优劣势,并结合实战案例探讨创建、管理及优化技巧,助力提升查询性能,感兴趣的朋... 目录一、索引概述1.1 索引的定义与作用1.2 索引的基本原理二、索引结构详解2.1 B树索引2.2

如何使用Maven创建web目录结构

《如何使用Maven创建web目录结构》:本文主要介绍如何使用Maven创建web目录结构的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录创建web工程第一步第二步第三步第四步第五步第六步第七步总结创建web工程第一步js通过Maven骨架创pytho

Python循环结构全面解析

《Python循环结构全面解析》循环中的代码会执行特定的次数,或者是执行到特定条件成立时结束循环,或者是针对某一集合中的所有项目都执行一次,这篇文章给大家介绍Python循环结构解析,感兴趣的朋友跟随... 目录for-in循环while循环循环控制语句break语句continue语句else子句嵌套的循

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Java 枚举的基本使用方法及实际使用场景

《Java枚举的基本使用方法及实际使用场景》枚举是Java中一种特殊的类,用于定义一组固定的常量,枚举类型提供了更好的类型安全性和可读性,适用于需要定义一组有限且固定的值的场景,本文给大家介绍Jav... 目录一、什么是枚举?二、枚举的基本使用方法定义枚举三、实际使用场景代替常量状态机四、更多用法1.实现接

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

C/C++中OpenCV 矩阵运算的实现

《C/C++中OpenCV矩阵运算的实现》本文主要介绍了C/C++中OpenCV矩阵运算的实现,包括基本算术运算(标量与矩阵)、矩阵乘法、转置、逆矩阵、行列式、迹、范数等操作,感兴趣的可以了解一下... 目录矩阵的创建与初始化创建矩阵访问矩阵元素基本的算术运算 ➕➖✖️➗矩阵与标量运算矩阵与矩阵运算 (逐元