如何用c#编写串口监控软件? 监控某个串口的数据接受和发送

例如:有个串口工具在和COM3通信,可以用 串口监控软件,监控它们的通信数据。
我用过serialPort试过,但serialPort.Open()打开后,其他串口工具就无法和COM3连接,提示被占用,如何解决即可以监控串口,但又不影响其他工具连接COM3进行通信。

AccessPort 串口监控工具可以实现这个功能,但不知道其怎么实现的,我需要把这个功能加到我自己的代码里面。

2个回答

package com.oracle.servlet;

import java.io.IOException;
import java.util.List;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.oracle.domain.Book;
import com.oracle.domain.Category;
import com.oracle.service.BaseServlet;
import com.oracle.service.BookService;
import com.oracle.service.CategoryService;

public class BookServlet extends BaseServlet {
BookService bookService=new BookService();
public String findAll(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
List booklist = bookService.findAll();
request.setAttribute("booklist", booklist);
return "f:/jsps/book/list.jsp";
}
public String findByCid(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String cid = request.getParameter("cid");
List booklist = bookService.findByCid(cid);
request.setAttribute("booklist", booklist);
return "f:/jsps/book/list.jsp";
}

public String findByBid(HttpServletRequest request, HttpServletResponse response)
        throws ServletException, IOException {
    String bid = request.getParameter("bid");
     Book book = bookService.findByBid(bid);
     System.out.println(book);
    request.setAttribute("book", book);
    return "f:/jsps/book/desc.jsp";
}

}

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
Python+OpenCV计算机视觉

Python+OpenCV计算机视觉

C#编写串口数据收发程序,收发频繁,求教多线程处理机制!

