ESP8266 串口接收数据,当接收的数据中包含0xFF的时候,这个字节后的数据会被分成两次接收,如何解决? 5C

ESP8266 串口接收随机数据,当接收的数据中包含0xFF的时候,这个字节后的数据有时候被分开,由于我发现了其实是触发两次 uart_recvTask(os_event_t *events) _这个函数来处理数据,由此实际上是触发了两次接收中断

例如我往ESP8266的串口发送
01 02 03 FF FF 00 37 12 53 75 12 73 57 12 FF FF 52 73 57 12 53 71 25 73 01 0F
这样子一组26个byte数据

然后ESP8266可能只接收到 01 02 03 FF 然后再次触发uart_recvTask(os_event_t *events) _来接收剩下的数据

这种情况不是每次都会发生,有时候会分成两次接收数据,有时候能一次性的接收完成的数据

这种问题该如何解决?

1个回答

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
ESP8266-SDK 串口中断 当串口接收到连续两个0xFF的时候,会触发多次中断,如何避免?

* 我们知道当串口接收到数据的时候,会触发串口中断,触发串口中断后会在 ``` LOCAL void uart0_rx_intr_handler(void *para) ``` 这个函数中处理数据,我们在这个函数中首先计算FIFO中接收到的数据长度,然后打印出FIFO的长度 ``` uint8 fifo_len = (READ_PERI_REG(UART_STATUS(UART0))>>UART_RXFIFO_CNT_S)&UART_RXFIFO_CNT; os_printf("fifo_len: %d !!!!!!!!!\r\n",fifo_len); ``` 此时例如发送如下数据 (26byte 16进制) 01 02 03 00 FF FF 37 12 53 75 12 FA AA 12 AA AA 52 73 57 12 53 AA AA 73 01 0F 可能接收数据的时候会分成两次接收,即触发了两次串口中断,一次中断接收01 02 03 FF FF ,然后再一次中断接收37 12 53 75 12 FA AA 12 AA AA 52 73 57 12 53 AA AA 73 01 0F ,因为从打印结果如下! ![图片说明](https://img-ask.csdn.net/upload/201811/05/1541386155_139747.jpg) 可以看到有时候fifo_len为完整的26个byte;而有时候则打印则连续两次,这说明 ``` LOCAL void uart0_rx_intr_handler(void *para) ``` 被执行了两次,即串口中断被触发了两次 此时我们将数据中的两个连续的 FF FF改成其他数据,例如改成12 23,即改接收如下数据 01 02 03 00 12 23 37 12 53 75 12 FA AA 12 AA AA 52 73 57 12 53 AA AA 73 01 0F 此时,就不会再出现中断被触发两次的情况,但是发送数据连续两个 FF FF也是不可避免的,要怎么解决这个问题,即使发送两个 FF FF也只触发一次中断??

C51串口中断接收多字节数据,并解析数据,问题是不能解析,哪错了?

#include<reg52.h> #include<math.h> #include<intrins.h> #define uchar unsigned char #define uint unsigned int uchar code SZDLJ[13]={0x41,0x54,0x2B,0x43,0x49,0x50,0x4D,0x55,0x58,0x3D,0x31,0x0D,0x0A};//AT+CIPMUX=1 uchar code KQFU[21]={0x41,0x54,0x2B,0x43,0x49,0x50,0x53,0x45,0x52,0x56,0x45,0x52,0x3D,0x31,0x2C,0x38,0x30,0x38,0x30,0x0D,0x0A};//AT+CIPSERVER=1,8080 uint URTAReceivedCount=0,n=1; //用于串口中断子函数中计数 uchar data Tempdatatable[5],CommandDatatable[5]; //定义临时数组和用于调用控制动作的数组 /***************************************************** 函数功能:延时若1ms *******************************************************/ void Delay_1ms(uint i) { uint x,j; for(j=0;j<i;j++) for(x=0;x<=148;x++); } /***************************************************** 函数:往串口发送数据 功能:只用于设定wifi模块 ***************************************************/ void SendData(uchar *sdata,int num) { int i; for(i=0;i<num;i++) { SBUF=sdata[i]; Delay_1ms(2); } } /******************************************************************** * 函数 :Moto_Forward() * 功能 :前进 ***********************************************************************/ void Moto_Forward() { P1= 0x0a; Delay_1ms(100); } /******************************************************************** * 函数 :Moto_Backward() * 功能 :后退 ***********************************************************************/ void Moto_Backward() { P1= 0x05; Delay_1ms(100); } /******************************************************************** * 函数 :Moto_TurnLeft() * 功能 :左转 ***********************************************************************/ void Moto_TurnLeft() { P1= 0x09; Delay_1ms(100); } /******************************************************************** * 函数 :Moto_TurnRight() * 功能 :右转 ***********************************************************************/ void Moto_TurnRight() { P1= 0x06; Delay_1ms(100); } /******************************************************************** * 函数 :Moto_Stop() * 功能 :停止 ***********************************************************************/ void Moto_Stop() { P1= 0x00; Delay_1ms(100); } /**************************************************************************** 函数:主函数 功能:初始化串口,并从串口发送指令到wifi模块用于设置模块,再使能中断, 再进入while循环,解析从串口收到的数据 *****************************************************************************/ void main(void) { Delay_1ms(3000); TMOD=0x21; //TMOD=0010 0001B,定时器T1工作于方式2 SCON=0x50; //SCON=0101 0000B,串口工作方式1 1起始位8数据位1停止位 PCON=0x00; //PCON=0000 0000B,波特率9600 晶振11.0592 TH1=0xFd; //根据规定给定时器T1赋初值 TL1=0xFd; //根据规定给定时器T1赋初值 TR1=1; //启动定时器T1 SendData(SZDLJ,13); //设置多连 Delay_1ms(3000); SendData(KQFU,21); //开启server端 Delay_1ms(8000); ES = 1; //串口中断使能 EA = 1; //开总中断 while(1) //一直循环直到中断产生,跳进中断执行中断子函数,完后再回到循环并解析数据,等待下次中断到来 { if(CommandDatatable[0]==0xFF&&CommandDatatable[4]==0XFF) { switch(CommandDatatable[1]) { case 0x00: switch(CommandDatatable[2]) { case 0X00:Moto_Stop();break; case 0X01:Moto_Forward();break; case 0X02:Moto_Backward();break; case 0X03:Moto_TurnLeft();break; case 0X04:Moto_TurnRight();break; default : break; } default: break; } } } } /***************************************************************************** 函数:串口中断子函数 功能:接收串口数据,组包成类 “0XFF 0X00 0X01 0X02 0XFF” 的数组,用于主函数解析,包头和包尾都是0XFF,的5元数组 ******************************************************************************/ void Com_Int(void) interrupt 4 { uchar temp; ES=0; RI=0; temp=SBUF; if(temp==0XFF && URTAReceivedCount<3) { Tempdatatable[0]==0XFF; URTAReceivedCount++; } else { Tempdatatable[n]=temp; n++; if(URTAReceivedCount==0&&n==2) n=1; } if(URTAReceivedCount==2) { Tempdatatable[0]=0XFF; Tempdatatable[4]=0XFF; n=1; URTAReceivedCount=0; temp=""; } CommandDatatable[0]=Tempdatatable[0]; CommandDatatable[1]=Tempdatatable[1]; CommandDatatable[2]=Tempdatatable[2]; CommandDatatable[3]=Tempdatatable[3]; CommandDatatable[4]=Tempdatatable[4]; ES=1; } 串口助手给MCU发16进制类似“FF 00 01 02 FF”数时,不能正确解析

stc io模拟串口接收端

stc12c5a60s2 io模拟串口接收端(Rxd)接收波特率1200bps的数据,在通过单片机实际串口1以波特率9600bps发送到上位机,出现问题只有串口一发送1200bps才能得到正确地数据!求哪里出问题啦 ``#include <reg52.h> #include<stdio.h> #include<string.h> typedef unsigned char uchar; #define F11_0592 uchar tmpbuf2[64]={0}; //用来作为模拟串口接收数据的缓存 struct { uchar recv :6; //tmpbuf2数组下标,用来将模拟串口接收到的数据存放到tmpbuf2中 uchar send :6; //tmpbuf2数组下标,用来将tmpbuf2中的数据发送到串口 }tmpbuf2_point={0,0}; sbit newRXD=P2^2; ////模拟串口的接收端设为P2.2 void UartInit() { SCON=0x50 ; // SCON: serail mode 1, 8-bit UART TMOD|=0x20 ; // TMOD: timer 1, mode 2, 8-bit reload,自动装载预置数(自动将TH1 送到TL1);T0工作在方式1,十六位定时 PCON|=0x80; // SMOD=1 TH1=0xa0; // Baud:9600 fosc=11.0592MHz 9600bps为从串口接收数据的速率 TL1=0xa0; // 计数器初始值,fosc=11.0592MHz 因为TH1一直往TL1送,所以这个初值的意义不大 TR1=1; // 启动TIMER1,用于产生波特率 TH0=0xFF; // 定时器0初始值,延时104us,目的是令模拟串口的波特率为9600bps TL0=0xA0 ; // 定时器0初始值,延时104us,目的是令模拟串口的波特率为9600bps TF0 = 0; //清除TF0标志 IT0=1 ; //设置外部中断0为边沿触发方式 //TR0=1; } void WaitTF0(void) { TF0=0; while(!TF0); TF0=0 ; //TH0=0xFF; // 定时器重装初值 模拟串口的波特率为9600bps fosc=11.0592MHz // TL0=0xA0; // 定时器重装初值 模拟串口的波特率为9600bps fosc=11.0592MHz } uchar RByte() { uchar Output=0; uchar i=8 ; // TR0=1 ; //启动Timer0 TH0=0xFF; // 定时器重装初值 模拟串口的波特率为9600bps fosc=11.0592MHz TL0=0xA0; // 定时器重装初值 模拟串口的波特率为9600bps fosc=11.0592MHz TF0=0; WaitTF0();//等过起始位 //接收8位数据位 while(i--) { Output>>=1; if(newRXD)Output|=0x80; //先收低位 WaitTF0();//位间延时 } // while(!TF0) if(newRXD) break; //此句和下一句不能加,如果加上了将导致耗时过长,影响下一个字节的接收 // // WaitTF0(); // TR0=0; //停止Timer0 return Output ; } //向COM1发送一个字符 void SendChar(uchar byteToSend)// void SendChar(uchar byteToSend) { SBUF=byteToSend ; while(!TI); TI=0; } void main() { UartInit(); Timer0Init(); while(1) { if(tmpbuf2_point.recv!=tmpbuf2_point.send)//差值表示模拟串口接收数据缓存中还有多少个字节的数据未被处理(发送至串口) { SendChar(tmpbuf2[tmpbuf2_point.send++]); } } } //外部中断0,说明模拟串口的起始位到来了 void Simulated_Serial_Start()interrupt 0 { EX0=0 ; //屏蔽外部中断0 tmpbuf2[tmpbuf2_point.recv++]=RByte();//从模拟串口读取数据,存放到tmpbuf2数组中 IE0=0; //防止外部中断响应2次,防止外部中断函数执行2次 EX0=1 ; //打开外部中断0 }

java的rxtx串口通信怎么接收16进制数据

package Cilent; import gnu.io.CommPortIdentifier; import gnu.io.NoSuchPortException; import gnu.io.PortInUseException; import gnu.io.SerialPort; import gnu.io.SerialPortEvent; import gnu.io.SerialPortEventListener; import gnu.io.UnsupportedCommOperationException; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.util.Enumeration; import java.util.Timer; import java.util.TimerTask; import java.util.TooManyListenersException; import javax.print.attribute.standard.PrinterMessageFromOperator; public class SendTest implements SerialPortEventListener{ protected static CommPortIdentifier portid = null; //通讯端口标识符 protected static SerialPort comPort = null; //串行端口 protected int BAUD = 9600; //波特率 protected int DATABITS = SerialPort.DATABITS_8;; //数据位 protected int STOPBITS = SerialPort.STOPBITS_1; //停止位 protected int PARITY = SerialPort.PARITY_NONE; //奇偶检验 private static OutputStream outputStream; //输出流 private static InputStream inputStream; //输入流 private static byte[] readBuffer = new byte[1024]; // 4k的buffer空间,缓存串口读入的数据 StringBuilder buf = new StringBuilder(128); public static void main(String[] args) { SendTest my = new SendTest(); my.setSerialPortNumber(); sendMsg(); } //读取所有串口 private void listPortChoices() { CommPortIdentifier portId; Enumeration en = CommPortIdentifier.getPortIdentifiers(); // iterate through the ports. while (en.hasMoreElements()) { portId = (CommPortIdentifier) en.nextElement(); if (portId.getPortType() == CommPortIdentifier.PORT_SERIAL) { System.out.println(portId.getName()); } } } //设置串口号 private void setSerialPortNumber() { String osName = null; String osname = System.getProperty("os.name", "").toLowerCase(); if (osname.startsWith("windows")) { // windows osName = "COM1"; } System.out.println(osName); try { portid = CommPortIdentifier.getPortIdentifier(osName); // portid = CommPortIdentifier.getPortIdentifier(Port); if(portid.isCurrentlyOwned()){ System.out.println("端口在使用"); }else{ comPort = (SerialPort) portid.open(this.getClass().getName(), 1000); } } catch (PortInUseException e) { System.out.println("端口被占用"); e.printStackTrace(); } catch (NoSuchPortException e) { System.out.println("端口不存在"); e.printStackTrace(); } try { inputStream = comPort.getInputStream(); //从COM1获取数据 outputStream = comPort.getOutputStream(); } catch (IOException e) { e.printStackTrace(); } try { comPort.addEventListener(this); //给当前串口增加一个监听器 comPort.notifyOnDataAvailable(true); //当有数据是通知 } catch (TooManyListenersException e) { e.printStackTrace(); } try { //设置串口参数依次为(波特率,数据位,停止位,奇偶检验) comPort.setSerialPortParams(this.BAUD, this.DATABITS, this.STOPBITS, this.PARITY); } catch (UnsupportedCommOperationException e) { System.out.println("端口操作命令不支持"); e.printStackTrace(); } } //将输入的16进制string转成字节 public static byte[] hexStringToBytes(String hexString) { if (hexString == null || hexString.equals("")) { return null; } hexString = hexString.toUpperCase(); int length = hexString.length() / 2; char[] hexChars = hexString.toCharArray(); byte[] d = new byte[length]; for (int i = 0; i < length; i++) { int pos = i * 2; d[i] = (byte) (charToByte(hexChars[pos]) << 4 | charToByte(hexChars[pos + 1])); } return d; } private static byte charToByte(char c) { return (byte) "0123456789ABCDEF".indexOf(c); } //向串口发送信息方法 public static void sendMsg(){ String msg="71340001";//要发送的命令msg try { outputStream.write(hexStringToBytes(msg)); } catch (IOException e) { e.printStackTrace(); } } //字节转换成十六进制字符串 public static String bytesToHexString(byte[] src){ StringBuilder stringBuilder = new StringBuilder(""); if (src == null || src.length <= 0) { return null; } for (int i = 0; i < src.length; i++) { int v = src[i] & 0xFF; String hv = Integer.toHexString(v); if (hv.length() < 2) { stringBuilder.append(0); } stringBuilder.append(hv); } return stringBuilder.toString(); } @Override public void serialEvent(SerialPortEvent event) { switch (event.getEventType()) { case SerialPortEvent.BI://Break interrupt,通讯中断 case SerialPortEvent.OE://Overrun error,溢位错误 case SerialPortEvent.FE://Framing error,传帧错误 case SerialPortEvent.PE://Parity error,校验错误 case SerialPortEvent.CD://Carrier detect,载波检测 case SerialPortEvent.CTS://Clear to send,清除发送 case SerialPortEvent.DSR://Data set ready,数据设备就绪 case SerialPortEvent.RI://Ring indicator,响铃指示 case SerialPortEvent.OUTPUT_BUFFER_EMPTY: break; case SerialPortEvent.DATA_AVAILABLE:// 当有可用数据时读取数据,并且给串口返回数据 try { // 多次读取,将所有数据读入 while (inputStream.available() > 0) { System.out.println("接收数据:"+((byte) inputStream.read())); } } catch ( IOException e ) { e.printStackTrace(); } break; } } } 各位大神,现在做的项目是往cpld发送指令控制,发送16进制的指令需要接收cpld返回的16进制数据判断指令是否正确执行,这是按照网上的例子写的,现在解决了发送指令,但是接收部分不知道如何接收16进制的返回数据,用串口调试助手往com1发送16进制数据只能显示2位的10进制,请问如何将接收的16进制数据正确显示出来,新手实在没办法了

C++如何接受串口返回的数据

void CNewTestDlg::OnStart() { // 55 55 00 00 00 00 00 00 00 00 00 00 00 00 00 00 FF 03 FD D4 14 01 17 00 CByteArray SendTemp,hexdata; COleSafeArray safearray_inp; CString strtemp; SendTemp.SetSize(24); SendTemp.SetAt(0,0x55); SendTemp.SetAt(1,0x55); SendTemp.SetAt(2,0x00); SendTemp.SetAt(3,0x00); SendTemp.SetAt(4,0x00); SendTemp.SetAt(5,0x00); SendTemp.SetAt(6,0x00); SendTemp.SetAt(7,0x00); SendTemp.SetAt(8,0x00); SendTemp.SetAt(9,0x00); SendTemp.SetAt(10,0x00); SendTemp.SetAt(11,0x00); SendTemp.SetAt(12,0x00); SendTemp.SetAt(13,0x00); SendTemp.SetAt(14,0x00); SendTemp.SetAt(15,0x00); SendTemp.SetAt(16,0xFF); SendTemp.SetAt(17,0x03); SendTemp.SetAt(18,0xFD); SendTemp.SetAt(19,0xD4); SendTemp.SetAt(20,0x14); SendTemp.SetAt(21,0x01); SendTemp.SetAt(22,0x17); SendTemp.SetAt(23,0x00); m_ctrlComm.SetOutput(COleVariant(SendTemp)); } 然后怎么写才能接收串口返回的数据?本人小白,谢谢各位大神了

nrf2401接收数据后状态寄存器STATUS值为0X0E是怎么回事

发送完全正常,但接收不到 接收部分代码: unsigned char nRF24L01_RxPacket(unsigned char* rx_buf) { unsigned char revale=0; u8 status; //sta=SPI_Read(STATUS); // 读取状态寄存其来判断数据接收状况 status=SPI_Read(READ_REG1+STATUS); // 读取状态寄存其来判断数据接收状况 if(status & 0x40) // 判断是否接收到数据 { MODE_CE(0); //SPI使能 //SPI_Read_Buf(RD_RX_PLOAD,rx_buf,TX_PLOAD_WIDTH);// read receive payload from RX_FIFO buffer SPI_Read_Buf(RD_RX_PLOAD,rx_buf,TX_PLOAD_WIDTH); //从接收缓冲区里读出数据 //rx_buf[1]=1; revale =1; //读取数据完成标志 } //SPI_RW_Reg(WRITE_REG+STATUS,sta); //接收到数据后RX_DR,TX_DS,MAX_PT都置高为1,通过写1来清楚中断标志 SPI_RW_Reg(WRITE_REG1+STATUS, status); //清除07寄存器标志 return revale; }

android 串口通信读取数据,处理问题?求大神帮忙

下面这段代码是我接收串口数据的 private class ReadThread extends Thread { @Override public void run() { super.run(); while (!isInterrupted()) { int size; try { byte[] buffer = new byte[30]; if (mInputStream == null) return; mInputStream.read(buffer); //根据数据协议规则,判断每条数据的长度 size=Integer.parseInt(Integer.toHexString(buffer[2]))+3; if (size > 3) { onDataReceived(buffer, size); //调用更新UI方法 } } catch (IOException e) { e.printStackTrace(); return; } } } } 下来的截图是我处理UI的。 void onDataReceived(final byte[] buffer, final int size) { // TODO Auto-generated method stub MainActivity.this.runOnUiThread(new Runnable() { @Override public void run() { // TODO Auto-generated method stub String reString=""; if (mReception!=null) { for (int i = 0; i <size; i++) { String hexString=Integer.toHexString(buffer[i]&0xFF); if (hexString.length()==1) { hexString='0'+hexString; } reString+=hexString.toUpperCase(); } mReception.append(reString+"\r\n"); Toast.makeText(getApplicationContext(), "接收成功"+reString, Toast.LENGTH_SHORT).show(); Intent intent=new Intent(MainActivity.this,Main2Activity.class); startActivity(intent); MainActivity.this.finish(); } } }); } 我现在的问题是,当我跳转页面,并关闭当前页面之后,我在新的页面在接收一条数据时,这条数据会让原页面给拦截接收,并再次把跳转页面执行了一遍(就是把新页面打开了两次),之后在发数据,它就可以正常在跳转之后的页面接收了。 为什么啊? 是我那么有加判断,还是我写的代码,跟线程不符 其中要根据接收的消息来更新ui,或跳转页面

int类型的数据&0xff会变成什么类型?

char buf[512]; int i; if (buf[i] != (i & 0xff)) 问题:i & 0xff结果会变成什么类型? 结果显示buf[i] = 0x80和 i = 0x80居然不相等,是不是符号的问题?

C#串口发送数据问题。

``` private void bntSendFile_Click(object sender, EventArgs e) { string fileName = txtFileName.Text.Trim(); if (fileName == "") { MessageBox.Show("请选择要发送的文件!", "Error"); return; } else { sRead = new StreamReader(fileName,Encoding.Default);//解决中文乱码问题 } timer1.Start(); } //发送文件时钟 private void timer1_Tick(object sender, EventArgs e) { string str1; str1 = sRead.ReadLine(); if (str1 == null) { timer1.Stop(); sRead.Close(); MessageBox.Show("文件发送成功!", "C#串口通讯"); this.toolStripStatusLabel5.Text = ""; return; } byte[] data = Encoding.Default.GetBytes(str1); sp.Write(data, 0, data.Length); this.toolStripStatusLabel5.Text = " 文件发送中..."; } ``` ``` ``` 以上是一段串口发送一个文件里面的内容。 现在需求如下,,, 现在想把文件的内容按照字节分数组,temp[0],temp[1],temp[2].......... 每个数组里面存放258个字节的内容。其中前两个字节是固定的 temp[0]={0xFF+0xB5+256字节_1}, temp[1]={0xFF+0xB6+256字节_2}, temp[2]={0xFF+0xB5+256字节_3}, temp[3]={0xFF+0xB6+256字节_4} temp[4]={0xFF+0xB6+256字节_5} ............................................... 直到所有文里面的所有字节内容发送完毕。结束。

Android APP接收UDP数据出错

/** * 接收数据线程 */ @Override public void run() { // TODO Auto-generated method stub try { while(!isStart); DatagramPacket dPacket = new DatagramPacket(reBuf, LEN); //InetAddress LocalAddr = InetAddress.getLocalHost(); //Log.e(TAG,"IP = "+LocalAddr); /*dSocket = new DatagramSocket(null); dSocket.setReuseAddress(true); dSocket.bind(new InetSocketAddress(LISTENPORT));*/ Log.e(TAG, "server run"); while(isReceiveRun){ /** * udp 监听,当接收到数据则对数据进入处理后发送消息给UI线程,进行更新UI */ Log.e(TAG,"receive"); listenSocket.receive(dPacket); Log.e(TAG,"port = "+dPacket.getPort()+""); if(dPacket.getPort() == SOURPORT) processMessage(dPacket.getData()); //for(int i=0;i<dPacket.getData().length;i++) //Log.e(TAG, dPacket.getData()[i]+""); } } catch (SocketException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } Log.e(TAG,"dSocket close"); } /** * 对接收到的数据进行处理和分发 * 数据处理后根据数据帧类型分别分发到 灯控查询数据:LightMap<Byte,boolean> * 环境数据:EnvironmentList<String> * 抄表数据:WatermeterList<String> * @param data */ private void processMessage(final byte[] data) { // TODO Auto-generated method stub Log.e(TAG,"data"); byte C = data[0]; int L = data[1]*256+data[2]; int DI = 0; DI |= ((int)data[3]&0xff)<<8; DI |= (int)data[4]; int SER = 0; SER |= (int)(data[5]&0xff)<<8; SER |= (int)data[6]; byte[] DATA = new byte[L-4]; for(int i=0; i<(L-4); i++) DATA[i] = data[i+7]; byte CS = data[L+3]; Log.e(TAG,"CS = "+((CS>>4)&0xf)+(CS&0xf)+" L = "+L+" DI = "+DI); if(CS != Check(data,L+4)){ Log.e(TAG,"CS erro"); return; } if(((byte)C != (byte)0xBB)&&((byte)C != (byte)0x3B)){ if(((byte)C == (byte)0xFB)||((byte)C == (byte)0xE3)){//错误应答 switch(DI){ case CONTROL_DI: dataType = CONTROL_TYPE; break; case SEARCH_ENVIRONMENT_DI: break; case SEARCH_LIGHT_DI: break; case SEARCH_SCENE_DI: break; case SEARCH_WATERMETER_DI: break; default: Log.e(TAG,"error DI bit"); return; } //return; }else{//此数据不符合协议 Log.e(TAG,"error protocol"); return; } } //处理正确应答数据 switch(DI){ case CONTROL_DI: dataType = CONTROL_TYPE; break; case SEARCH_ENVIRONMENT_DI: dataType = SEARCH_ENVIRONMENT_TYPE; //enable = 1; break; case SEARCH_LIGHT_DI: dataType = SEARCH_LIGHT_TYPE; int len = DATA.length; int nums = len/2; for(int i=0; i<nums; i++) LightMap.put(DATA[i*2], (DATA[i*2+1]==0)?false:true); break; case SEARCH_SCENE_DI: dataType = SEARCH_SCENE_TYPE; break; case SEARCH_WATERMETER_DI: dataType = SEARCH_WATERMETER_TYPE; break; default: Log.e(TAG,"error DI bit"); return; } 对接受到的数据进行首字节判断,判断正确更改按键当前状态并改变发送UDP数据 ,判断失败按键状态不变发送UDP数据不变 目前打印不出接收到的数据,不知道哪里出问题了,有人能帮我看看吗?我是android菜鸟

c#串口通信延迟问题,数据的发送和接受

在vs2010中调试运行,功能都完整,为什么在debug下运行exe文件。功能就会出现问题 自己认为是接受数据的时候发生了延迟。 comm_DataReceived 接受代码: int n = serialPort1.BytesToRead; byte[] buf = new byte[n]; serialPort1.Read(buf, 0, n); buffer.AddRange(buf); if (!isDataReceived) { buffer.Clear(); isDataReceived = false; bindControlDetail(); } else { if (buffer.Count == 9) { if (buffer[0] == 0xee && buffer[1] == 0xff) { //byte[] binary_data_1 = new byte[9]; buffer.CopyTo(0, binary_data_1, 0, 9); reader = CommonUtil.CommonUtil.byteToHexStr(binary_data_1); buffer.Clear(); analysisRuningTimeControlData();//解析 } } if (buffer.Count > 9) { buffer.Clear(); } } 请教各位大神,帮忙看看!!!!

STM32串口调试助手接收HEX格式FF

STM32发送数据,可是串口调试助手一直接收的是FF,换波特率接受干脆就停止了。请问是怎么回事啊,有没有可能是串口线坏掉了

stm32串口发送可以进入中断但没有数据显示

程序功能是:若接收到数据0x55,则发送接收到的数据(0x55)。 但现在问题是:通过串口助手发送0x55,已经进入接收中断接受到数据,然后通过SendData函数发送数据,能进入发送中断,但是串口助手却没有显示0x55(好像是数据并没有发送出去) /*头文件*/ #ifndef __HEAD_H__ #define __HEAD_H__ #include <misc.h> #include <stm32f10x_usart.h> #include <stm32f10x_gpio.h> #include <STM32F10x_rcc.h> #include <stdint.h> #include "stm32f10x_flash.h" //#include <stm32100e_eval.h> //#include <stm32_eval.h> void NVIC_Configuration(void); void RCC_Configuration(void); void Usart_Initial(void); void gpio_Init(void); void Delayms(uint16_t ms); extern uint16_t rece; #endif /*函数*/ #include "head.h" void NVIC_Configuration(void){ //ÖжÏÓÅÏȼ¶ÉèÖà NVIC_InitTypeDef NVIC_InitStruc; NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1); NVIC_InitStruc.NVIC_IRQChannel = USART1_IRQn; NVIC_InitStruc.NVIC_IRQChannelPreemptionPriority = 0; NVIC_InitStruc.NVIC_IRQChannelSubPriority = 0; NVIC_InitStruc.NVIC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStruc); } void RCC_Configuration(void){ ErrorStatus HSEStartUpStatus; RCC_DeInit(); RCC_HSEConfig(RCC_HSE_ON); HSEStartUpStatus = RCC_WaitForHSEStartUp(); if(RCC_WaitForHSEStartUp() == SUCCESS) { FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); FLASH_SetLatency(FLASH_Latency_2); RCC_HCLKConfig(RCC_SYSCLK_Div1); RCC_PCLK2Config(RCC_HCLK_Div1); RCC_PCLK1Config(RCC_HCLK_Div2); RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9); RCC_PLLCmd(ENABLE); while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY==RESET)) {} RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); while(RCC_GetSYSCLKSource()!=0x08){} } RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_USART1, ENABLE); } void Usart_Initial(void){ USART_InitTypeDef USART_InitStructure; USART_ClockInitTypeDef USART_ClockStructure; USART_InitStructure.USART_BaudRate = 115200; USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None; USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx; USART_InitStructure.USART_Parity = USART_Parity_No; USART_InitStructure.USART_StopBits = USART_StopBits_1; USART_InitStructure.USART_WordLength = USART_WordLength_8b; // USART_ClockStructure.USART_Clock = USART_Clock_Disable; // USART_ClockStructure.USART_CPHA = USART_CPHA_2Edge; // USART_ClockStructure.USART_CPOL = USART_CPOL_Low; // USART_ClockStructure.USART_LastBit = USART_LastBit_Disable; USART_ClockStructInit(&USART_ClockStructure); USART_Init(USART1,&USART_InitStructure); USART_ClockInit(USART1,&USART_ClockStructure); RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE); // USART_ITConfig(USART1,USART_IT_TXE,ENABLE); // USART_ITConfig(USART1, USART_IT_RXNE,ENABLE); // USART_WakeUpConfig(USART1, USART_WakeUp_IdleLine); USART_Cmd(USART1,ENABLE); } void gpio_Init(void){ GPIO_InitTypeDef GPIO_InitSTA; GPIO_InitTypeDef GPIO_InitSTB; /* GPIO_PinLockConfig(GPIOB,GPIO_Pin_12);*/ RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOB,ENABLE); GPIO_InitSTA.GPIO_Mode = GPIO_Mode_Out_PP; //TxD1 GPIO_InitSTA.GPIO_Pin = GPIO_Pin_9; GPIO_InitSTA.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(GPIOA,&GPIO_InitSTA); GPIO_InitSTA.GPIO_Mode = GPIO_Mode_IN_FLOATING; //RxD1 GPIO_InitSTA.GPIO_Pin = GPIO_Pin_10; // GPIO_InitSTA.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(GPIOA,&GPIO_InitSTA); GPIO_InitSTB.GPIO_Mode = GPIO_Mode_Out_PP; GPIO_InitSTB.GPIO_Pin = GPIO_Pin_12 | GPIO_Pin_13; GPIO_InitSTB.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(GPIOB,&GPIO_InitSTB); GPIO_SetBits(GPIOA,GPIO_Pin_9 | GPIO_Pin_10); GPIO_SetBits(GPIOB,GPIO_Pin_12 | GPIO_Pin_13); } void Delayms(uint16_t ms){ uint16_t i = 0; uint16_t j = 0; for(j = 0;j < ms;j ++){ for(i = 0;i < 12000;i ++){ } } } /*主程序,串口usart1中断函数*/ #include "head.h" #include "stdio.h" #include "stm32f10x_it.h" uint16_t rece = 0; int main(void){ NVIC_Configuration(); RCC_Configuration(); Usart_Initial(); gpio_Init(); USART_ITConfig(USART1,USART_IT_TXE,ENABLE); USART_ITConfig(USART1,USART_IT_RXNE,ENABLE); GPIO_WriteBit(GPIOB,GPIO_Pin_12 | GPIO_Pin_13,Bit_RESET); while(1){ // GPIO_WriteBit(GPIOB,GPIO_Pin_12 | GPIO_Pin_13,Bit_SET); // Delayms(1000); GPIO_WriteBit(GPIOB,GPIO_Pin_12 | GPIO_Pin_13,Bit_RESET); Delayms(1000); // USART_SendData(USART1,0x55); // Delayms(1000); // while(USART_GetFlagStatus(USART1,USART_FLAG_TXE) == RESET){}; } } void USART1_IRQHandler(void) { /* if(USART_GetITStatus(USART1, USART_IT_PE) != RESET) { USART_ITConfig(USART1, USART_IT_RXNE, ENABLE); rece = USART_ReceiveData(USART1); } */ if(USART_GetITStatus(USART1, USART_IT_TXE) != RESET) { GPIO_WriteBit(GPIOB,GPIO_Pin_12,Bit_SET); //若发送0x55,引脚电平会变 // USART_SendData(USART1, 0xff); // while(USART_GetFlagStatus(USART1,USART_FLAG_TXE) == RESET){}; USART_ClearFlag(USART1,USART_FLAG_TC); USART_ITConfig(USART1, USART_IT_TXE, DISABLE); } if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) { /* Disable USART1 RXNE Interrupt */ rece = USART_ReceiveData(USART1); USART_ClearFlag(USART1,USART_IT_RXNE); // USART_ITConfig(USART1, USART_IT_RXNE, DISABLE); if(rece == 0x55){ // GPIO_WriteBit(GPIOB,GPIO_Pin_12,Bit_SET); USART_ITConfig(USART1,USART_IT_TXE,ENABLE); USART_SendData(USART1,rece); while(USART_GetFlagStatus(USART1,USART_FLAG_TXE) == RESET){}; // printf("hello"); } } }

串口通信返回数据出错问题

我想从调试助手里发送一个多位数到单片机上,然后单片机处理加1返回到电脑,结果我发1,返回1;发123,返回24;发12,返回2,这是什么问题啊,我发一段代码,大家能帮我看一下吗 ``` #include<reg52.h> #include"bstv51.h" unsigned char num=0; void Uart_Init(); void main() { Uart_Init(); while(1); } void Uart_Init() { TMOD=0X20;//设置定时器1工作方式为2,8位重装定时器 TH1=0XFD; TL1=0XFD; //设置波特率为9600 SCON=0X50;//设置串口工作方式为1,8位元uart,开启接受允许 PCON=0X00;//波特率不加倍 EA=1; ES=1; TR1=1; } void Uart_Isr() interrupt 4 { if(TI) { TI=0; REN=1; } if(RI) { RI=0; num=SBUF; num++; SBUF=num; REN=0; } } ```

51单片机模拟spi控制电力载波芯片MI200E,发送0xaa,接收有显示,但不是0xaa。

想测试发送0xaa,但接收不对,而且接收更像是乱码,改了很多地方都不对,不知道问题出在哪里,希望各位大神帮忙看看代码错在哪。我用的keil3编译环境,51单片机,电力线载波芯片是MI200E,测试接收0xaa是通过8个led灯(也用串口显示过,和led灯显示相匹配)第一次提问题,不知道怎么把MI200E的数据手册和应用手册贴出来,在代码后贴出了文档在百度文库上的网址,麻烦各位大神了,小弟这次是碰到棘手困难了,在这先谢了。代码如下: /********发送程序*********************/ #include <reg52.h> #include <intrins.h> #define uchar unsigned char #define uint unsigned int //sbit MOSI=P1^0; //主设备发送从设备接收线,master output subordinate input //sbit MISO=P1^1; //从设备发送主设备接收线 master input subordinate output sbit SDO=P1^2; //p1.3口模拟主机输出 主设备发送从设备接收 sbit SDI=P1^1; //p3.2口模拟主机输入,接到外部中断0 主设备接收从设备发送 sbit sck=P1^3; //SPI时钟 sbit cs=P1^4; //片选 p1.3 sbit MI200E_RST=P1^5; //复位 sbit ceshi1=P0^6; sbit ceshi2=P0^7; uchar num; uchar RDSR_command; //用来读0x82 uchar CRC_H,CRC_L; uchar step,i; void delay(uint z);//延时 void cudelay_50us(); void init_MI200E();//初始化 void Write_CommandReg(uchar add,uchar com);//写控制指令 uchar Read_CommandReg(uchar add);//读控制指令 void Write_DataReg(uchar add,uchar dat);//写数据,dat应是16位的 void Write_DataReg2(uchar add,uchar dat_H,uchar dat_L);//改进,将高低8位分开发送 uchar Read_DataReg(uchar add);//读数据 void send(); void delay(uint z) { uint x,y; for(x=z;x>0;x--) for(y=110;y>0;y--); } void cudelay_50us() { uchar i; for(i=0;i<5;i++); } void init_MI200E() //初始化 { MI200E_RST=0; delay(600); //要求延时超过500ms MI200E_RST=1; delay(60); //要求延时超过50ms Write_CommandReg(0x01,0xFF); Write_CommandReg(0x0C,0x58); Write_CommandReg(0x0D,0x01); //应用笔记这样写 // Write_CommandReg(0x0D,0x0A); //数据手册这样写 Write_CommandReg(0x10,0x66); Write_CommandReg(0x12,0x66); Write_CommandReg(0x14,0x66); Write_CommandReg(0x11,0x88); Write_CommandReg(0x13,0x88); Write_CommandReg(0x15,0x88); Write_CommandReg(0x07,0xFF); Write_CommandReg(0x0A,0x00); Write_CommandReg(0x0B,0x00); } void init() { TMOD=0x01;//设置定时器0工作方式1 TH0=(65536-2293)/256;//定时5ms TL0=(65536-2293)%256; EA=1; ET0=1;//开定时器0 TR0=1;//启动定时器0 } //写入控制寄存器 void Write_CommandReg(uchar add,uchar com) { uchar i; uchar mark; cs=0; mark=0x80; _nop_(); //_nop_();延时1us _nop_(); for(i=0;i<8;i++) { sck=0; _nop_(); if(add&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } mark=0x80; for(i=0;i<8;i++) { sck=0; _nop_(); if(com&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } _nop_(); sck=0; cs=1; } //读取控制寄存器 uchar Read_CommandReg(uchar add) //时序有问题,返回的readdata有三个高,目测是TI、carr和 { //Frame,但P2口值检测出Frame为高 uchar i; uchar mark; uchar readdata; cs=0; mark=0x80; _nop_(); _nop_(); for(i=0;i<8;i++) { sck=0; // _nop_(); if(add&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } _nop_(); _nop_(); for(i=0;i<8;i++) { //此处不能加延时 sck=0; _nop_(); readdata<<=1; if(SDI) { readdata|=1; } else { readdata&=0xFE; } sck=1; _nop_(); } _nop_(); sck=0; _nop_(); cs=1; return(readdata); } //写入数据寄存器 void Write_DataReg(uchar add,uchar dat) { uchar i; uchar mark; uchar marklong; cs=0; mark=0x80; marklong=0x8000; _nop_(); _nop_(); for(i=0;i<8;i++) { sck=0; _nop_(); if(add&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } for(i=0;i<16;i++) { sck=0; _nop_(); if(dat&marklong) { SDO=1; } else { SDO=0; } sck=1; _nop_(); marklong>>=1; } _nop_(); sck=0; cs=1; } void Write_DataReg2(uchar add,uchar dat_H,uchar dat_L) { uchar i; uchar mark; uint marklong; cs=0; mark=0x80; marklong=0x8000; _nop_(); _nop_(); for(i=0;i<8;i++) { sck=0; _nop_(); if(add&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } for(i=0;i<8;i++) { sck=0; _nop_(); if(dat_H&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } for(i=0;i<8;i++) { sck=0; _nop_(); if(dat_L&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } _nop_(); sck=0; cs=1; } //读取数据寄存器 uchar Read_DataReg(uchar add) { uchar i; uchar mark; uint readdata; cs=0; mark=0x80; readdata=0; _nop_(); _nop_(); for(i=0;i<8;i++) { sck=0; _nop_(); if(add&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } _nop_(); _nop_(); for(i=0;i<16;i++) { sck=0; _nop_(); readdata<<=1; if(SDI) { readdata|=1; } else { readdata&=0xFE; } sck=1; _nop_(); } _nop_(); sck=0; cs=1; return(readdata); } void send() { // Write_CommandReg(0x01,0x01); //bit6~4扩频码字,bit3~2波特率选择,bit1~0载波频率 //配置进入发送状态 switch(step) { case 0: { Write_CommandReg(0x01,0x0d);//将0x01的bit2、3至高,其余不变,以最低速率发送bit2、3 // Write_CommandReg(0x02,0x00);//将TI复位 Write_DataReg2(0x04,0xff,0xff); //发送0xff,0xff引导码 step=1; } break; case 1: { Write_CommandReg(0x02,0xfd);//将0x02的CRC清零 // Write_CommandReg(0x02,0x00);//将TI复位 Write_DataReg2(0x04,0x1a,0x0c);//发送bit3 0x1a和bit4 波特率和长度 step=2; } break; case 2: { Write_CommandReg(0x01,0x01);//将bit2、3恢复原设波特率1600和76.8kHZ // Write_CommandReg(0x02,0x00);//将TI复位 Write_DataReg(0x04,0xaa);//发送bit5,即使改成0xaaaa也不对 for(i=0;i<10;i++) //延时50us { _nop_(); _nop_(); _nop_(); _nop_(); _nop_(); } CRC_H=Read_CommandReg(0xa8); //读CRC CRC_L=Read_CommandReg(0xa9); step=3; } break; case 3: { // Write_CommandReg(0x02,0x00);//将TI复位 Write_DataReg2(0x04,CRC_H,CRC_L);//发送CRC step=0; } break; default: {delay(10);} break; } } void main() { init(); init_MI200E(); Write_CommandReg(0x02,0x80); Write_DataReg2(0x04,0xff,0xff); Write_CommandReg(0x01,0x01); //bit6~4扩频码字,bit3~2波特率选择,bit1~0载波频率 step=0; sck=0; SDI=1; while(1); } void timer0() interrupt 1//2.5ms { // P1|=1; TH0=(65536-2293)/256;// TL0=(65536-2293)%256;//重装初值 // Write_CommandReg(0x02,0x80); RDSR_command=Read_CommandReg(0x82); P2=RDSR_command; if((RDSR_command & 0x80)==0x80) //每隔2.5ms查询0x82,判断bit7 TI是否为1 { ceshi2=0; // P1&=0xFE; Write_CommandReg(0x02,0x00);//将TI复位 // delay(5); send(); //TI为1执行发送,TI为1往发送寄存器写入数据,之后TI需复位 // Write_CommandReg(0x01,0x0d);//将0x01的bit2、3至高,其余不变,以最低速率发送bit2、3 // Write_DataReg2(0x04,0xff,0xff); //发送0xff,0xff引导码 // P1|=1; // P0=0xaa; } // P1&=0xFE; } /*************接收程序************************/ #include <reg52.h> #include <intrins.h> #define uchar unsigned char #define uint unsigned int //sbit MOSI=P1^0; //主设备发送从设备接收线,master output subordinate input //sbit MISO=P1^1; //从设备发送主设备接收线 master input subordinate output sbit SDO=P1^2; //p1.3口模拟主机输出 主设备发送从设备接收 sbit SDI=P1^1; //p3.2口模拟主机输入,接到外部中断0 主设备接收从设备发送 sbit sck=P1^3; //SPI时钟 sbit cs=P1^4; //片选 p1.3 sbit MI200E_RST=P1^5; //复位 sbit ceshi1=P0^6; sbit ceshi2=P0^7; uchar num; uchar RDSR_command; //用来读0x82 uchar RDRR_command; //用来读0x83 uchar RDRB0_DataReg; //用来读取数据寄存器0x84 uchar CRC_H,CRC_L,CRC_flag; uchar step,i; void delay(uint z); void cudelay_50us(); void init_MI200E(); void Write_CommandReg(uchar add,uchar com); uchar Read_CommandReg(uchar add); void Write_DataReg(uchar add,uchar dat); void Write_DataReg2(uchar add,uchar dat_H,uchar dat_L); uchar Read_DataReg(uchar add); void send(); void delay(uint z) { uint x,y; for(x=z;x>0;x--) for(y=110;y>0;y--); } void cudelay_50us() { uchar i; for(i=0;i<5;i++); } void init_MI200E() //初始化 { MI200E_RST=0; delay(600); //要求延时超过500ms MI200E_RST=1; delay(60); //要求延时超过50ms Write_CommandReg(0x01,0xFF); Write_CommandReg(0x0C,0x58); Write_CommandReg(0x0D,0x01); //应用笔记这样写 // Write_CommandReg(0x0D,0x0A); //数据手册这样写 Write_CommandReg(0x10,0x66); Write_CommandReg(0x12,0x66); Write_CommandReg(0x14,0x66); Write_CommandReg(0x11,0x88); Write_CommandReg(0x13,0x88); Write_CommandReg(0x15,0x88); Write_CommandReg(0x07,0xFF); Write_CommandReg(0x0A,0x00); Write_CommandReg(0x0B,0x00); } void init() { TMOD=0x01;//设置定时器0工作方式1 TH0=(65536-2293)/256;//定时5ms TL0=(65536-2293)%256; EA=1; ET0=1;//开定时器0 TR0=1;//启动定时器0 } //写入控制寄存器 void Write_CommandReg(uchar add,uchar com) { uchar i; uchar mark; cs=0; mark=0x80; _nop_(); //_nop_();延时1us _nop_(); for(i=0;i<8;i++) { sck=0; _nop_(); if(add&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } mark=0x80; for(i=0;i<8;i++) { sck=0; _nop_(); if(com&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } _nop_(); sck=0; cs=1; } //读取控制寄存器 uchar Read_CommandReg(uchar add) { uchar i; uchar mark; uchar readdata; cs=0; mark=0x80; _nop_(); _nop_(); for(i=0;i<8;i++) { sck=0; // _nop_(); if(add&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } _nop_(); for(i=0;i<8;i++) { //此处不能加延时 sck=0; _nop_(); readdata<<=1; if(SDI) { readdata|=1; } else { readdata&=0xFE; } sck=1; // _nop_(); } _nop_(); sck=0; _nop_(); cs=1; return(readdata); } //写入数据寄存器 void Write_DataReg(uchar add,uchar dat) { uchar i; uchar mark; uchar marklong; cs=0; mark=0x80; marklong=0x8000; _nop_(); _nop_(); for(i=0;i<8;i++) { sck=0; _nop_(); if(add&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } for(i=0;i<16;i++) { sck=0; _nop_(); if(dat&marklong) { SDO=1; } else { SDO=0; } sck=1; _nop_(); marklong>>=1; } _nop_(); sck=0; cs=1; } void Write_DataReg2(uchar add,uchar dat_H,uchar dat_L) { uchar i; uchar mark; uint marklong; cs=0; mark=0x80; marklong=0x8000; _nop_(); _nop_(); for(i=0;i<8;i++) { sck=0; _nop_(); if(add&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } for(i=0;i<8;i++) { sck=0; _nop_(); if(dat_H&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } for(i=0;i<8;i++) { sck=0; _nop_(); if(dat_L&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } _nop_(); sck=0; cs=1; } //读取数据寄存器 uchar Read_DataReg(uchar add) { uchar i; uchar mark; uint readdata; cs=0; mark=0x80; readdata=0; _nop_(); _nop_(); for(i=0;i<8;i++) { sck=0; _nop_(); if(add&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } _nop_(); _nop_(); for(i=0;i<16;i++) { sck=0; _nop_(); readdata<<=1; if(SDI) { readdata|=1; } else { readdata&=0xFE; } sck=1; _nop_(); } _nop_(); sck=0; cs=1; return(readdata); } void send() { // Write_CommandReg(0x01,0x01); //bit6~4扩频码字,bit3~2波特率选择,bit1~0载波频率 //配置进入发送状态 switch(step) { case 0: { Write_CommandReg(0x01,0x0d);//将0x01的bit2、3至高,其余不变,以最低速率发送bit2、3 Write_DataReg2(0x04,0xff,0xff); //发送0xff,0xff引导码 step=1; } break; case 1: { Write_CommandReg(0x02,0xfd);//将0x02的CRC清零 Write_DataReg2(0x04,0x1a,0x0c);//发送bit3 0x1a和bit4 波特率和长度 step=2; } break; case 2: { Write_CommandReg(0x01,0x01);//将bit2、3恢复原设波特率1600和76.8kHZ Write_DataReg(0x04,0xaa);//发送bit5 for(i=0;i<10;i++) //延时50us { _nop_(); _nop_(); _nop_(); _nop_(); _nop_(); } CRC_H=Read_CommandReg(0xa8); //读CRC CRC_L=Read_CommandReg(0xa9); step=3; } break; case 3: { Write_DataReg2(0x04,CRC_H,CRC_L);//发送CRC ceshi1=1; ceshi2=0; Write_CommandReg(0x02,0x00);//将TI复位 step=0; } break; default: {} break; } } void receive() { switch(step) { case 0: { RDRR_command=Read_CommandReg(0x83); if(RDRR_command!=0x00) { Write_CommandReg(0x01,0x81); step=1; } } break; case 1: { if((RDSR_command & 0x40)==0x40) { step=2; } else { step=1; } } break; case 2: { Write_CommandReg(0x02,0x7a);//将CRC标志位置1 RDRB0_DataReg=Read_DataReg(0x84);//读取0x84 Write_CommandReg(0x02,0x30);//将RI清零 P0=RDRB0_DataReg; step=3; } break; case 3: { CRC_flag=Read_DataReg(0x84);//读取CRC校验标志位 // P0=CRC_flag; if(CRC_flag==1) { Write_CommandReg(0x02,0x00);//将EPF和CRC标志位清零 } } break; default: {} break; } } void main() { init(); init_MI200E(); // Write_CommandReg(0x02,0x80); Write_CommandReg(0x02,0x00); Write_CommandReg(0x01,0x81);//bit6~4扩频码字,bit3~2波特率选择,bit1~0载波频率 Write_CommandReg(0x01,0x8d);//配置接收状态 step=0; sck=0; SDI=1; while(1); } void timer0() interrupt 1//2.5ms { // P1|=1; TH0=(65536-2293)/256;// TL0=(65536-2293)%256;//重装初值 RDSR_command=Read_CommandReg(0x82); P2=RDSR_command; if(((RDSR_command & 0x20)==0x20)&&((RDSR_command & 0x10)==0x10)) //每隔2.5ms查询0x82,判断carr和frame是否为1 { // P1&=0xFE; // Write_CommandReg(0x02,0x00);//将TI复位 // delay(2.5); receive(); //carr和frame为1执行接收 // cudelay_50us(); // ceshi2=0; // Write_CommandReg(0x02,0x30);//将RI清零 //Write_DataReg2(0x04,0xff,0xff); // P1|=1; // P0=0xaa; } // P1&=0xFE; } MI200E数据手册网址:[CSDN移动问答][1] MI200E应用笔记网址:[CSDN移动问答][2] [1]: http://wenku.baidu.com/link?url=stE_-LF4OcojG9xuouzs9Qbi54F6CmP96yoTdgtQ7VInQRp03tBh-A_P4TSIgvJ-vRZ7TaSg0UUNZNbUz36vnhU1QpT91omCDljRUAw8qY3 [2]: http://wenku.baidu.com/link?url=A-0hTe_YiFslr94yLvoqhliuPPIoGZaa98bp-va-Hvi1oO63lC3XW3kAIt4JuWfsAo7BUENnnvGjCWP4hmKFyxecv82QOixL-5ere1IAEYe

关于AT89C51的串口发送数据

我的代码如下: #include<reg51.h> unsigned char temp=0xaa; void delay(unsigned char i); void Inituart(); void main(){ Inituart(); SBUF=temp; while(1); } void Inituart(){ SCON=0X40; PCON=0X00; TMOD=0X20; TH1=0XFD; TL1=0XFD; ET1=0; ES=1; EA=1; TR1=1; } void uart() interrupt 4 { TI=0; delay(50); SBUF=temp; } void delay(unsigned char i){ unsigned char j=255; for(;j>0;j--) for(;i>0;i--); } ``` ``` 用proteus仿真得到的逻辑如图:![图片说明](https://img-ask.csdn.net/upload/201611/02/1478088231_760960.png) 也就是 0 0 1 0 1 0 1 0 1 1 刚好10位,但是我代码发送的是0xaa,不应该是 0 1 0 1 0 1 0 1 0 1吗?求救大腿??

C#串口发送数据回复问题。

写了一个串口通信的程序,设计一个协议。 目前我通过C#串口上位机给设备发送一个0xFF 0xB5的命令, 设备会回复 0xFF 0xB5 0x00 的消息显示在接受的textbox中。 然后开始发送下一个消息。 C#怎么判断设备回复了消息,这块代码改怎么写??

AAC LD rtp 接收到的数据如何存储下来,如何解码?

1、使用rtp接收到的AAC LD 的数据,使用什么格式存储下来才能播放,我使用的是LATM封装的,7个字节头,payloadlength根据大小添加大于255 时为2个字节,例如 260 字节长度 0xff 0x05 ,然后是纯音频编码数据。不知道这样可不可以?是不是不可以存储为adts封装格式? 2、 AAC LD 的数据有没有解码器,FAAD中有没有解码, VLC可不可以播放? 已经搞了几天,最终还是卡到封装格式上,还有不能确定什么样的播放器可以播放。希望大神帮助一下。谢谢。

C# 串口发送卡死 求大神解决

上位机和底层的通信方式是同步的,上位机第一次发送可以完成。 串口接收到返回的信息进行判断,然后直接在接收函数中再次发送。 设置断点可以完成整个过程,但是直接运行,就卡死。 目前发现是接收到返回的信息后再次发送的时候,卡死。 请问如何解决? ``` //串口接收事件 private void comm_DataReceived(object sender, SerialDataReceivedEventArgs e) { while (comm.BytesToRead > 0) { rx_Buf[rx_Cnt++] = (byte)comm.ReadByte(); } if (rx_Cnt == 8) { //8个字节 接收完成 rx_Cnt = 0; } else { return; } Console.WriteLine("-----接收发回帧-----"); if (rx_Buf[0] == 0xFF && rx_Buf[1] == 0xFE && rx_Buf[6] == 0xFE && rx_Buf[7] == 0xFF) { switch (rx_Buf[4]) { case 0x01: if (rx_Buf[5] == 0xAA) { flag_State = FLAG_STATUS.STATE_WRITE; send_file = true; Console.WriteLine("-----验证成功 开始发送文件-----"); } else { MessageBox.Show("0x01 失败"); } break; case 0x02: if (rx_Buf[5] == 0xAA) send_file = true; else MessageBox.Show("0x02 失败"); break; default: MessageBox.Show("失败"); break; } //验证通过,发送文件 if (send_file) { if (transLen < fileLenth) { int len = fs.Read(sendBuf, 5, 1024); Console.WriteLine("len:" + len.ToString()); if (len > 0) { uint crcValue = Fn_GetCRC32(sendBuf, 5, 1024); byte[] crcBytes = new byte[4]; for (int i = 4; i > 0; i--) { crcBytes[4 - i] = (byte)(crcValue & 0xFF); crcValue >>= 8; } for (int i = 0; i < 4; i++) { sendBuf[1029 + i] = crcBytes[i]; } transLen += len; comm.DiscardOutBuffer(); Console.WriteLine("-----清空发送缓冲区-----"); comm.Write(sendBuf, 0, sendBuf.Length); Console.WriteLine("transLen:" + transLen.ToString()); Console.WriteLine("------------------------------------"); } } else { MessageBox.Show("烧写完成"); try { fs.Close(); comm.Close(); } catch (Exception) { } } send_file = false; } } } ```

MySQL 8.0.19安装教程(windows 64位)

话不多说直接开干 目录 1-先去官网下载点击的MySQL的下载​ 2-配置初始化的my.ini文件的文件 3-初始化MySQL 4-安装MySQL服务 + 启动MySQL 服务 5-连接MySQL + 修改密码 先去官网下载点击的MySQL的下载 下载完成后解压 解压完是这个样子 配置初始化的my.ini文件的文件 ...

Python+OpenCV计算机视觉

Python+OpenCV计算机视觉系统全面的介绍。

Vue.js 2.0之全家桶系列视频课程

基于新的Vue.js 2.3版本, 目前新全的Vue.js教学视频,让你少走弯路,直达技术前沿! 1. 包含Vue.js全家桶(vue.js、vue-router、axios、vuex、vue-cli、webpack、ElementUI等) 2. 采用笔记+代码案例的形式讲解,通俗易懂

navicat(内含激活码)

navicat支持mysql的可视化操作,内涵激活码,不用再忍受弹框的痛苦。

HTML期末大作业

这是我自己做的HTML期末大作业,花了很多时间,稍加修改就可以作为自己的作业了,而且也可以作为学习参考

150讲轻松搞定Python网络爬虫

【为什么学爬虫?】 &nbsp; &nbsp; &nbsp; &nbsp;1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是一项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到! &nbsp; &nbsp; &nbsp; &nbsp;2、如果是作为一个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站 【课程设计】 一个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是: 网络请求:模拟浏览器的行为从网上抓取数据。 数据解析:将请求下来的数据进行过滤,提取我们想要的数据。 数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。 那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是: 爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。 Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。 通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为一个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果一台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 &nbsp; 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求! 【课程服务】 专属付费社群+每周三讨论会+1v1答疑

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

基于STM32的电子时钟设计

时钟功能 还有闹钟功能,温湿度功能,整点报时功能 你值得拥有

学生成绩管理系统(PHP + MYSQL)

做的是数据库课程设计,使用的php + MySQL,本来是黄金搭配也就没啥说的,推荐使用wamp服务器,里面有详细的使用说明,带有界面的啊!呵呵 不行的话,可以给我留言!

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

程序员的兼职技能课

获取讲师答疑方式: 在付费视频第一节(触摸命令_ALL)片头有二维码及加群流程介绍 限时福利 原价99元,今日仅需39元!购课添加小助手(微信号:itxy41)按提示还可领取价值800元的编程大礼包! 讲师介绍: 苏奕嘉&nbsp;前阿里UC项目工程师 脚本开发平台官方认证满级(六级)开发者。 我将如何教会你通过【定制脚本】赚到你人生的第一桶金? 零基础程序定制脚本开发课程,是完全针对零脚本开发经验的小白而设计,课程内容共分为3大阶段: ①前期将带你掌握Q开发语言和界面交互开发能力; ②中期通过实战来制作有具体需求的定制脚本; ③后期将解锁脚本的更高阶玩法,打通任督二脉; ④应用定制脚本合法赚取额外收入的完整经验分享,带你通过程序定制脚本开发这项副业,赚取到你的第一桶金!

实用主义学Python(小白也容易上手的Python实用案例)

原价169,限时立减100元! 系统掌握Python核心语法16点,轻松应对工作中80%以上的Python使用场景! 69元=72讲+源码+社群答疑+讲师社群分享会&nbsp; 【哪些人适合学习这门课程?】 1)大学生,平时只学习了Python理论,并未接触Python实战问题; 2)对Python实用技能掌握薄弱的人,自动化、爬虫、数据分析能让你快速提高工作效率; 3)想学习新技术,如:人工智能、机器学习、深度学习等,这门课程是你的必修课程; 4)想修炼更好的编程内功,优秀的工程师肯定不能只会一门语言,Python语言功能强大、使用高效、简单易学。 【超实用技能】 从零开始 自动生成工作周报 职场升级 豆瓣电影数据爬取 实用案例 奥运冠军数据分析 自动化办公:通过Python自动化分析Excel数据并自动操作Word文档,最终获得一份基于Excel表格的数据分析报告。 豆瓣电影爬虫:通过Python自动爬取豆瓣电影信息并将电影图片保存到本地。 奥运会数据分析实战 简介:通过Python分析120年间奥运会的数据,从不同角度入手分析,从而得出一些有趣的结论。 【超人气老师】 二两 中国人工智能协会高级会员 生成对抗神经网络研究者 《深入浅出生成对抗网络:原理剖析与TensorFlow实现》一书作者 阿里云大学云学院导师 前大型游戏公司后端工程师 【超丰富实用案例】 0)图片背景去除案例 1)自动生成工作周报案例 2)豆瓣电影数据爬取案例 3)奥运会数据分析案例 4)自动处理邮件案例 5)github信息爬取/更新提醒案例 6)B站百大UP信息爬取与分析案例 7)构建自己的论文网站案例

