Keil + STM32学习嵌入式数据结构-01

news2025/1/12 2:54:43

 视频链接

初识数据结构,十天搞定嵌入式数据结构_哔哩哔哩_bilibili

课程目的

学会嵌入式经常使用的数据结构

具备基础知识 

具有C语言基础(结构体、指针、内存(malloc))

具有数据结构的基础知识,因此提及到的基础知识比较少

嵌入式数据结构的实现基本上基于结构体 ,在FreeRTOS的源码中体现的很清楚,基本上都是结构体,或者为了描述一个东西(数据)的属性时(数据元素--数据的基本单位)你需要使用结构体,比如学生的成绩、排名、姓名等

学习方法

以分析FreeRTOS中内部存在的数据结构来学习嵌入式数据结构,数据结构在操作系统中体现的淋漓尽致,因此当你分析完FreeRTOS中数据结构的算法后,你就具备了嵌入式数据结构的基础。嵌入式的数据结构内容不是特别的多,因为有些数据结构很少使用到

代码量决定你的能力提升范围

数据结构的作用

让数据的处理更加高效、灵活,使用起来更方便,为了满足更多的情况

数据的逻辑结构

线性、层次、网状,其实就是分线性和非线性结构(按照前趋数和后继数分类的),我们常见的并且使用最多的是线性结构(线性表、栈、队列)

数据的存储结构

如何把数据存储在内存(把内存想象成一个房子的房间)中,连续存储(数组-房间号连续)、非连续数组(链表--房间号不连续---用地址/指针建立连接)

数据结构意义

1:提高编程能力

2:提高程序的复用性、维护性、可读性

3:程序 = 数据结构 + 算法

什么是数据结构

数据结构 = 数据 + 结构(逻辑和存储)

数据和数据元素

 

 比如下面的属性就是数据元素,为了描述数据

 顺序存储

缺点:插入和删除不方便

优点:查找方便

根据处理的问题进行选择性的使用存储方式

 上图亮点在typedef int data_t中,因为我们的数据类型可以改变

last表示数组长度

顺序存储的使用

1:代码分层处理,把顺序存储分成.c和.h文件,如果别人需要使用我们的写的文件,我们给的是.h和.so文件(动态库)(由.c编译的二进制文件,防止别人知道源码实现,这个操作很常见,比如你不知道printf的源码时如何实现的,你只能打开stdio.h而不存在stdio.c)

2:在写代码的时候,要有代码架构思想,为了提高我们的代码复用性,可以很方便的给别人使用或者换一个场景也能很快使用

在C语言中,一般使用数组(结构体数组)表示顺序存储。因此我们使用结构体数组来点亮我们想要的LED灯---需要借助FreeRTOS的动态内存分配

typedef struct Class LED_t ;
#define N  5      //表示能装多少个LED灯

struct  Class
{
    uint8_t Num;
    uint32_t RCC_CLOCK;
    GPIO_TypeDef * GPIOX;
    uint16_t GPIO_Pin;
    GPIOMode_TypeDef GPIO_Mode;
    GPIOSpeed_TypeDef GPIO_Speed;
    BitAction BitVal;  //赋值电平
    const char *str;
    
};

typedef struct
{    
    LED_t LED_Data[N];
    uint16_t len;
   
}sqlsitLED, *sqlinkLED;

顺序数组的操作

/*
*   创建顺序表
*/
sqlinkLED List_Create()
{
   sqlinkLED  class;
   class = (sqlinkLED)pvPortMalloc(sizeof(sqlsitLED));
   if( class == NULL )
    {
       printf("List_Create is fail\r\n");
       return NULL;
    }
    else
    {
        printf("List_Create is sucess\r\n");
        memset(class->LED_Data , 0 , sizeof(LED_t)*N);
        class->len = 0;
        return class;
    }
    
}

