51单片机 和 STM32 在硬件操作上的差异

news/2025/1/11 7:51:40/

单片机>51单片机STM32 在硬件操作上的差异


1. 时钟系统的差异

STM32 的时钟系统

STM32 的时钟系统非常复杂,支持多种时钟源(如内部晶振、外部晶振、PLL 等),并且每个外设(如 GPIO、定时器、串口等)都有独立的时钟开关。因此,在使用任何外设之前,必须启用其时钟。

  • 为什么需要启用时钟?
    • STM32 的外设默认是关闭的,以节省功耗。
    • 时钟是硬件工作的基础,没有时钟,硬件无法运行。

单片机>51单片机的时钟系统

单片机>51单片机的时钟系统非常简单,通常只有一个时钟源(如外部晶振或内部振荡器),并且所有外设共享同一个时钟。因此,单片机>51单片机不需要手动启用外设时钟。

  • 为什么不需要启用时钟?
    • 单片机>51单片机的时钟是全局的,所有外设默认都使用同一个时钟。
    • 硬件资源较少,没有复杂的时钟管理需求。

2. 外设配置的差异

STM32 的外设配置

STM32 的外设功能非常丰富,每个外设都有多种工作模式(如 GPIO 可以配置为输入、输出、复用功能等)。为了灵活配置这些外设,STM32 使用了结构体来存储配置参数,并通过初始化函数将配置应用到硬件。

  • 为什么需要配置结构体?
    • STM32 的外设功能复杂,需要通过结构体灵活配置。
    • 结构体可以存储多个参数,方便统一管理。

单片机>51单片机的外设配置

单片机>51单片机的外设功能非常简单,通常只需要直接操作寄存器即可。例如,配置 GPIO 时,只需要设置对应的寄存器位。

  • 为什么不需要配置结构体?
    • 单片机>51单片机的外设功能单一,配置简单。
    • 直接操作寄存器即可完成配置,不需要额外的结构体和初始化函数。

3. 硬件资源的差异

STM32 的硬件资源

STM32 的硬件资源非常丰富,支持多种外设(如 GPIO、定时器、串口、ADC、DAC 等),并且每个外设都有独立的控制寄存器。为了管理这些资源,STM32 使用了复杂的库函数和结构体。

  • 为什么需要初始化硬件?
    • STM32 的外设功能复杂,初始化过程需要配置多个寄存器。
    • 初始化函数将配置参数应用到硬件,确保硬件按照预期工作。

单片机>51单片机的硬件资源

单片机>51单片机的硬件资源较少,通常只有基本的 GPIO、定时器、串口等外设,且控制寄存器非常简单。因此,单片机>51单片机不需要复杂的初始化过程。

  • 为什么不需要初始化硬件?
    • 单片机>51单片机的硬件功能简单,配置过程直接通过寄存器完成。
    • 没有复杂的初始化需求。

4. 代码示例对比

STM32 的 GPIO 配置

// 1. 启用时钟
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);// 2. 配置结构体
GPIO_InitTypeDef GPIO_InitStructure;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;  // 推挽输出
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5;         // 引脚 5
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; // 输出速度 50MHz// 3. 初始化硬件
GPIO_Init(GPIOA, &GPIO_InitStructure);

单片机>51单片机的 GPIO 配置

sbit LED = P1^0;  // 定义 LED 引脚为 P1.0void main()
{LED = 0;  // 直接操作寄存器,点亮 LED
}

5. 总结:为什么 51 单片机不需要“三步走”?

  1. 时钟系统简单单片机>51单片机的时钟是全局的,所有外设共享同一个时钟,不需要手动启用。
  2. 外设功能单一单片机>51单片机的外设功能简单,直接操作寄存器即可完成配置。
  3. 硬件资源有限单片机>51单片机的硬件资源较少,没有复杂的初始化需求。

相比之下,STM32 的硬件资源丰富、外设功能复杂,因此需要通过“三步走”来管理时钟、配置参数和初始化硬件。


http://www.ppmy.cn/news/1562191.html

相关文章

Kafka集群安装

Apache kafka是由Apache软件基金会开发的一个开源流处理平台,由Scala和Java编写。Kafka是一种高吞吐量的分布式发布订阅消息系统,是消息中间件的一种,用于构建实时数据管道和流应用程序。 Kafka官网:http://kafka.apache.org/ 安装环境: Kafka集群环境搭建,依赖于zookeep…

实时数仓:基于数据湖的实时数仓与数据治理架构

设计一个基于数据湖的实时数仓与数据治理架构,需要围绕以下几个核心方面展开:实时数据处理、数据存储与管理、数据质量治理、数据权限管理以及数据消费。以下是一个参考架构方案: 一、架构整体概览 核心组成部分 数据源层 数据来源&#xff…

软件系统安全逆向分析-混淆对抗

1. 概述 在一般的软件中,我们逆向分析时候通常都不能直接看到软件的明文源代码,或多或少存在着混淆对抗的操作。下面,我会实践操作一个例子从无从下手到攻破目标。 花指令对抗虚函数表RC4 2. 实战-donntyousee 题目载体为具有漏洞的小型软…

R语言的网络编程

R语言的网络编程 引言 随着互联网的迅速发展,网络编程已经成为一个重要的研究和应用领域。各种数据的获取、处理和分析都离不开网络编程,尤其是在大数据时代。R语言作为一种专注于统计分析和数据处理的编程语言,在网络编程方面同样展现了其…

【gRPC】一元请求与流式请求的go案例展示

简述区别 请求类型方法名描述示例场景一元请求UnaryEcho客户端发送单个请求,服务端返回单个响应。简单查询或操作服务端流ServerStreamingEcho客户端发送单个请求,服务端返回一个流的响应。分页、持续更新客户端流ClientStreamingEcho客户端发送一个流的…

排序的本质、数据类型及算法选择

排序的本质、数据类型及算法选择 一、排序的本质二、排序的数据类型三、排序算法的选择依据 前两天老金写了篇 “十大排序简介”,有点意犹未尽,这一回老金想把排序连根拔起,从排序的本质说道说道。 一、排序的本质 从字面上理解&#xff0c…

RabbitMQ基础(简单易懂)

什么是RabbitMQ? 它基于AMQP协议(Advanced Message Queuing Protocol),一种为应用构建消息队列的标准协议。过程中,它提供了一些重要模块:为消息发送的Producer(生产者)&#xff0c…

统计有序矩阵中的负数

统计有序矩阵中的负数 描述 给你一个 m * n 的矩阵 grid,矩阵中的元素无论是按行还是按列,都以非递增顺序排列。 请你统计并返回 grid 中 负数 的数目 示例 1: 输入:grid [[4,3,2,-1],[3,2,1,-1],[1,1,-1,-2],[-1,-1,-2,-3]]…