Java8零基础入门视频教程

这门课程基于主流的java8平台,由浅入深的详细讲解了java SE的开发技术,可以使java方向的入门学员,快速扎实的掌握java开发技术!

Python数据挖掘简易入门

&nbsp; &nbsp; &nbsp; &nbsp; 本课程为Python数据挖掘方向的入门课程,课程主要以真实数据为基础,详细介绍数据挖掘入门的流程和使用Python实现pandas与numpy在数据挖掘方向的运用,并深入学习如何运用scikit-learn调用常用的数据挖掘算法解决数据挖掘问题,为进一步深入学习数据挖掘打下扎实的基础。

零基础学C#编程—C#从小白到大咖

本课程从初学者角度出发,提供了C#从入门到成为程序开发高手所需要掌握的各方面知识和技术。 【课程特点】 1 由浅入深,编排合理; 2 视频讲解,精彩详尽; 3 丰富实例,轻松易学; 4 每章总结配有难点解析文档。 15大章节,228课时,1756分钟与你一同进步!

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

多功能数字钟.zip

利用数字电子计数知识设计并制作的数字电子钟(含multisim仿真),该数字钟具有显示星期、24小时制时间、闹铃、整点报时、时间校准功能

极简JAVA学习营第四期(报名以后加助教微信:eduxy-1)

