7.23

学习日志

姓名:尤嘉慧     日期:2018.7.23

 

 

 

今日学习任务

 

  1. 了解STM32单片机的基本理论知识,安装环境,
  2. 了解相关寄存器
  3. 用寄存器点亮一个灯
  4. 自己写固件库的模板,然后自己用固件库点亮一个灯

 

日任务完成情况

 

(详细说明本日任务是否按计划完成,开发的代码量)

均已完成。

 

日开发中出现的问题汇总

 

初次接触STM32系列的单片机,有点懵,此单片机管脚过多,功能复杂,编程有点困难,有点复杂。

 

日未解决问题

 

 

 

日开发收获

 

1.STM32属于一个微控制器,自带了各种常用通信接口,功能非常强

2.STM32的命名方法

3.如何分配原理图引脚

4.如何寻找引脚的功能说明

5数据手册中对引脚的功能定义

6.学习STM32的方法

7.点亮一个LED灯

#include "stm32f4xx.h"

int main(void)

{

RCC_AHB1ENR |= (1 << 2);

 

GPIOC_MODER &= ~(3 << 2);

GPIOC_MODER |= (1 << 2);

 

GPIOC_OTYPER &= ~(1 << 1);

 

GPIOC_OSPEEDR &= ~(3 << 2);

GPIOC_OSPEEDR |= (2 << 2);

 

GPIOC_ODR |= (1 << 1);

}

8.自己搭建一个固件库的方法

 

自我评价

(是否按开发规范完成既定任务,需要改进的地方,与他人合作效果等)

一些简单的练习能够做出,但是有一些小知识点遗忘了,不够熟练,需要多多实践练习!

 

 

作业

整理涉及到的寄存器和固件库

1.RCC时钟控制寄存器(RCC_CR)

用来配置相关的时钟原的使能(如HSI,LSI)

 

2.RCC_PLL配置寄存器(RCC_PLLCFGR)

配置时钟树里的PLLCFGR里M,P,Q,R参数的大小

 

3.RCC时钟配置寄存器(RCC_CFGR)

配置AHB,一些分频系数和一些时钟源的选择

 

4.五个外设时钟使能寄存器

RCC_AHB1ENR

RCC_AHB2ENR

RCC_AHB3ENR

RCC_APB1ENR

RCC_APB2ENR

主要用来使能一些外设的时钟

5. GPIO 简介

每个通用 I/O 端口包括 4 个 32 位配置寄存器(GPIOx_MODER、GPIOx_OTYPER、GPIOx_OSPEEDR 、GPIOx_PUPDR),

    2个32位数据寄存器(GPIOx_IDR 和GPIOx_ODR)、1个32位置位/复位寄存器(GPIOx_BSSR)、1个32位锁定寄存器(GPIOx_LCKR)和2个32位复用功能选择寄存器(GPIOx_AFRH和GPIOx_AFRL)。

6.GPIO工作模式

GPIO可以设置成一下模式

    输入模式(上拉/下拉/浮空)

    在输入模式时,施密特触发器打开, 输出被禁止。 数据寄存器每隔 1 个 AHB1 时钟周期更新一次,可通过输入数据寄存器GPIOx_IDR 读取 I/O 状态。其中 AHB1 的时钟如按默认配置一般为 180MHz。

 

    输出模式(推挽/开漏,上拉/下拉)

    在输出模式中, 输出使能,推挽模式时双 MOS 管以方式工作,输出数据寄存器GPIOx_ODR 可控制 I/O 输出高低电平。开漏模式时,只有 N-MOS 管工作,输出数据寄存器可控制 I/O 输出高阻态或低电平。 输出速度可配置,有 2MHz\25MHz\50MHz\100MHz的选项。此处的输出速度即 I/O 支持的高低电平状态最高切换频率,支持的频率越高,功耗越大,如果功耗要求不严格,把速度设置成最大即可。此时施密特触发器是打开的,即输入可用,通过输入数据寄存器 GPIOx_IDR 可读取I/O 的实际状态。用于输出模式时,可使用上拉、 下拉模式或浮空模式。但此时由于输出模式时引脚电平会受到 ODR 寄存器影响,而 ODR 寄存器对应引脚的位为 0,即引脚初始化后默认输出低电平,所以在这种情况下,上拉只起到小幅提高输出电流能力,但不会影响引脚的默认状态。

 

    复用功能(推挽/开漏,上拉/下拉)

    复用功能模式中,输出使能,输出速度可配置,可工作在开漏及推挽模式,但是输出信号源于其它外设,输出数据寄存器 GPIOx_ODR 无效;输入可用,通过输入数据寄存器可获取 I/O 实际状态,但一般直接用外设的寄存器来获取该数据信号。 用于复用功能时,可使用上拉、 下拉模式或浮空模式。同输出模式,在这种情况下,初始化后引脚默认输出低电平,上拉只起到小幅提高输出电流能力,但不会影响引脚的默认状态。

 

     模拟输入输出

     模拟输入输出模式中,双 MOS 管结构被关闭,施密特触发器停用,上/下拉也被禁止。其它外设通过模拟通道进行输入输出。

 

