适合短距离通信,并行通信控制简单、相对传输速度快(8位一起传输)。
只能一位一位的传送。
建立发送方时钟对接收方时钟的直接控制,使双方达到完全同步。此时,传输数据的位之间的距离均为“位间隔”的整数倍,同时传送的字符间不留间隙。
发送方对接收方的同步可以通过外同步和自同步
以字符(构成的帧)为单位进行传输。数据位从低到高传送。
格式:
这里的空闲时间是任意的。
在发送数据时,数据位尾随的1位为奇偶校验位(1/0)。奇校验时,数据中1的个数与检验位1的个数之和应为奇数;偶校验时,数据中1的个数与校验位1的个数之和应为偶数。接收字符时,对1的个数进行校验,若字符不一致,则说明传输数据过程中出现错误。
发送方将所发数据块求和(或各字节异或),产生一个字节的校验字符(校验和)附加到数据块末尾。接收方接收数据时,同时对数据块(除校验字节外)求和(或各字节异或),将所得的结果与发送方的“校验和”进行比较,一致则无差。
通过某种数学预算实现有效信息与校验位之间的循环校验,常用语对磁盘信息的传输、存储区的完整性校验。
#include <reg52.h> #include <stdio.h> //printf头文件 #define uc unsigned char #define uint unsigned int uc flag,i,flag_t,s[50]="",j=0,flag_n=0; uc code table[]="I get "; void init() { TMOD=0x20; //定时器工作方式,选择了定时器1,工作方式2 八位初值自动重装的8位定时器。 TH1=0xfd; //定时器1初值 ,设置波特率为9600 晶振11.0529MHZ? TL1=0xfd; TR1=1; //开启定时器1 SM0=0; SM1=1; //10位异步接收,(8位数据)波特率可变 REN=1; //允许串行口接收位 EA=1; //允许中断(总闸) ES=1; //允许串口中断 } void main() { init(); while(1) { if(flag==1) { if(flag_n!=0) //使第二个及以后I get xx 换行,不与You transfer在一行(单纯为了格式好看) {TI=1; printf("\n"); while(!TI); TI=0; } for(i=0;i<6;i++) { SBUF=table[i]; while(!TI); TI=0; } for(i=0;s[i]!='#'&&i<50;i++) { SBUF=s[i]; while(!TI); TI=0; } flag=0; } if(flag_t==1) //发送完毕之后,在电脑端输出。 { TI=1; //printf之前必须将T1置为1才行。 printf ("\nYou transfer %s",s); while(!TI); TI=0; flag_t=0; } } } void ser() interrupt 4 { if(RI) //接收数据,手动将RI清0 { RI=0; if(flag==0&&j!=0)//1.循环赋值为'\0'(字符串结尾标志符),j=0,为了第二次传递字符串是又是从头输出 { //2.flag为0和j不为0时,保证是第二次及以后,传输字符串(控制输出格式) flag_n++; for(j=0;s[j]!='#'&&j<50;j++) s[j]='\0'; j=0; } s[j]=SBUF; flag=1; if(s[j]=='#'||j==49) //以'#'作为传送字符串的结尾符,我定义的字符数组最长为50所以49也应该结束。 flag_t=1; else j++; } if(TI) //发送数据 { } }
用来管理单片机的电源部分,包括上电复位检测、掉电模式
、空闲模式等