想学好JAVA必须要报两万的培训班吗? Java大神勿入 如果你: 零基础想学JAVA却不知道从何入手 看了一堆书和视频却还是连JAVA的环境都搭建不起来 囊中羞涩面对两万起的JAVA培训班不忍直视 在职没有每天大块的时间专门学习JAVA 那么恭喜你找到组织了,在这里有: 1. 一群志同道合立志学好JAVA的同学一起学习讨论JAVA 2. 灵活机动的学习时间完成特定学习任务+每日编程实战练习 3. 热心助人的助教和讲师及时帮你解决问题,不按时完成作业小心助教老师的家访哦 上一张图看看前辈的感悟: &nbsp; &nbsp; 大家一定迫不及待想知道什么是极简JAVA学习营了吧,下面就来给大家说道说道: 什么是极简JAVA学习营? 1. 针对Java小白或者初级Java学习者; 2. 利用9天时间,每天1个小时时间; 3.通过 每日作业 / 组队PK / 助教答疑 / 实战编程 / 项目答辩 / 社群讨论 / 趣味知识抢答等方式让学员爱上学习编程 , 最终实现能独立开发一个基于控制台的‘库存管理系统’ 的学习模式 极简JAVA学习营是怎么学习的? &nbsp; 如何报名? 只要购买了极简JAVA一:JAVA入门就算报名成功! &nbsp;本期为第四期极简JAVA学习营,我们来看看往期学员的学习状态: 作业看这里~ &nbsp; 助教的作业报告是不是很专业 不交作业打屁屁 助教答疑是不是很用心 &nbsp; 有奖抢答大家玩的很嗨啊 &nbsp; &nbsp; 项目答辩终于开始啦 &nbsp; 优秀者的获奖感言 &nbsp; 这是答辩项目的效果 &nbsp; &nbsp; 这么细致的服务,这么好的氛围,这样的学习效果,需要多少钱呢? 不要1999,不要199,不要99,只要9.9 是的你没听错,只要9.9以上所有就都属于你了 如果你: 1、&nbsp;想学JAVA没有基础 2、&nbsp;想学JAVA没有整块的时间 3、&nbsp;想学JAVA没有足够的预算 还等什么?赶紧报名吧,抓紧抢位,本期只招300人,错过只有等时间待定的下一期了 &nbsp; 报名请加小助手微信:eduxy-1 &nbsp; &nbsp;