![![![![图片说明](https://img-ask.csdn.net/upload/201604/20/1461167601_434062.jpg)图片说明](https://img-ask.csdn.net/upload/201604/20/1461167592_877283.jpg)图片说明](https://img-ask.csdn.net/upload/201604/20/1461167576_770964.jpg)图片说明](https://img-ask.csdn.net/upload/201604/20/1461167565_101017.jpg)C#编写串口数据收发程序,点击界面按钮发送指令数据,等待接收返回的数据,此外还有周期性数据需要不断接收;接收到的数据要判断重复帧和是否是最后一帧,然后去掉帧头帧尾并显示在界面控件内;目前程序开了三个线程:接收、处理、发送,三个线程都是一直循环判断指针是否有更新,但这样导致界面切换太卡,请问该怎么处理这三个线程之间的关系才能使界面切换流畅呢,初学C#,如果能给出具体修改代码方法更佳,请大神帮帮忙啊~急!

C#连接串口接受数据显示问题。很急。

C#串口上位机工具,接收到发过来的一串16进制数据,格式如下: FA AF 00 08 FF 31 32 33 34 FA AF 00 07 FF 35 36 后面可能还会有FA AF开头的 这串数据分析如下:识别FA AF为固定开始的头,紧接着后面的两个00 08为第一个整个字符串实际长度(FA AF 00 08 01 31 32 33 34),FF为固定的数据,不用管。 FF后面对应的数据为实际需要输出显示的数据(31 32 33 34),长度为4,然后这4个数据以正常的ASCII码显示出来。 第一个(FA AF 00 08 FF 31 32 33 34)实际需要的数据31 32 33 34对应的ASCII码为1234 第二个(FA AF 00 07 FF 35 36)实际需要的数据35 36对应的ASCII码为56 所以串口最终输出在textbox中显示为123456 以下代码是接受数据并显示在textbox的代码。怎么修改能达到以上的要求? ``` private void Com_DataReceived(object sender, SerialDataReceivedEventArgs e) { byte[] ReDatas = new byte[ComDevice.BytesToRead]; ComDevice.Read(ReDatas, 0, ReDatas.Length);//读取数据 this.AddData(ReDatas);//输出数据 } /// <summary> /// 添加数据 /// </summary> /// <param name="data">字节数组</param> public void AddData(byte[] data) { if (rbtnHex.Checked) { StringBuilder sb = new StringBuilder(); for (int i = 0; i < data.Length; i++) { sb.AppendFormat("{0:x2}" + " ", data[i]); } AddContent(sb.ToString().ToUpper()); } else if (rbtnASCII.Checked) { AddContent(new ASCIIEncoding().GetString(data)); } else if (rbtnUTF8.Checked) { AddContent(new UTF8Encoding().GetString(data)); } else if (rbtnUnicode.Checked) { AddContent(new UnicodeEncoding().GetString(data)); } else {} lblRevCount.Invoke(new MethodInvoker(delegate { lblRevCount.Text = (int.Parse(lblRevCount.Text) + data.Length).ToString(); })); } /// <summary> /// 输入到显示区域 /// </summary> /// <param name="content"></param> private void AddContent(string content) { this.BeginInvoke(new MethodInvoker(delegate { if(chkAutoLine.Checked && txtShowData.Text.Length>0) { txtShowData.AppendText("\r\n"); } txtShowData.AppendText(content); })); } ```

VC++如何调用C#编写的串口驱动 DLL

最近弄一个串口打印的项目,我一直是用VC++进行开发的,c#没用过,但是对方提供的打印机的DEMO却是C#的例程,本来想着DLL是跨语言的,应该没什么问题,但是我用vc++编写了一个测试程序,确没有任何数据输出,很简单的例程,我按流程在上面加了打开串口,设置串口,发送数据,关闭串口。这几步都是用的现成的dll里面的函数,他把串口的数据操作也封装起来了,然后我就想到,在c#中是可以直接用库函数对串口读写,是不是因为这个原因,导致我在vc++中不能使用? 里面所有的都是用DLL提供的函数直接操作串口,但是就是没有串口数据输出。 注:打印机提供的C#的例程DEMO是可以正常串口打印的。 求大神解答。下面是我在vc++的窗初始化函数里写的流程。 ``` BOOL CTestDll2008Dlg::OnInitDialog() { CDialog::OnInitDialog(); // 设置此对话框的图标。当应用程序主窗口不是对话框时,框架将自动 // 执行此操作 SetIcon(m_hIcon, TRUE); // 设置大图标 SetIcon(m_hIcon, FALSE); // 设置小图标 if (LoadPrintLib() == FALSE) { AfxMessageBox(_T("printdll.dll not found")); return FALSE; } ASCII_OpenPrinter(3); //ComState cs; //cs.dwBaudRate = 9600; //cs.Parity = NOPARITY; //cs.StopBits = ONESTOPBIT; DCB dcb; dcb.BaudRate = CBR_9600; dcb.ByteSize = 8; dcb.Parity = NOPARITY; dcb.StopBits = ONESTOPBIT; ASCII_SetComPortParam(dcb); char pBuff[3] = { 0x1b,0x57,0x02}; ASCII_DirectData(pBuff,3); char pBuff1[] = {"hello world"}; ASCII_DirectData(pBuff1,10); pBuff[2] = 0x01; ASCII_DirectData(pBuff,3); ASCII_DirectData(pBuff1,10); ASCII_ClosePrinter(); UnloadPrintLib(); return TRUE; // 除非将焦点设置到控件,否则返回 TRUE } ```

c#winform编写上位机串口接受到数据如何分开使用

首先已经编写完了上位机接收数据的程序也实现了在textbox控件中实时显示但是传上来的数据是一组xy坐标值我想如何可以在两个textbox控件中分别显示xy也就是把一组数据分开。因为后面还要利用xy值作图。目前我只能把xy一组数据放在一个textbox控件中达到实时更新数据或者使用Split、正则表达式对数据进行分割只能显示第一组分割后的数据但无法实时更新数据。![图片说明](https://img-ask.csdn.net/upload/201705/18/1495096956_858492.png) ![图片说明](https://img-ask.csdn.net/upload/201705/18/1495096701_157934.png)![图片说明](https://img-ask.csdn.net/upload/201705/18/1495097241_53003.png)代码如下: private void sp_DataReceived(object sender, SerialDataReceivedEventArgs e) { byte[] ReceivedData = new byte[sp.BytesToRead];//创建接收字节数组 sp.Read(ReceivedData, 0, ReceivedData.Length);//读取所接收到的数据 receivedDatas.AddRange(ReceivedData); textBox3.Text = (Convert.ToInt32(textBox3.Text) + ReceivedData.Length).ToString(); if (checkBox2.Checked) { textBox1.Text = Class1.ByteTo16Str(receivedDatas.ToArray()); } else { textBox1.Text = Encoding.Default.GetString(receivedDatas.ToArray()); //让文本框获取焦点 string a = Encoding.Default.GetString(receivedDatas.ToArray()); **string[] sArray = a.Split(','); //这里是进行分割数据,去掉这部分直接把a赋值给textbox就会实时显示但是在一个框里显示xy一组数据而不是一个数据x或者y textBox15.Text = sArray[0]; textBox16.Text = sArray[1];** this.textBox15.Focus(); //设置光标的位置到文本尾 this.textBox15.Select(this.textBox1.TextLength, 0); //滚动到控件光标处 this.textBox15.ScrollToCaret(); this.textBox1.Focus(); //设置光标的位置到文本尾 this.textBox1.Select(this.textBox1.TextLength, 0); //滚动到控件光标处 this.textBox1.ScrollToCaret(); } // sp.DiscardInBuffer();//丢弃接收缓冲区数据

C#写串口通信程序接收数据没有反应是怎么回事啊??

using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.IO.Ports; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms; namespace ChuanKou2 { public partial class Form1 : Form { SerialPort sp = null; //声明串口类 bool isOpen = false; //打开串口标志 bool isSetProperty = false; //属性设置标志 bool isHex = false; //十六进制显示标志位 public Form1() { InitializeComponent(); } private void Form1_Load(object sender, EventArgs e) { this.MaximumSize = this.Size; this.MinimumSize = this.Size; this.MaximizeBox = false; for (int i=0;i<10;i++) { cbxCOMPort.Items.Add("COM" + (i + 1).ToString()); } } private void btnCheckCOM_Click(object sender, EventArgs e) //检测有哪串口 { bool comExistence = false; //是否有可用的串口 cbxCOMPort.Items.Clear(); //清除当前串口号中的所有串口名称 for(int i=0;i<10;i++) { try { SerialPort sp = new SerialPort("COM" + (i + 1).ToString()); sp.Open(); sp.Close(); cbxCOMPort.Items.Add("COM" + (i + 1).ToString()); comExistence = true; } catch (Exception) { continue; } } if (comExistence) { cbxCOMPort.SelectedIndex = 0;//使ListBox显示第一个添加的索引 } else { MessageBox.Show("没有找到可用串口!","错误提示"); } } private bool CheckPortSetting() //串口是否设置 { if (cbxCOMPort.Text.Trim() == "") return false; if (cbxBaudRate.Text.Trim() == "") return false; if (cbxDataBits.Text.Trim() == "") return false; if (cbxParitv.Text.Trim() == "") return false; if (cbxStopBits.Text.Trim() == "") return false; return true; } private bool CheckSendData() { if (tbxSendData.Text.Trim() == "") return false; return true; } private void SetPortProPerty() //设置串口属性 { sp = new SerialPort(); sp.PortName = cbxCOMPort.Text.Trim(); //串口名 sp.BaudRate = Convert.ToInt32(cbxBaudRate.Text.Trim());//波特率 float f = Convert.ToSingle(cbxStopBits.Text.Trim());//停止位 if (f == 0) { sp.StopBits = StopBits.None; } else if (f == 1.5) { sp.StopBits = StopBits.OnePointFive; } else if (f == 1) { sp.StopBits = StopBits.One; } else if (f == 2) { sp.StopBits = StopBits.Two; } else { sp.StopBits = StopBits.One; } sp.DataBits = Convert.ToInt16(cbxDataBits.Text.Trim());//数据位 string s = cbxParitv.Text.Trim(); //校验位 if (s.CompareTo("无") == 0) { sp.Parity = Parity.None; } else if (s.CompareTo("奇校验") == 0) { sp.Parity = Parity.Odd; } else if (s.CompareTo("偶校验") == 0) { sp.Parity = Parity.Even; } else { sp.Parity = Parity.None; } sp.ReadTimeout = -1; //设置超时读取时间 sp.RtsEnable = true; //定义DataReceived事件,当串口收到数据后触发事件 sp.DataReceived += new SerialDataReceivedEventHandler(sp_DataReceived); if (rbnHex.Checked) { isHex = true; } else { isHex = false; } } private void sp_DataReceived(object sender,SerialDataReceivedEventArgs e) { System.Threading.Thread.Sleep(100); //延时100ms等待接收数据 //this.Invoke 跨线程访问ui的方法 this.Invoke((EventHandler)(delegate { if (isHex == false) { tbxRecvData.Text += sp.ReadLine(); } else { Byte[] ReceivedData = new Byte[sp.BytesToRead]; sp.Read(ReceivedData, 0, ReceivedData.Length); String RecvDataText = null; for(int i = 0; i < ReceivedData.Length - 1; i++) { RecvDataText += ("0x" + ReceivedData[i].ToString("X2") + ""); } tbxRecvData.Text += RecvDataText; } sp.DiscardInBuffer(); //丢弃接收缓冲区数据 })); } private void btnSend_Click(object sender, EventArgs e) //发送数据 { if (isOpen) { try { sp.WriteLine(tbxSendData.Text); } catch(Exception) { MessageBox.Show("发送数据时发生错误!", "错误提示"); return; } } else { MessageBox.Show("串口未打开", "错误提示"); return; } if (!CheckSendData()) { MessageBox.Show("请输入要发送的数据!", "错误提示"); return; } } private void btnOpenCom_Click(object sender, EventArgs e) { if (isOpen == false) { if (!CheckPortSetting()) //检测串口设置 { MessageBox.Show("串口未设置!", "错误提示"); return; } if (!isSetProperty) //串口未设置则设置串口 { SetPortProPerty(); isSetProperty = true; } try { sp.Open(); isOpen = true; btnOpenCom.Text = "关闭串口"; //串口打开后则相关串口设置按钮便不可再用 cbxCOMPort.Enabled = false; cbxBaudRate.Enabled = false; cbxDataBits.Enabled = false; cbxParitv.Enabled = false; cbxStopBits.Enabled = false; rbnChar.Enabled = false; rbnHex.Enabled = false; } catch (Exception) { //打开串口失败后,相应标志位取消 isSetProperty = false; isOpen = false; MessageBox.Show("串口无效或已被占用!", "错误提示"); } } else { try //关闭串口 { sp.Close(); isOpen = false; btnOpenCom.Text = "打开串口"; //关闭串口后,串口设置选项可以继续使用 cbxCOMPort.Enabled = true; cbxBaudRate.Enabled = true; cbxDataBits.Enabled = true; cbxParitv.Enabled = true; cbxStopBits.Enabled = true; rbnChar.Enabled = true; rbnHex.Enabled = true; } catch (Exception) { MessageBox.Show("关闭串口时发生错误!", "错误提示"); } } } private void btnCleanData_Click(object sender, EventArgs e) { tbxRecvData.Text = ""; tbxSendData.Text = ""; } } }

C#winform串口接收数据不能换行

![串口数据发送程序](https://img-ask.csdn.net/upload/201705/27/1495894317_580025.png) 下位机发送的是字符串数组;一共发送三个数组,间隔10ms左右,每个数组发送完成后添加"\r\n"换行; ![上位机接收显示程序](https://img-ask.csdn.net/upload/201705/27/1495894387_353263.png) C#winform上位机接收串口数据后显示到textbox控件中; ![上位机显示情况](https://img-ask.csdn.net/upload/201705/27/1495894251_237664.png) 理想的情况是要数据单列显示,便于保存到excel。但是在下位机添加"\r\n"后,依旧不能保证每次接收到的数据都自成一行。 请问这是什么原因?具体能怎么解决呢? (PS:利用开发板商的工具能够稳定的单列显示)

C#编写串口通讯程序,需要发送数组怎么发送?

byte[] bte = { 170, 0, 15, 31,, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 204 }; port.Write(bte); 这样发送一个数组会报错,要转成string类型,但转成后发送就不是想要的数据了。比如要发送:AA 00 31 00 00 CC 这样的数据。求大佬解惑

c#实时监控windows下的串口占用、释放状态

触发事件:当串口被占用时,能接收到占用通知,和串口名称;当串口释放时能接收通知和串口名称

C#中串口通信发送数据问题

串口通信数据发送,除了可用字节数组byte[],还可以用其他的什么吗?

用C#编写的串口调试助手中 数据接收区的TextBox的自定义事件

用C#编写的串口调试助手中 判断数据接收区的TextBox的text属性是否与预先设定的一个字符串相同,如果相同就会触发一个自定义的事件,这个事件的处理程序是往串口发送一个字符串,各位大神帮帮忙怎么实现这个功能,能有示例代码就更好了!!!

C#串口接收数据问题,怎么在处理数据前判断数据接收完毕

上位机接收数据格式如下: 0x53 0x50 0x01 0x01 0x00 0x00 0x00 0x00 0x57 0x23 0x7F 0x3F 0xA6 0xFC 0xBF 0x3A 0x11 0x07 0x17 0x11 0x13 0x39 其中 53 50是包头,后面是有效数据,我现在想把0x00 0x00 0x00 0x00 0x57 0x23 0x7F 0x3F 0xA6 0xFC 0xBF 0x3A 这几个字节分别转化为三个浮点数,但是问题是,我现在无法判断数据是否接收完毕,及完整的一个数据包。 注:通过按下一次单片机上的“确定键”,单片机给上位机发送一次数据,数据格式如上描述。请大家指点下,谢谢! 我是通过绑定串口接收事件实现的,但这样会多次触发串口接收事件,主要卡在数据接收和数据以浮点数显示环节,代码如下: private void sp_DataReceived(object sender,SerialDataReceivedEventArgs e) { if (isHex==true) { string str; uint i=0; int bufferlen = sp.BytesToRead; byte[] bytes = new byte[bufferlen]; sp.Read(bytes, 0, bufferlen); for(i=0;i<bytes.Length;i++) { str= Convert.ToString((byte)bytes[i], 16).ToUpper(); tbxRecvData.AppendText("0x" + (str.Length == 1 ? "0" + str : str) + " "); } } else { int bufferlen = sp.BytesToRead; byte[] bytes = new byte[bufferlen]; sp.Read(bytes, 0, bufferlen); string gb = System.Text.Encoding.Default.GetString(bytes); tbxRecvData.AppendText(gb); } }

c#串口数据读取不全问题

![正确的NFC贴片值](https://img-ask.csdn.net/upload/201611/30/1480487915_614568.png) 我自己写的值和代码 private void sp_DataReceived(object sender, SerialDataReceivedEventArgs e) { System.Threading.Thread.Sleep(100);//延时100ms等待接收完数据 // this.Invoke就是跨线程访问ui的方法 this.Invoke((EventHandler) (delegate { if (isHex == false) { tbxRecvData.Text += sp.ReadLine(); } else { Byte[] ReceivedData = new Byte[sp.BytesToRead]; sp.Read(ReceivedData, 0, ReceivedData.Length); String RecvDataText = null; for (int i = 0; i < ReceivedData.Length; i++) { RecvDataText += (" " + ReceivedData[i].ToString("X2") + ""); } tbxRecvData.Text += RecvDataText; } sp.DiscardInBuffer();//丢弃接收缓冲区数据 })); } ![图片说明](https://img-ask.csdn.net/upload/201611/30/1480488296_546399.png)

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(); } } 请教各位大神,帮忙看看!!!!

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} ............................................... 直到所有文里面的所有字节内容发送完毕。结束。

C#多个窗口使用用一个串口接受数据问题

我在主窗口MainForm中设置了Static SerialPort,在主界面注册了一个监听事件,然后在调到子界 之前,我注销了监听事件, serialPort.DataReceived -= new SerialDataReceivedEventHandler(serial_DataReceived); ``` 然后在子界面Calibration中使用了SerialPort,然后重新设置了监听事件: MainForm.serialPort.DataReceived += new SerialDataReceivedEventHandler(DataReceived2); ``` 想实现的方式是:在子窗口关闭之前将监听事件取消,然后在主界面在重新设置监听事件,关闭子窗口后主界面实现的代码 calibrationForm = new Calibration( ); calibrationForm.ShowDialog(); if (calibrationForm.DialogResult == System.Windows.Forms.DialogResult.OK) { serialPort.DataReceived += new SerialDataReceivedEventHandler(serial_DataReceived); } 但是现在的结果是回到主界面后返回的数据仍然在子窗口事件监听器中显示(通过Console打印返回的数据大小) ``` 求大神指点!!! ```

C#串口通讯实时读取数据,把数据分成25个一组

大学刚毕业在做实习生,老大交代的小任务,现在遇到的瓶颈,请各位大神能多多指导一下,最好直接上代码,谢谢各位!!!新手没有积分,还望慷慨 串口实时读取设备的数据,一直读,现在要以25个数据为一组,在winform的list view中显示出来,一行25个,一行25个,该怎么做,谢谢!!!![图片说明](https://img-ask.csdn.net/upload/201907/20/1563605519_255343.png)

C# 通过串口重复发送16进制数据有时候接收不正确的问题

C#编写的代码 串口信息 速率9600bits 数据8bit 停止1bit 校验无 软件发送 01 06 00 0c 00 00 49 c9(转换成byte[]发送) 串口调试工具接收到的数据正常时候为 01 06 00 0c 00 00 49 c9 但是会时不时的出现(前面4个不一样)00 00 63 20 00 00 49 c9 附图是连续发送50次接收到的数据 ![图片说明](https://img-ask.csdn.net/upload/201903/19/1552983178_232915.jpg) _______________________________________ 但是如果软件发送01 06 00 0c 00 01 88 09 串口调试工具接收的数据就没问题一直都是01 06 00 0c 00 01 88 09 如果把有问题的数据01 06 00 0c 00 00 49 c9最后一个c9,改成09,那也接收没问题 小弟完全搞不明白,请大神解惑.

C#串口读取较大的数据的问题

向下位机发送一条指令,会返回一串数据,数据比较大,可能有几十K,不确定具体大小,上位机怎么接受到完整的数据并保存到本地,求助。

C#通过串口控制led显示

有谁有用C#写的串口通信程序的源代码,就像串口调试助手那种软件,用PC通过串口来控制液晶显示模块?

2019 Python开发者日-培训

2019 Python开发者日-培训

150讲轻松搞定Python网络爬虫

150讲轻松搞定Python网络爬虫

设计模式(JAVA语言实现)--20种设计模式附带源码

设计模式(JAVA语言实现)--20种设计模式附带源码

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

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

java后台+微信小程序 实现完整的点餐系统

java后台+微信小程序 实现完整的点餐系统

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

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

初级玩转Linux+Ubuntu(嵌入式开发基础课程)

初级玩转Linux+Ubuntu(嵌入式开发基础课程)

2019 AI开发者大会

2019 AI开发者大会

玩转Linux:常用命令实例指南

玩转Linux:常用命令实例指南

一学即懂的计算机视觉(第一季)

一学即懂的计算机视觉(第一季)

4小时玩转微信小程序——基础入门与微信支付实战

4小时玩转微信小程序——基础入门与微信支付实战

Git 实用技巧

Git 实用技巧

Python数据清洗实战入门

Python数据清洗实战入门

使用TensorFlow+keras快速构建图像分类模型

使用TensorFlow+keras快速构建图像分类模型

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

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

程序员的算法通关课:知己知彼(第一季)

程序员的算法通关课:知己知彼(第一季)

MySQL数据库从入门到实战应用

MySQL数据库从入门到实战应用

机器学习初学者必会的案例精讲

机器学习初学者必会的案例精讲

手把手实现Java图书管理系统(附源码)

手把手实现Java图书管理系统(附源码)

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

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

.net core快速开发框架

.net core快速开发框架

玩转Python-Python3基础入门

玩转Python-Python3基础入门

Python数据挖掘简易入门

Python数据挖掘简易入门

微信公众平台开发入门

微信公众平台开发入门

程序员的兼职技能课

程序员的兼职技能课

Windows版YOLOv4目标检测实战:训练自己的数据集

Windows版YOLOv4目标检测实战:训练自己的数据集

HoloLens2开发入门教程

HoloLens2开发入门教程

微信小程序开发实战

微信小程序开发实战

Java8零基础入门视频教程

Java8零基础入门视频教程

相关热词 c# 解析cad c#数字格式化万 c#int转byte c#格式化日期 c# wpf 表格 c# 实现ad域验证登录 c#心跳包机制 c#使用fmod.dll c#dll vb 调用 c# outlook
立即提问
相关内容推荐