基于51的串行通讯原理及协议详解(uart)

串行与并行通讯方式
并行:控制简单,传输速度快。线多,长距离成本较高且同时接受困难。
串行:将数据字节分成一位一位的行驶在一条传输线上进行传输。如图:
 



同步与异步串行通讯方式
同步串行通讯方式:同步通讯需要建立发送方对接收方时钟的直接控制,是双方达到完全同步。
异步串行通讯方式:通讯的发送和接收设备使用各自的时钟控制数据的发送和接收,为使双方收发协调,要求发送和接收的时钟尽可能一致。如图:


异步通讯方式的特点:
异步通讯以字符构成的帧为单位进行传输,字符与字符之间的间隙是任意的,但每个字符中的各位是以固定的时间传送的。其一帧字符信息由4部分组成:起始位、数据位、奇偶检验位、停止位。在单片机中的通讯一般情况下均使用这种帧格式。如图:


串行通讯的制式
单工:数据传输仅沿一个方向,不能实现反向传输
半双工:数据可以沿两个方向传输,但是需要分时
全双工:数据可以同时进行双向传输

串行通讯三种错误校验:奇偶校验、代码和校验、循环冗余校验

RS232电平与TTL电平的转换
PC使用的串口的电平为RS232的九针串口,MCU使用的电平是TTL电平,要使得PC 和MCU进行通讯,就需要对其电平极性转换。主要的几款电平转换芯片:MAX232、MAX202、HIN232,SIPEX320等

串行通讯速度的定义_波特率
串行通讯的速率用波特率表示,其定义为:
                   每秒钟传送二进制代码的位数,即1波特=1位/秒,单位bps(位/秒)
eg:每秒钟传送240个字符,而每个字符格式包含10位(1起始、8数据、1停止),此时的波特率为:
                   10位*240个/秒=2400bps

串行通讯波特率的计算
单片机的串行口可设定为四种工作方式,其中方式0和方式2波特率固定,方式1和方式3波特率可变,由定时器T1的溢出率来决定。计算公式如下:

其中:fosc为系统晶振频率,通常为12MHz(或者11.0592MHz),SMOD为PCON寄存器的最高位。T1的溢出率即定时器T1溢出的频率。

电源管理寄存器_PCON

SMOD;该位与串通信波特率有关。
SMOD=0;串口方式1、2、3时,波特率正常
SMOD=1;串口方式1、2、3时,波特率加倍
SMOD0,LVDF,P0F,此三位为STC_MCU 所特有的,可查看相关手册。
GF1、GF0;两个通用标志位,可随意使用。
PD;掉电模式设定位,
PD=0;MCU正常工作
PD=1;MCU进入掉电模式
IDL;空闲模式设定位
IDL=0;MCU正常工作
IDL=1;单片机进入空闲模式

单片机的两种模式状态:
掉电模式:进入掉电模式后,晶振停震,CPU,定时器,串行口全部停止工作,只有外部中断继续工作,
可有外部中断低电平触发或下降沿触发或硬件复位模式唤醒。
空闲模式:除CPU不够工作外,其余仍继续工作,在空闲模式下,可由任一个中断或者硬件复位唤醒

T1的溢出率
T1的溢出率就是T1定时器溢出的频率,只要算出T1定时器每一处一次所需的时间T,那么T的倒数即为他的溢出率。

51串行口结构
51单片机串行口是一个可编程全双工的通信接口,具有Uart(通用异步收发器)的全部功能,能同时进行数据的发送与接收,也可作为同步一位寄存器使用。
51_MCU主要由两个独立的串行数据缓冲寄存器SBUF (一个发送,一个接收)和发送控制器、接收控制器,输入移位寄存器及若干控制门电路。如图:


串行口控制寄存器_SCON

SM0,SM1;工作方式选择位,串口有四中工作方式,如下:

SM2;多机通信可控制位,SM2主要用于方式2和方式3,当接收机的SM2=1时,可以利用收的RB8来控制是否激活RI;
RB8=0,不激活RI,收到的信息丢弃
RB8=1,收到的数据进入SBUF,并激活RI,进而在中断服务中将数据从SBUF读走,