Python可以这样学(第一季:Python内功修炼)

董付国系列教材《Python程序设计基础》、《Python程序设计(第2版)》、《Python可以这样学》配套视频,讲解Python 3.5.x和3.6.x语法、内置对象用法、选择与循环以及函数设计与使用、lambda表达式用法、字符串与正则表达式应用、面向对象编程、文本文件与二进制文件操作、目录操作与系统运维、异常处理结构。

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

机器学习实战系列套餐(必备基础+经典算法+案例实战)

机器学习实战系列套餐以实战为出发点,帮助同学们快速掌握机器学习领域必备经典算法原理并结合Python工具包进行实战应用。建议学习顺序:1.Python必备工具包:掌握实战工具 2.机器学习算法与实战应用:数学原理与应用方法都是必备技能 3.数据挖掘实战:通过真实数据集进行项目实战。按照下列课程顺序学习即可! 课程风格通俗易懂,用最接地气的方式带领大家轻松进军机器学习!提供所有课程代码,PPT与实战数据,有任何问题欢迎随时与我讨论。

Java面试题大全(2020版)

发现网上很多Java面试题都没有答案,所以花了很长时间搜集整理出来了这套Java面试题大全,希望对大家有帮助哈~ 本套Java面试题大全,全的不能再全,哈哈~ 一、Java 基础 1. JDK 和 JRE 有什么区别? JDK:Java Development Kit 的简称,java 开发工具包,提供了 java 的开发环境和运行环境。 JRE:Java Runtime Environ...

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

