嵌入式学习笔记 - 关于单片机的位数

通常我们经常说一个单片机是8位的,16位的,32位的,那么怎么判断一款单片机的位数是多少位呢,判断的依据是什么呢,

一 单片机的位数

单片机的位数是指单片机数据总线的宽度,也就是一次能处理的数据的位数(bit),不是地址总线的宽度,也不是存储器的位宽,地址线的位数可以跟数据线不一致,像51单片机的地址总线为16位,但是它是8位单片机,ARM的存储器也有8位的但是它是32位机。

顾名思义,单片机的位数越多,一次能处理的数据也就越大,一次能搬运执行的命令也就越复杂,性能也就越强,例如stm32F1系列的性能可以到16~17,而51单片机只能到2~3。

但是8位单片机也有他的优势,就是在达到某些低性能的应用场景下,它的指令与数据更密集,能利用较小的空间实现同样的功能,成本比较低。

二 8位,16位,32位单片机的典型代表以及应用场景

8位单片机,典型的是51系列的,再高级点用AVR、pic的,功能方面,似乎都不会很复杂,一般可能是控制类的多一下。一般不跑嵌入式OS。

16位的单片机,例如MSP430,感觉16位的单片机比较尴尬,高不成低不就,要求低一点,8位MCU就够,高级点不如用32位MCU。一般不跑嵌入式OS。

32位的,就高级点了,一般能跑嵌入式OS,例如ucos2,ucos3,uclinux等等,能做更多复杂的功能。用OS和不用OS的话,编程的思路差异比较大。功能一般有面向控制的,也有简单消费类电子的。

三 编程差异性:

单纯C写代码没啥区别,一般编译器把初始化都做了,需要注意的是,8位单片机定义变量最小可以到1位bit,最大位数可能只能是8位uint8_t, 而16位,32位单片机最小只能到8bit uint8_t, 最大可能能到32bit,uint32_t.

再有就是变量字节对齐问题,32位机字起始地址必须是0,4,8,C这样的4的整数倍,如果一个char型的变量赋值给一个int型字变量,要通过强制类型转换,内存会自动先转换到4字节对齐再赋值。

还有就是结构体中成员对齐的问题,如果在一个 32-bit 类型的成员前面,有 char 及 short 类型成员,且没有凑齐到 32-bit 自然边界,那么编译器将会自动补 NULL 来填充。可以参考另一篇文章-《结构体成员对齐问题》

相关推荐
虾球xz28 分钟前
CppCon 2014 学习:Making C++ Code Beautiful
c++·学习
__如果3 小时前
深度学习复习笔记
人工智能·笔记·深度学习
锦瑟居士3 小时前
Docker 笔记 -- 借助AI工具强势辅助
笔记·docker·eureka
find_element_by_id5 小时前
adb 常用命令笔记
笔记·adb
清晨朝暮5 小时前
【Linux 学习计划】-- 命令行参数 | 环境变量
linux·运维·学习
Python小老六5 小时前
单片机寄存器的四种主要类型!
单片机·嵌入式硬件
jiuweiC6 小时前
hive 笔记
hive·hadoop·笔记
2301_803652747 小时前
tiktoken学习
学习
小赵哦7 小时前
TMS320F28388D使用sysconfig配置IPC
单片机·dsp开发
许有杨9 小时前
智能门禁的项目
单片机·嵌入式硬件