当SM2=0时,无论收到的RB8是0还是1,均可以收收到的数据进入SBUF,并激活RI,通过控制SM2可实现多机通信。
在方式0时,SM2必须是0,
在方式1时,若SM2=1,则只有接收到有效停止位时,RI才置1

REN;允许串行接收位
REN=1;允许串行口接收数据
REN=0;禁止串行口接收数据

TB8;方式2、3中发送数据的第九位,可定义其作用,奇偶检验,地址帧标志等,方式0和1中,未使用
RB8;方式2、3中接收数据的第九位,可定义其作用,奇偶检验,地址帧标志等,方式1,若SM2=0,则RB8是接收到的停止位。
TI;发送中断标志位,方式0中,串行发送第8位数据结束时,或者其他方式,串行发送停止位时,由内部硬件置1,向CPU发出中断申请,在中断服务程序中,须用软件清零,取消此中断申请。
RI;接收中断标志位, 方式0中,串行接收第8位数据结束时,或者其他方式,串行接收停止位时,由内部硬件置1,向CPU发出中断申请,在中断服务程序中,须用软件清零,取消此中断申请

串口方式0,串行口为同步移位寄存器的输入输出方式,主要永不扩展并行输入输出接口,数据由RXD(P3.0)引脚输入或者输出,同步移位脉冲由TXD(P3.1)引脚输出,发送和接收均为8位数据,低位在先,高位在后。波特率固定fosc/12

串口方式1;10位数据一步通讯口,1起始,8数据,1停止,TXD(P3.1)为数据发送引脚,RXD(P3.0)为数据接收引脚。其传输波特率可变,对51而言,波特率有定时器1的溢出率而决定,一般而言,在单片基于单片机,单片机与计算机,计算机与计算机串口通讯时,基本都市选择方式1,所以此种方式必须掌握

串口方士2,3;11位数据的异步通讯口,XD(P3.1)为数据发送引脚,RXD(P3.0)为数据接收引脚。在这两种方式下,1起始,9数据,1停止,一帧数据11位。方式2的波特率固定为晶晶振频率的1/64或1/32,方式3的波特率由定时器1的溢出率决定。
方式2和方式2的差别仅在于波特率的选取不同,两种方式下,接收到的停止位与SBUF,RB8,RI都无关。

串口方式1的编程实现
方式1数据输出时序图如下:

当数据被写入SBUF寄存器后,单片机自动开始从起始位发送数据,发送到停止位的开始时,
由内部硬件将TI置1,向CPU申请中断,接下来可在中断服务程序中进行相关处理,也可选择不进入中断。

用软件置REN为1时,接收器以所选择波特率的16倍速率采样RXD引脚电平,
检测到RXD引脚输入电平发声负跳变时,则说明起始位有效。
将其移入输入移位寄存器并开始接受这一帧信息的其余位。

接收过程中,数据从输入移位寄存器右边移入,起始位移至输入移位寄存器的最左边,
控制电路进行最后一次移位,当RI=0且SM2=0(或结收到的停止位为1)时,
将接受到的9位数据前8位数据装入接收SBUF,第九位(停止位)进入RB8,并置RI=1,向CPU申请中断,

在进行串口的相关操作之前,需要对单片机的一些特殊寄存器和进行初始化设置
主要是设置产生波特率的定时器1,串行口控制和中断控制,具体步骤如下:
确定T1的工作方式(编程TMOD寄存器)
计算T1的初值,装载TH1和TL1
启动T1(编程TCON中的TR1位)
确定串行口工作方式(编程SCON寄存器)
串行口工作在中断方式时,要进行中断设置(编程IE、IP寄存器)


-----------------------------------------------------------------------------------------------------------------------
//串口方式1
TMOD=0X20;    //T1定时器,工作方式2
TH1=0XFD;    //T1定时器装初值
TL1=0XFD;    //T1定时器装初值
TR1=1;        //启动T1定时器
REN=1;        //允许串口接收
SM0=0;        //设定串口工作方式1
SM1=1;        //设定串口工作方式1
EA=1;        //开总中断
ES=1;        //开串口中断
-----------------------------------------------------------------------------------------------------------------------