/*
*   清空顺序表  0--失败  1--成功
*/
uint8_t Clear_List( sqlinkLED class )
{
    if( class == NULL )
        return 0;
    
    memset(class->LED_Data , 0 , sizeof(LED_t)*N);
    class->len = 0;
    
    return 1;
}

/*
*   判断顺序表是否为空 1--空  0--不为空
*/
uint8_t List_empty( sqlinkLED class )
{
    if(class->len == 0) 
        return 1;
    
    return 0;
    
}

/*
*   判断顺序表的长度
*/
uint8_t List_length( sqlinkLED class )
{
   if(class != NULL )
   {       
        return class->len;
   }
}

创建LED灯顺序表

sqlinkLED LED;

LED = List_Create();
    if(LED == NULL )
    {
        printf("create list is fail\r\n");
    }
    else
    {
        printf("create list is sucess\r\n");
    }

LED灯顺序表赋值

功能行驶函数

void Give_ListValue( sqlinkLED class,uint8_t index )
{
    GPIO_InitTypeDef  GPIO_InitStructure;
 	
    RCC_APB2PeriphClockCmd(class->LED_Data[index].RCC_CLOCK, ENABLE);	
	
    GPIO_InitStructure.GPIO_Pin = class->LED_Data[index].GPIO_Pin;				
    GPIO_InitStructure.GPIO_Mode = class->LED_Data[index].GPIO_Mode ; 		 
    GPIO_InitStructure.GPIO_Speed =  class->LED_Data[index].GPIO_Speed;		 
    GPIO_Init( class->LED_Data[index].GPIOX, &GPIO_InitStructure);
    GPIO_WriteBit(class->LED_Data[index].GPIOX, class->LED_Data[index].GPIO_Pin, class->LED_Data[index].BitVal);
    
   	printf("%s\r\n",class->LED_Data[index].str);			 
    
}
LED->LED_Data[1].GPIOX = GPIOD;
    LED->LED_Data[1].BitVal = 0;
    LED->LED_Data[1].GPIO_Pin = GPIO_Pin_2;
    LED->LED_Data[1].GPIO_Mode = GPIO_Mode_Out_PP;
    LED->LED_Data[1].GPIO_Speed = GPIO_Speed_50MHz;
    LED->LED_Data[1].Num = 1;
    LED->LED_Data[1].str = "LED1";
    LED->LED_Data[1].RCC_CLOCK = RCC_APB2Periph_GPIOD;
    LED->len = 2;

 点亮LED

改变LED->LED_Data[1].BitVal 的值即可熄灭和点亮LED

Give_ListValue(LED, 1);

为其他数组赋值

 LED->LED_Data[0] =  LED->LED_Data[1];
 printf("S%s\r\n",LED->LED_Data[1].str);  

清零数组

 memset(&(LED->LED_Data[1]) , 0 , sizeof(LED_t));  

插入led数组

/*
*   插入一个LED_t类型的变量插入在数组中去,你需要考虑数组是否满了-插入位置是否合法---插入形式
*   pos是位置从1开始
*/
uint8_t List_Insert( sqlinkLED class, LED_t led, uint8_t pos )
{
    uint8_t i;
    
    //先判断有没有位置
    if(class->len == N)
        return 1;  //表示满了
    
    //判断pos的值是否符合
    if(N  < pos )  //不符合,没有这个数组下标
        return 1;
    
    //判断pos的值是否是最后一个
    if(N == pos)
    {
        class->LED_Data[pos-1] = led;
        class->len++;
        return 0;
    }
    
    //移动,空出pos的位置
    for( i=class->len-1;i>=pos;i--)
       class->LED_Data[i] = class->LED_Data[i-1] ;
    
    class->len++;
    return 0;
    
}


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/153899.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Android 深入系统完全讲解(8)