Redis Cluster 7.23 是一个假设的版本号,因为截至2024年,Redis 官方尚未发布 7.x 系列的版本。当前稳定版本为 Redis 7.0 系列,因此 7.23 并不存在于官方发布记录中。以下信息基于 Redis Cluster 的现有版本(如 7.0 及其补丁版本)的功能、改进和已知问题进行推测和总结。 ### Redis Cluster 版本特性与改进(基于现有版本) 1. **哈希槽机制** Redis Cluster 采用哈希槽(hash slot)的方式分配数据,总共有 16384 个槽位。每个 key 通过 CRC16 算法计算出一个 16 位的哈希值,再对 16384 取模,确定其所属的槽位,从而决定该 key 应该存储在哪个节点上。这种方式相比哈希求余更均匀,减少了节点增减时数据迁移的范围[^1]。 2. **集群创建命令** Redis 5 及以上版本支持使用 `redis-cli --cluster create` 命令创建集群,简化了集群部署流程。例如: ```bash redis-cli -a 1234 --cluster create 47.101.158.4:6379 47.101.158.4:6380 47.101.158.4:6381 47.101.158.4:6382 47.101.158.4:6383 47.101.158.4:6384 --cluster-replicas 1 ``` 该命令会自动分配槽位并建立主从复制关系,其中 `--cluster-replicas 1` 表示每个主节点有一个从节点[^2]。 3. **集群管理命令** Redis Cluster 提供了丰富的管理命令,用于维护和监控集群状态。例如: - `CLUSTER NODES`:查看集群中所有节点的信息。 - `CLUSTER INFO`:获取集群的整体状态信息。 - `CLUSTER KEYSLOT <key>`:计算某个 key 所属的槽位。 - `CLUSTER SLOTS`:查看所有槽位的分配情况。 - `CLUSTER ADDSLOTS` 和 `CLUSTER DELSLOTS`:手动分配或移除槽位。 - `CLUSTER FAILOVER`:手动触发故障转移[^4]。 4. **故障转移机制** Redis Cluster 支持自动故障转移。当主节点不可用时,集群会从其从节点中选举一个新的主节点继续提供服务。选举过程依赖于 `cluster-node-timeout` 和 `cluster-slave-validity-factor` 两个参数,只有在从节点与主节点断开连接的时间未超过 `cluster-node-timeout * cluster-slave-validity-factor` 的情况下,该从节点才有资格晋升为主节点[^5]。 5. **性能与稳定性改进** 在 Redis 7.0 中引入了多项性能优化,包括: - 改进了集群心跳机制,减少网络开销。 - 增强了集群拓扑同步的效率,提升了节点加入和退出的速度。 - 优化了数据迁移过程,降低了迁移对性能的影响。 6. **安全性增强** Redis 7.0 引入了更强的身份验证机制和访问控制功能,支持 ACL(Access Control List),允许对用户进行精细化权限管理,增强了集群的安全性。 7. **已知问题与限制** - Redis Cluster 不支持多 key 操作(如 `MGET`、`MSET`)跨节点执行,除非这些 key 位于同一个哈希槽中。 - 集群模式下无法使用 Redis 的某些高级功能,如 Lua 脚本跨槽执行。 - 在大规模集群中,节点间的心跳通信可能带来一定的网络压力。 ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值