-----------------------------------------------------------------------------------------------------------------------
//串口中断服务程序
void ser() interrupt 4
{
    RI=0;           //RI清零;因为收到数据或者或者发送了数据会由硬件置1
    a=SBUF;           //将SBUF中的数据读走给a
    flag=1;           //中断标志位置1
}
-----------------------------------------------------------------------------------------------------------------------

串口方式0
串行口为同步移位寄存器的输入输出方式,主要永不扩展并行输入输出接口,数据由RXD(P3.0)引脚输入或者输出,同步移位脉冲由TXD(P3.1)引脚输出,发送和接收均为8位数据,低位在先,高位在后。波特率固定fosc/12。

在该模式下,串行口的SBUF是作为同步移位寄存器使用的。
在串行口发送时。SBUF相当于一个并行进入,串行输出的移位寄存器,
由单片机的内部总线并行接收八位数据,并从RXD信号线串行输出,在接收操作时,他有相当于一个串行输入、并行输出的移位寄存器。该模式下,SM2,RB8,TB8不起作用。
方式0数据输出时序图如下:

发送操作在TI=0时进行,CPU将数据移入SBUF后,RXD线上即可发出8位数据,TXD上发送同步脉冲,
8位数据发送完后,TI由硬件置位,并在中断允许的情况下向CPU申请中断,
CPU相应中断后,先用软件是TI清零,然后再给SBUF送下一个需要发送的字符,如此重复上述过程。

方式0数据输入时序图如下:

接收过程在REN=1和RI=0的条件下启动,为此串行数据由RXD线输入,TXD线输出同步脉冲,
接收电路接收到8位数据后,RI自动置位并在中断允许的条件下向CPU发出中断请求,
CPU 查询到RI为1或者相应中断以后便将SBUF中的数据送到累加器,RI需要由软件复位,

需要注意的是:
串行口工作模式0并不是一个同步通讯串口通讯方式,
它的主要用途是与外面的同步移位寄存器相连已达到扩展单片机输入并行口和输出并行口的目的。
其可以通过芯片(74LS164)把串口数据转化成并口数据,通过芯片(74LS165)把并行输出的数据转换成串口输出

-----------------------------------------------------------------------------------------------------------------------
使用串口工作模式0间隔发送数据0XAA
void main()
{
    SCON=0;               //串行口工作方式0
    EA=1;            //开总中断
    ES=1;            //允许串口中断
    TI=0;            //发送中断标志位
    while(1)
    {
        SBUF=0XAA;   
        delay();
    }
}
-----------------------------------------------------------------------------------------------------------------------

-----------------------------------------------------------------------------------------------------------------------
void ser0() interrupt 4
{
    TI=0;        //清楚发送中断标志位
}
-----------------------------------------------------------------------------------------------------------------------

串口方式2和方式3
均为11位数据的异步通信口,唯一的区别在于传输速率的不同。
TXD数据发送引脚,RXD数据接收引脚,1起始,
9数据(含1位附加第9位,发送时为SCON中的TB8,接收时为RB8),1停止,一帧数据11位。
方式2的波特率固定为晶晶振频率的1/64或1/32,方式3的波特率由定时器1的溢出率决定。

串口方式2和方式3一帧数据传送格式,如图:


串口方式2和方式3输出时序图:

发送开始时,先把起始位0输出到TXD管脚,然后发送移位寄存器的的输出位(D0)到TXD引脚
每一个移位脉冲都使输出移位寄存器的各位右移一位,并由TXD引脚输出,
第一次移位时,停止位1移入输出移位寄存器的第9位,以后每次移位,左边都输入0
当停止移位至输出位时,左边其余位全为零,检测电路检测到这一条件时,使控制电路进行最后一次移位,并置TI=1;向CPU请求中断。

串口方式2和方式3输入时序图:

接受时,数据从右边移入输入移位寄存器,在起始位0移到最左边时,控制电路进行最后一次移位。
当RI=0且SM2=0(或接收到第9位数据位1)时,接收到的数据装入接收缓冲器SBUF和RB8(接收数据的第9位),置RI=1,向CPU申请中断,如果条件不满足,则数据丢失,且不置位RI,继续搜索RXD引脚的负跳变。

