#include "windows.h"
#include <iostream>
#include <TCHAR.H>
#include <string.h>
using namespace std;
HANDLE hCom; //全局变量,串口句柄
int serial_open(LPCWSTR COM1, int BaudRate) {
hCom = CreateFile(COM1, //COM1口
GENERIC_READ | GENERIC_WRITE, //允许读和写
0, //独占方式
NULL,
OPEN_EXISTING, //打开而不是创建
0, //重叠方式FILE_ATTRIBUTE_NORMAL | FILE_FLAG_OVERLAPPED (同步方式设置为0)
NULL);
if (hCom == INVALID_HANDLE_VALUE)
{
printf("打开COM失败!\n");
return FALSE;
}
SetupComm(hCom, 1024, 1024); //输入缓冲区和输出缓冲区的大小都是1024
//设定读写超时
/*COMMTIMEOUTS TimeOuts;
TimeOuts.ReadIntervalTimeout=1000;
TimeOuts.ReadTotalTimeoutMultiplier=500;
TimeOuts.ReadTotalTimeoutConstant=5000; //设定写超时
TimeOuts.WriteTotalTimeoutMultiplier=500;
TimeOuts.WriteTotalTimeoutConstant = 2000;
SetCommTimeouts(hCom, &TimeOuts); //设置超时
*/
DCB dcb;
GetCommState(hCom, &dcb);
dcb.BaudRate = BaudRate; //设置波特率为BaudRate
dcb.ByteSize = 8; //每个字节有8位
dcb.Parity = NOPARITY; //无奇偶校验位
dcb.StopBits = ONESTOPBIT; //一个停止位
SetCommState(hCom, &dcb); //设置参数到hCom
PurgeComm(hCom, PURGE_TXCLEAR | PURGE_RXCLEAR);//清空缓存区 //PURGE_TXABORT 中断所有写操作并立即返回,即使写操作还没有完成。
//PURGE_RXABORT 中断所有读操作并立即返回,即使读操作还没有完成。
//PURGE_TXCLEAR 清除输出缓冲区
//PURGE_RXCLEAR 清除输入缓冲区
return TRUE;
}
int serial_write(char lpOutBuffer[]) //同步写串口
{
DWORD dwBytesWrite = sizeof(lpOutBuffer);
COMSTAT ComStat;
DWORD dwErrorFlags;
BOOL bWriteStat;
ClearCommError(hCom, &dwErrorFlags, &ComStat);
bWriteStat = WriteFile(hCom, lpOutBuffer, dwBytesWrite, &dwBytesWrite, NULL);
if (!bWriteStat)
{
printf("写串口失败!\n");
return FALSE;
}
PurgeComm(hCom, PURGE_TXABORT | PURGE_RXABORT | PURGE_TXCLEAR | PURGE_RXCLEAR);
return TRUE;
}
void Serial_close(void) //关闭串口
{
CloseHandle(hCom);
}
int main()
{
serial_open(_T("COM1"), 4800); //打开COM1,波特率为4800
serial_write("数据");//数据
Serial_close();//关闭串口
system("pause");
return 0;
}
这个是以前自己搞的一个串口通讯跟之前写的不一样,运用的时候只需调整我们的串口以及波特率,然后发送我们所需要的的数据,当然我们还需要根据我们的数据来调整所发的字节数,免得漏发。
之后我们 将能够冲串口调试小助手里面得到我们发送的数据,以下是运行结果