2 Smali 调试 Smali 是安卓 Apk 反编译出来的格式&#xff0c;类似于我们 PC 上面的汇编语言。语法可以参考这个文 章&#xff1a;https://blog.csdn.net/yuanguozhengjust/article/details/80493963 PC 上的反编译调试工具用 OD 和 IDA&#xff08;这个也可以调试 Android &…

Java 调用 扫描仪的技术该如何选择?

文章目录Java 调用 扫描仪的技术该如何选择?详细介绍;&#xff08;1&#xff09;TWAIN&#xff08;2&#xff09;Kodakimg&#xff08;3&#xff09;Dynamic TWAIN ActiveX&#xff08;4&#xff09;WIA&#xff08;用于桌面应用程序&#xff09;开发应用程序&#xff0c;您可…

计算机组成原理习题一

计算机组成原理习题一 文章目录计算机组成原理习题一题目答案题目 1.某数的IEEE单精度浮点数存储形式为C1F00000H&#xff0c;则其所表示的十进制数真值是多少&#xff1f;要求写出详细求解过程以及最终结果。 2.求出数据10010100110的海明码&#xff0c;可检/纠错一位错&…

【实战篇】40 # 如何实现3D地球可视化?

说明 【跟月影学可视化】学习笔记。 如何实现一个 3D 地球 学习笔记源码实现&#xff1a;https://github.com/kaimo313/visual-learning-demo 整体实现效果如下&#xff1a; 1、绘制一个 3D 球体 <!DOCTYPE html> <html lang"en"><head><m…

五、数据导入与基本的 SELECT 语句

文章目录一、数据导入指令二、基本查询语句2.1 SELECT ...2.2 使用 SELECT 语句查询一个数据表2.3 查询表中的一列或多列三、单表查询3.1 用 DISTINCT 关键字去除结果中的重复行3.2 使用 AS 设置别名3.3 着重号3.4 运算符3.4.1 算术运算符3.4.2 比较运算符3.4.3 逻辑运算符3.4.…

k8s之Deployment

写在前面 本文一起看下Deployment API对象&#xff0c;该对象的作用是保证POD的高可用&#xff0c;即保证POD的可用数量一直维持在某个期望状态中&#xff0c;比如期望状态是有3个POD&#xff0c;当有一个POD意外终止时&#xff0c;则会自动再启动一个新POD&#xff0c;所以De…

Makefile 如何构建Go项目

前言 &#x1f4da; 请问你是如何打包Go语言开发的项目呢&#xff1f; 是直接命令行输入&#xff1f; go build . 开发调试时&#xff1f; go run main.go 但是我们看到开源的Go语言项目运行时是&#xff1a; make build || make install 我们打包运行的这个过程&#xff0…

Mask RCNN网络源码解读(Ⅵ) --- Mask分支及Loss计算

目录 0.先决知识 1.简介 2.mask_rcnn.py解析 2.1 初始化函数 2.2 MaskRCNNHeads类 2.3 MaskRCNNPredictor类 3.RoIHeads类解析 3.1 正向传播过程 3.2 mask部分损失 3.3 maskrcnn_inference 0.先决知识 学习此篇博客之前&#xff0c;读者应有&#xff1a; ①一定的p…

MySQL常用命令 (这些命令专属于MySQL 不属于标准SQL语句)

1、查看MySQL版本 &#xff1a;select version(); ​​​​​​​ ​​​​​​​ ​​​​​​​ 2、创建数据库 &#xff1a;create database 数据库名称; 3、使用/指定数据库&#xff1a;use 数据库名称; 4、查看当前使用的数据库…

硬件系统工程师宝典(3)-----信号完整性分析是个啥?

各位同学大家好&#xff0c;欢迎继续做客电子工程学习圈&#xff0c;今天我们继续来讲这本书&#xff0c;硬件系统工程师宝典。上篇我们读到硬件电路的概要设计需要考虑的问题&#xff0c;相关的可行性分析可以使开发工作事半功倍。信号完整性分析概述今天我们开始学习在高速电…