在方式2和方式3中,要用到SCON寄存器中的TB8位和RB8位,TB8为数据发送的第9位,用于方式2和方式3,由软件更改,RB8为数据接收的第9位,用于方式2和方式3,在方式1中,如果SM2=0,则RB8用于存放接收到的停止位,在方式0下不适用该位。

-----------------------------------------------------------------------------------------------------------------------
使用串口工作方式2发送0XAA
void main()
{
    SM0=1;            //SMOSM1为10,串行工作方式2
    SM1=0;            //11位异步收发(9位数据)
    TB8=0;            //数据发送的第9位
    EA=1;            //开总中断
    ES=1;            //允许串口中断
    TI=0;            //发送中断标志位
    while(1)
    {
        SBUF=0XAA;   
        delay();
    }
}
-----------------------------------------------------------------------------------------------------------------------

-----------------------------------------------------------------------------------------------------------------------
void ser0() interrupt 4
{
    TI=0;        //清楚发送中断标志位
}
-----------------------------------------------------------------------------------------------------------------------

单片机双机通信
通常单片机通信有以下四种实现方式:
TTL电平通信
RS-232C通信
RS-422A通信
RS-485通信

TTL电平通信:


RS-232C通信:


RS-422A通信
RS-422A驱动器为双端驱动器,其中一条线的逻辑为1,另一条线就为0,
具抗干扰型,能够200mv以上的电位差,
传输速率90Kbps,传输距离可达1200m,接口电路如下:(全双工)


RS-485通信
RS-485是RS-422A的变种,422A是全双工,485为半双工,
最多可使用32对差分器。如在一个网络中连接超过32个,还可使用中继器。
引起传输线采用差动信号,所以抗干扰性好,传输速率可达1Mbps,接口如下:


多机通信
采用主从结构,在整个系统中,有且仅有一个主机,其余全是从机,多机通信所应遵循的原则如下:
A.所有从机的SM2=1;处于接收地址帧状态
B.主机发送一地址帧,其中8位是地址,第9位是地址/数据区分标志,该位置1表示地址帧。
所有从机收到地址帧后,与本季的地址比较,对于地址相符的从机,
是自己的SM2置0(已接收主机随后发来的数据帧),并把本机地址发回主机作为应答,
对于地址不符的,仍保持SM2=1,对主机随后发来的数据帧不予理睬.

C.从机发送数据结束后,要发送一帧校验和,并置第9位(TB8)为1,作为从机数据结束的标志。
D.主机验证数据时,先判断数据接收标志(RB8),若RB8=1;表示数据传送结束,并比较此帧校验和,
若正确则会送正确信号00H,命令该从机复位(即重新等待地址帧)。
若校验和出错,则发送0FFH,命令该从机重发数据。
若接受侦的RB8=0;则将数据存到缓存区,并准备接收下一帧信息。

E.主机接到从机应答地址后,确认地址是否相符,如果地址不符,
则发复位信号(数据帧中TB8=1),如果地址相符,则TB8清0,开始发送数据。

从机收到复位命令后,会到监听地址状态(SM2=1),否则开始接收数据和命令。
编程时,可按以下方式操作:
主机发送的地址联络信号为00H,01H,02H,...(即从机设备地址);地址FFH为命令各从机复位,即回复SM2=1;
主机命令编码如下:
01H:主机命令从机接收数据;
02H:主机命令从机发送数句;
若有其他数据,则都按02H对待。

从机状态字格式如图:

若ERR =1;从机收到非法命令。
若TRDY=1;从机发送准备就绪
若RRDY=1;从机接收准备就绪

通常,从机以中断方式控制和主机通讯。

多机通信主机流程图如下:


程序代码如下:
-----------------------------------------------------------------------------------------------------------------------
#include
#define  uchar unsigned char
#define uint unsigned int
#define SLAVE 0X02   //从机地址
#define  NB 16

uchar rbuf[16];
uchar code tbuf[16]={"master transmit"};

void err()
{
    SBUF=0XFF;
    while(!TI=1);
    TI=0;
}
-----------------------------------------------------------------------------------------------------------------------

