Ⅰ 12T和1T单片机的一个机器周期相同吗
晶振决定时钟周期(机器周期),51的指令周期是12个时钟周期。NOP 指令占一个指令周期。
Ⅱ 什么叫12T和1T的单片机
首先是时钟周期和晶振周期的区别,时钟周期不一定等于晶振周期,例如倍频的时候。其次,1t在这里所指的就是一个机器周期为一个时钟周期,而指令的执行时间是以机器周期为单位的。额外补充:stc的1t系列单片机除了一个机器周期为一个时钟周期外,还对指令进行了优化,令一些指令执行所需的机器周期较原来的要少。
Ⅲ 一般说1T 4T 6T 12T的单片机是指的什么
1T、4T、6T、12T应该是指每个指令周期所需要的机器周期数。
以经典51平台为例,以振荡输入端每12个周期作为一个指令周期。
选购单片机时,应以是否熟悉、是否会用为绝对优先。当然如果是纯学习,则不妨选择一款使用较广泛、较具有代表性的单片机作为上手的初恋^_^
单片机的晶振不能乱选,应根据其手册确定所能达到的频率上限、任务所实际需求的执行速度、功耗的要求、电磁兼容性能的要求来综合选择。另外某些特殊应用也对晶振频率有一定要求,例如51进行UART通信时为了得到较精确的波特率,一般选用11.0592MHz晶体。
Ⅳ STC12的1T模式与12T模式哪个稳定
1T和12T
1T和12T只有在STC12系列以后的单片机里才出现的。前面我们已经说到了,传统的单片机其实就是12T单片机,也就是晶振频率会被12分频后才是指令运行的频率。到时STC12系列以后的STC单片机出现1T模式,也就是有些指令的执行时只需要两个晶振周期就能执行完。理论上来说,这样的运行速度会比传统单片机快6倍,为什么加“理论”,因为不是所有的指令都快6倍,只是一部分,还有些是快4倍,快3倍的。具体的需要看STC官方数据手册,如下图。
仔细的小伙伴会看到在第5列的第一行里有个小括号(采用STC-Y2 CPU内核指令集),STC12用的就是这个内核,而到了STC15系列芯片用的是STC-Y5内核,STC8系列用的是STC-Y6内核,Y后面的数字越大,指令优化的越厉害,表现出来的就是运行的更快,STC-Y5内核的指令集里,大部分的汇编指令到时一个晶振周期就执行完成的了,也就是比传统单片机快12倍。 现在我在做单片机开发的时候,绝大部分都是采用的C语言开发,你还在用汇编,那我只能是膜拜你了。C语言编程的程序方便移植,好理解,容易入门,不需要去记住那些复杂的寄存器,但是确定也明显,就是效率不高,运行速度我们没办法准确的计算出来。编译器在把C语言代码转化为汇编语言的过程我们是没法控制的,这样编译出来的机器代码我们就没办法去计算时间的指令运行时间。 >>>>
软件仿真和实际开发板
仿真软件,外国老表开发的,STC国产(好吧,内核还是人家的)。不知道什么原因,我们不知道,也不敢问,在仿真软件里就是没有STC的单片机芯片可以选择,没有STC的单片机,我们只能选择传统51单片机,这样一来,仿真的时候,程序运行的速度是传统的12T模式,也就是晶振频率12分频后才是执行的实际频率。 单片机开发板运行时,因为提问小伙伴用的单片机是STC12系列的芯片,就算他运行在12T模式下,指令系统还是有优化,速度肯定比传统的指令集要快。更何况呢,他连1T和12T都分不清,运行在1T模式下也是有可能的,所以,今天的问题就来了。实际开发板运行速度肯定会比软件仿真快。 写在最后 在很久之前,我就写过一篇文字,就说了不建议初学单片机的菜鸟从软件仿真开始。现在还有多少高校的单片机课程还在是以仿真运行的呢,希望是没有了,但我想,仅仅是我想想。 其实,小代觉得,学单片机的最终是要自己设计属于自己的东西,比如自己的毕设,更或是亲手做一个小礼物俘获女神的芳心。但是自己写的代码永远都运行在软件里,没有实际电路,你又怎么可能会自己设计电路呢。你不自己看见过电阻,又怎么可能会知道一个长得很像电阻的电子元件它其实是二极管。 最最后,回到今天的问题上,当我们把软件仿真运行完美的代码移植到实际开发板上运行时,代码是需要做单片机的适配的,比如,采用代码方式实现的延时函数,比如IO端口的配置,比如某些中断的入口,比如某些寄存器的定义等等。在移植之前,还是得拿目标芯片的数据手册来看看。
Ⅳ 1T和12T单片机的区别
早期的标准51单片机,其机器周期为 12倍系统时钟周期;
随着单片机的高速发展,对运算速度要求逐渐加大,各单片机厂家纷纷出台高速单片机,如microchip单片机采用 4倍系统时钟,宏晶的高速单片机为 单倍系统时钟……
后来人们把这些分别称为 12T、4T、1T……