上海亚商投顾:两市震荡引分化 汽车产业链获青睐

上海亚商投顾前言&#xff1a;无惧大盘大跌&#xff0c;解密龙虎榜资金&#xff0c;跟踪一线游资和机构资金动向&#xff0c;识别短期热点和强势个股。市场情绪大小指数今日走势分化&#xff0c;沪指全天弱势震荡&#xff0c;创业板指在权重股助力下&#xff0c;午后一度冲高涨…

靶机测试 0s-hackNos-2笔记

简介靶机地址https://www.vulnhub.com/entry/hacknos-os-hacknos-2,403/#Difficulty : Easy to IntermediateFlag : 2 Flag first user And second rootLearning : Web Application | Enumeration | Password Cracking测试过程信息收集nmap扫描端口nmap -p- -A 192.168.1.103 -…

如何在 Zorin OS 上安装 ONLYOFFICE 桌面编辑器

ONLYOFFICE 桌面应用是一款开源办公套件&#xff0c;包括用于文本文档、电子表格、演示文稿和表单的编辑器。除了离线工作&#xff0c;您还可以将该应用连接到云端进行在线文档协作。这款套件的源代码可在 GitHub 上获得&#xff0c;是根据 AGPL v.3.0 许可。 ONLYOFFICE桌面编…

golang中new与make的区别

new和make new // The new built-in function allocates memory. The first argument // is a type,not a value, and the value returned is a pointer to a // newly // allocated zero value of that type. func new(Type) *Type对于官方是这么解释new的&#xff1a;这个…

(6)go-micro微服务consul配置、注册中心

文章目录一 Consul介绍1. 注册中心Consul基本介绍2.注册中心Consul关键功能3.注册中心Consul两个重要协议二 Consul安装1.使用docker拉取镜像三 Config配置四 Consul代码编写1.设置consul配置中心2.获取consul配置中心的数据3.consul可视化界面数据编写4. main.go代码编写五 最…

微信小程序-页面导航

小程序实现页面导航的两种方式 声明式导航(tabBar 页面&#xff0c;在app.json中配置) 在页面上声明一个<navigator>导航组件通过点击<navigator> 组件实现页面跳转 app.json中 "tabBar": {"list": [{"pagePath": "pages/home…

【胖虎的逆向之路】02——Android整体加壳原理详解实现

【胖虎的逆向之路】(02)——Android整体加壳原理详解&实现 Android Apk的加壳原理流程及详解 文章目录【胖虎的逆向之路】(02)——Android整体加壳原理详解&实现前言一、加壳前的知识储备1. Android 应用的启动流程2. Android 应用的安装3. Android应用的启动流程&…

09-JAVA四种引用类型?

在JDK1.2版之后&#xff0c;Java对引用的概念进行了扩充&#xff0c;将引用分为强引用&#xff08;Strongly Reference&#xff09;、软引用&#xff08;Soft Reference&#xff09;、弱引用&#xff08;Weak Reference&#xff09;和虚引用&#xff08;Phantom Reference&…

使用Deep Q-Network学习如何玩《飞行的小鸟》游戏

目录概述效果需要的依赖如何运行算法原理实验输入处理网络结构训练代码概述 使用DQN实现《飞行的小鸟》游戏&#xff0c;代码可修改扩展为其他游戏&#xff0c;适合学习研究用。 效果 需要的依赖 Python 2.7 or 3 TensorFlow 0.7 pygame OpenCV-Python 如何运行 运行主函数…

目标追踪综述

目标追踪综述 - 知乎目标跟踪是计算机视觉领域的一个重要问题&#xff0c;目前广泛应用在体育赛事转播、安防监控和无人机、无人车、机器人等领域。下面是一些应用的例子。 体育赛事转播 无人车 目标跟踪任务分类了解了目标跟踪的用途&#xff0c;我们接下…https://zhuanlan.z…