-----------------------------------------------------------------------------------------------------------------------
uchar master(uchar add,uchar com)
{
    while(1)
    {
        SBUF=SLAVE;            //发呼叫地址
        while(!TI=1);
        TI=0;
        while(!RI=1);
        RI=0;                //等待从机应答
        if(SBUF!=add)
        {
            err();            //地址错误,发复位信号
        }         
        else                //地址相符
        {
            TB8=0;            //清地址标志
            SBUF=cmd;        //发命令
            while(!TI=1);
            TI=0;
            while(!RI=1);
            RI=0;
            aa=SBUF;        //接收状态
            if(aa&0x08==0x08)        //若命令未被接收,发复位信号
            {
                TB8=1;
                err();
            }
            else
            {
                if(cmd==0X01)          //发送命令
                {
                    if(aa&0x01==0x01)     //从机准备好接受
                    {
                        do
                        {
                            p=0;              //清校验和
                            for(i=0;i
                            {
                                SBUF=tbuf[i];    //发送一数据
                                p+=tbuf[i];
                                while(!TI=1);
                                TI=0;
                            }
                            SBUF=p;            //发送检验和
                            while(!TI=1);
                            TI=0;
                            while(!RI=1);
                            RI=0;
                        }
                        while(SBUF!=0);        //接收不正确,重新发送
                        TB8=1;                //置地址标志
                        return(0);
                    }
                    else
                    if(aa&0x02==0x02)        //是接收命令,从机准备好发送
                    {
                        while(1)
                        {
                            p=0;        //清检验和
                            for(i=0;i
                            {
                                while(!RI=1);
                                RI=0;
                                rbuf[i]=SBUF;        //接收一数据
                                p+=rbuf[i];
                            }
                            while(!RI=1);
                            RI=0;
                            if(SBUF==p)
                            {
                                SBUF=0x00;            //校验和相同发0X00
                                while(!TI=1);
                                TI=0;
                                break;
                            }
                            else
                            {
                                SBUF=0xFF;
                                while(!TI=1);
                                TI=0;
                            }
                        }
                        TB8=1;              //置地址标志
                        return(0);
                    }
                }

            }
        }
    }

}
-----------------------------------------------------------------------------------------------------------------------

-----------------------------------------------------------------------------------------------------------------------
void main()
{
    TMOD=0x20;    //T/C1定义为方式2
    TL1=0XFD;    //置初值
    TH1=0XFD;
    PCON=0X00;
    TR1=1;
    SCON=0XF0;    //串行口方式3
    master(SLAVE,0x01);
    master(SLAVE,0X02);
    while(1);
}
-----------------------------------------------------------------------------------------------------------------------

-----------------------------------------------------------------------------------------------------------------------
多机通信从机流程图:


程序如下:
-----------------------------------------------------------------------------------------------------------------------
#include
#define uchar unsigned char
#define uint unsigned int
#define  SLAVE 0X02
#define BN  16

uchar trbuf[16];
uchar rebuf[16];
bit tready;
bit rready;

void str(void);
void sre(void);

void main()
{
     TMOD=0x20;            //T/C1定义为方式2
    TH1=0XFD;
    TL1=0XFD;
    PCON=0X00;
    TR1=1;
    SCON=0XF0;
    ES=1;     //开串行口中断
    EA=1;     //开总中断

    while(1)
    {
        tready=1;
        rready=1;   
    }         //假定准备好发送和接受
}
-----------------------------------------------------------------------------------------------------------------------

-----------------------------------------------------------------------------------------------------------------------
void ssio(void) interrupt 4
{
    uchar a;
    RI=0;
    ES=0;
    if(SBUF!=SLAVE)
    {
        ES=1;
        goto reti;
    }                      //非本机地址继续监听
    SM2=0;                //取消监听状态
    SBUF=SLAVE;            //从本地址发回
    while(!TI=1);
    TI=0;
    while(!RI=1);
    RI=0;
    if(RB8=1)
    {
        SM2=1;
        ES=1;
        goto reti;
    }                      //是复位信号,恢复监听
    a=SBUF;                //接收命令
    if(a==0X01)
    {
        if(rready=1)
            SBUF=0X01;        //接收准备好发状体
        else
            SBUF=0X00;
        while(!TI=1);
        TI=0;
        while(!RI=1);
        RI=0;
        if(RB8==1)
        {
            SM2=1;
            ES=1;
            goto reti;
        }
        sre();            //接收数据
    }
    else
    {
        if(a==0X02)            //从机向主机发送数据
        {
            if(tready=1)
                SBUF=0X02;        //发送准备好发状体
            else
                SBUF=0X00;
            while(!TI=1);
            TI=0;
            while(!RI=1);
            RI=0;
            if(RB8==1)
            {
                SM2=1;
                ES=1;
                goto reti;
            }
            str();            //发送数据
        }
        else
        {
            SBUF=0X80;            //命令非法,发状态
            while(!TI=1);
            TI=0;
            SM2=1;
            ES=1;             //恢复监听
        }   
    }
    reti;
}
-----------------------------------------------------------------------------------------------------------------------

-----------------------------------------------------------------------------------------------------------------------
void str(void)            //发送数据块
{
    uchr p,i;
    tready=0;
    do
    {
        p=0;        //清校验和
        for(i=0;i
        {
            SBUF=trbuf[i];            //发送一数据
            p+=trbuf[i];
            while(!TI=1);
            TI=0;
        }
        SBUF=p;             //发送校验和
        while(!TI=1);
        TI=0;
        while(!RI=1);
        RI=0;
    }while(SBUF!=0);        //主机接收不正确,从新发送
    SM2=1;
    ES=1;   
}
-----------------------------------------------------------------------------------------------------------------------

-----------------------------------------------------------------------------------------------------------------------
void sre(void)                  //接收数据块
{
    uchr p,i;
    rready=0;
    while(1)
    {
        p=0;        //清校验和
        for(i=0;i
        {
            while(!RI=1);
            RI=0;
            rebuf[i]=SBUF;        //接收数据
            p+=rebuf[i];
        }
        while(!RI=1);
        RI=0;
        if(SBUF==p)
        {
            SBUF=0X00;
            break;
        }          //校验和相同发00
        else
        {
            SBUF=0XFF;           //校验值不同发0FF,重新接收
            while(!TI=1);
            TI=0;
        }
    }
    SM2=1;
    ES=1;       
}
-----------------------------------------------------------------------------------------------------------------------

以上是51串口的通讯的协议内容,也可以说是串口通讯协议。其与Uart等具有相同的传输性质:双向传输,全双工!

转载于:https://www.cnblogs.com/hulianxingkong/p/9096733.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/427651.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计算机四级考试题数据库,计算机四级考试《数据库系统工程师》试题及答案

计算机四级考试《数据库系统工程师》试题及答案计算机四级备考工作正在火热进行中,为帮助考生们更好地复习备考,以下是百分网小编搜索整理的一份计算机四级考试《数据库系统工程师》试题及答案,供参考练习,预祝考生们考出自己理想…

二层环路保护,RRPP多环的配置

作者:邓聪聪 组网需求: 局域网中,由A/B/C/D构成RRPP域1换网络结构,要求环网机构中的任意两条线路中断都不能影响业务。 配置思路: 环路由两部分组成,ring1、ring2,B为环1的主节点,G0/0/2为主端口…

如图所示是一种轧钢计算机控制系统,高速线材厂轧钢工艺培训(活套)

原标题:高速线材厂轧钢工艺培训(活套)活套现代高速线材轧机为保证产品尺寸精度,采用微张力及无张力轧制,以消除轧制过程中各种动态干扰引起的张力波动和由此引起的轧件尺寸波动。由于精轧机组为集体传动,故精轧采用微张力轧制&…

Linux服务部署之NTP时间服务器

Linux服务部署之NTP时间服务器: 服务器端IP:192.168.11.119 client端Ip: 192.168.11.101 先安装服务器端ntp: 首先先查看是否安装了ntp时间服务器; ~]# rpm -q ntp >查看是否安装了ntp服务器; 如果没有,安装服务器…

Dubbo架构设计详解

Dubbo是Alibaba开源的分布式服务框架,它最大的特点是按照分层的方式来架构,使用这种方式可以使各个层之间解耦合(或者最大限度地松耦合)。从服务模型的角度来看,Dubbo采用的是一种非常简单的模型,要么是提供…

new 3ds右摇杆测试软件,电击杂志编辑新3DS评测:防抖3D效果拔群!

电击杂志日前在本周杂志上看在了10月11日任天堂将会发售新型3DS主机“新3DS”与“新3DS LL”的上手报告。究竟新版3DS表现如何?让我们一窥究竟。新3DS与新3DS LL“新3DS”与“新3DS LL”是于8月29日配信的“任天堂8月29日3DS直面会”中发表的,主要特点是…

计算机cad比例尺1 150,CAD图纸里面 1:50 和:1:100和1:150三个比例分别怎么换算...

CAD图纸里面 1:50 和:1:100和1:150三个比例分别怎么换算以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!CAD图纸里面 1:50 和&…

Thread类学习(一)

Thread类API中的英文描述: file:///D:/Java/JDK8/Docs/docs/api/index.html 英语不好,大致的意思是: 线程是程序执行时的线程,java虚拟机(JVM)允许一个应用运行多个线程(并发)。 每一个线程都自己的优先权,优先级高的线…

做企业网站为什么要服务器呢,企业为什么要建站?

一、企业建站为何要建立自己的网站1、企业建站的第1个好处就是树立企业形象酒香不怕巷子深,说的就是线下企业经营时以自身企业形象带来的效果,但企业在网上经营活动时,一方面没有大量老客户支援,另一方面陌生人也没有信任感&#…

[转]Oh My Zsh,安装,主题配置

https://swp-song.com/2017/08/20/Tools/OhMyZsh%E5%AE%89%E8%A3%85%E5%92%8C%E4%B8%BB%E9%A2%98%E9%85%8D%E7%BD%AE%E6%96%B9%E6%B3%95/ Oh MyZsh 是什么 Oh My Zsh 它是基于 zsh 命令行的一个扩展工具集,驱动的命令行工具,提供了主题配置 / 插件机制 /…

Linux系统运维成长记

2017年秋天,大一入学,由于高考分数没有达标计算机专业于是被调剂到了土木工程专业。起初大家一起上课下课感觉不到什么变化,但是随着时间的流逝,日子久了,我越发觉得这样的生活毫无乐趣。我的主要兴趣在计算机方面&…

手把手教你撸一个简易的 webpack

背景 随着前端复杂度的不断提升,诞生出很多打包工具,比如最先的grunt,gulp。到后来的webpack和Parcel。但是目前很多脚手架工具,比如vue-cli已经帮我们集成了一些构建工具的使用。有的时候我们可能并不知道其内部的实现原理。其实…

centos7.3下apache搭建django[未成功]

centos7.3下apache搭建django[未成功] 1 apache肯定已经按照完毕了, 如果没有 yum install httpd yum install mod_wsgi 安装完成之后,mod_wsgi.so会在Apache的modules目录中, 2 在httpd.conf文件中添加以下内容  LoadModule wsgi_module modules/mod…

排序算法入门之冒泡排序

分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!在开发中,对一组数据进行有序地排…

VMware12.0下安装CentOS-6.9-x86_64-bin-DVD.iso

使用的是vmware workstation 12 pro 创建虚拟机 注意上面的 安装程序光盘镜象文件(iso)(M): 是我之前配置,现在可以不做任何处理 此处使用的是centos的64位 在创建虚拟机存在的地方是D:\vmware\redis,因为我准备在这装redis集群&a…

判断回文字符串

分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!《递归入门》所谓回文字符串,就是…

matplotlib 中文显示 的问题

第一种方法 from pylab import mpl import numpy as npmpl.rcParams[font.sans-serif] [SimHei] # 指定默认字体 mpl.rcParams[axes.unicode_minus] False # 解决保存图像是负号 - 显示为方块的问题 %pylab inline t np.arange(-5 * np.pi, 5 * np.pi, 0.01) y np.sin…

排序算法入门之冒泡排序优化

分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!这篇文章是对上一篇文章中的冒泡排序进行优化…

递归入门 斐波那契数列

分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!《递归入门》斐波那契数列百度百科斐波那契数…

用栈解决四则运算问题

分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!本文章的解决方法参考了《大话数据结构》中关…