HoloLens2开发入门教程

本课程为HoloLens2开发入门教程,讲解部署开发环境,安装VS2019,Unity版本,Windows SDK,创建Unity项目,讲解如何使用MRTK,编辑器模拟手势交互,打包VS工程并编译部署应用到HoloLens上等。

几率大的Redis面试题(含答案)

本文的面试题如下: Redis 持久化机制 缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级等问题 热点数据和冷数据是什么 Memcache与Redis的区别都有哪些? 单线程的redis为什么这么快 redis的数据类型,以及每种数据类型的使用场景,Redis 内部结构 redis的过期策略以及内存淘汰机制【~】 Redis 为什么是单线程的,优点 如何解决redis的并发竞争key问题 Red...

MFC一站式终极全套课程包

该套餐共包含从C小白到C++到MFC的全部课程,整套学下来绝对成为一名C++大牛!!!

【数据结构与算法综合实验】欢乐连连看(C++ & MFC)案例

这是武汉理工大学计算机学院数据结构与算法综合实验课程的第三次项目:欢乐连连看(C++ & MFC)迭代开发代码。运行环境:VS2017。已经实现功能:开始游戏、消子、判断胜负、提示、重排、计时、帮助。

YOLOv3目标检测实战:训练自己的数据集

YOLOv3是一种基于深度学习的端到端实时目标检测方法,以速度快见长。本课程将手把手地教大家使用labelImg标注和使用YOLOv3训练自己的数据集。课程分为三个小项目:足球目标检测(单目标检测)、梅西目标检测(单目标检测)、足球和梅西同时目标检测(两目标检测)。 本课程的YOLOv3使用Darknet,在Ubuntu系统上做项目演示。包括:安装Darknet、给自己的数据集打标签、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算和画出PR曲线)和先验框聚类。 Darknet是使用C语言实现的轻型开源深度学习框架,依赖少,可移植性好,值得深入探究。 除本课程《YOLOv3目标检测实战:训练自己的数据集》外,本人推出了有关YOLOv3目标检测的系列课程,请持续关注该系列的其它课程视频,包括: 《YOLOv3目标检测实战:交通标志识别》 《YOLOv3目标检测:原理与源码解析》 《YOLOv3目标检测:网络模型改进方法》 敬请关注并选择学习!

u-boot-2015.07.tar.bz2

uboot-2015-07最新代码,喜欢的朋友请拿去

相关热词 c# dbml文件 修改 c#遍历tree c# 能够控制单片机 c#对象写入数据库 c# 添加activex c#2005 json c# 数据库在云端 c# 字符串移位加密 c#禁用滚轮 c#实体类list去重复
立即提问