寫了個串口程式,重啟電腦后,串口就接受不到資訊了,這是怎么回事?
這個時候用串口工具隨便發送一條資訊過去,接著再打開自己的串口程式,如果不重啟電腦,程式就一直都能正常收發資訊了,這是怎么一回事啊?
是我自己程式的問題嗎?
uj5u.com熱心網友回復:
int CHTDLPCard::OpenPort() //打開串口
{
CString strComm;
int die;
die = ::GetPrivateProfileInt("HARDWARE", "卡串口號", 0, ".\\card.ini");
strComm.Format("%s%d", "COM", die);
m_hCom = CreateFile(strComm,//COM1口
GENERIC_READ | GENERIC_WRITE, //允許讀和寫
0, //獨占方式
NULL,
OPEN_EXISTING, //打開而不是創建
0, //同步方式
NULL);
int a = GetLastError();
if (m_hCom == INVALID_HANDLE_VALUE)
{
AfxMessageBox("卡串口打開失敗");
m_bOpen = FALSE;
return FALSE;
}
//else
//AfxMessageBox("打開串口成功");
SetCommMask(m_hCom, EV_RXCHAR);
//清干凈輸入、輸出緩沖區
PurgeComm(m_hCom, PURGE_TXABORT | PURGE_RXABORT | PURGE_TXCLEAR | PURGE_RXCLEAR);
SetupComm(m_hCom, 2048, 2048); //輸入緩沖區和輸出緩沖區的大小都是1024
COMMTIMEOUTS TimeOuts;
//設定讀超時
TimeOuts.ReadIntervalTimeout = MAXDWORD;//把間隔超時設為最大,把總超時設為0,將導致ReadFile立即回傳并完成操作
TimeOuts.ReadTotalTimeoutMultiplier = 1;
TimeOuts.ReadTotalTimeoutConstant = 5;
//設定寫超時
TimeOuts.WriteTotalTimeoutMultiplier = 1;
TimeOuts.WriteTotalTimeoutConstant = 5;
SetCommTimeouts(m_hCom, &TimeOuts); //設定超時
GetCommState(m_hCom, &dcb);
dcb.BaudRate = m_nBaud; //波特率為9600
dcb.ByteSize = m_nDataBits; //每個位元組有8位
dcb.Parity = m_nParity; //無奇偶校驗位
dcb.StopBits = m_nStopBits; //停止位
SetCommState(m_hCom, &dcb);
m_bOpen = TRUE;
COMSTAT ComStat;
DWORD dwErrorFlags = 0;
ClearCommError(m_hCom, &dwErrorFlags, &ComStat);
return 1;
}
int CHTDLPCard::SendData(HANDLE com /*串口號*/,
BYTE bFun /*功能碼*/,
BYTE bDataLen /*資料長度*/,
BYTE* pbData /*資料*/) //發送資料,例如SendData(com, 0x01, 0, NULL)
{
//檢查引數
if (bDataLen < 0)
return 0;
//總目標發送長度
int iTxLen = 0
+ 2 //位元組頭
+ 1 //功能碼
+ 1 //位元組長度
+ bDataLen //資料長度
+ 2 //校驗
+ 2 //位元組尾
+ 0;
//申請緩沖區
BYTE* pTxData = new BYTE[iTxLen];
//構造發送資料幀
int iOfst = 0;
pTxData[iOfst] = 0xC1; iOfst++;//位元組頭
pTxData[iOfst] = 0xC2; iOfst++;
pTxData[iOfst] = bFun; iOfst++;//功能碼
pTxData[iOfst] = bDataLen + 2; /*資料位+兩個校驗位*/ iOfst++;//位元組長度
memcpy(pTxData + iOfst, pbData, bDataLen); iOfst += bDataLen;//資料
{ //計算校驗位
uint16_t checksum = getChecksum(pTxData, iOfst);
//ULONG uSumL = 0;//之前所有資料的累計和
//for (int n = 0; n < iOfst; n++) { uSumL += pTxData[n]; }
////(高16位+低16位)后取反
//WORD wSum = (WORD)(~(HIWORD(uSumL) + LOWORD(uSumL)));
#ifdef _BIG_ENDIAN //大端模式
pTxData[iOfst] = checksum >> 8; iOfst++;
pTxData[iOfst] = checksum; iOfst++;
//pTxData[iOfst] = HIBYTE(wSum); iOfst++;
//pTxData[iOfst] = LOBYTE(wSum); iOfst++;
#else //!_BIG_ENDIAN //小端模式
pTxData[iOfst] = checksum >> 8; iOfst++;
pTxData[iOfst] = checksum; iOfst++;
//pTxData[iOfst] = LOBYTE(wSum); iOfst++;
//pTxData[iOfst] = HIBYTE(wSum); iOfst++;
#endif
}
pTxData[iOfst] = 0x0A; iOfst++;//位元組尾
pTxData[iOfst] = 0x0D; iOfst++;
//COMSTAT ComStat; //清理緩沖區
//DWORD dwErrorFlags;
//ClearCommError(m_hCom, &dwErrorFlags, &ComStat);
//PurgeComm(m_hCom, PURGE_TXABORT | PURGE_RXABORT | PURGE_TXCLEAR | PURGE_RXCLEAR);
//這里用串口等通訊介面發送資料
DWORD bytesWritten;
bool ret = WriteFile(com, pTxData, iOfst, &bytesWritten, 0);
//結束清理
delete[] pTxData;
if (ret)
return 1;
else
return 0;
}
uj5u.com熱心網友回復:
是我串口沒有打開?或者是電腦問題,第一次打開串口有什么特別的東西要做,我程式中沒寫?我發送資料下去,程式既不執行指令,也不回報資訊。
用一個串口監控軟體看了下,只有下發的資訊,沒有讀取到資訊
uj5u.com熱心網友回復:
這里錯了?我發現當執行 SetCommState 是程式報錯,也就是設定串口的時候出現錯誤了。再仔細檢查發現設定 dcb.StopBits屬性時直接賦值為1,然而事實上這并不代表停止位為1,而是1.5。關于StopBits 的描述是這樣子的:dcb.StopBits //兩個停止位 0,1,2 = 1, 1.5, 2 ,當StopBits 值為0是代表停止位為1,值為1時代表停止位為1.5。而計算機并沒有1.5這個設定,因此 SetCommState 報錯,也就是初始化串口沒有成功。
————————————————
著作權宣告:本文為CSDN博主「kfhzy」的原創文章,遵循CC 4.0 BY-SA著作權協議,轉載請附上原文出處鏈接及本宣告。
原文鏈接:https://blog.csdn.net/kfhzy/article/details/11607545
uj5u.com熱心網友回復:
GetCommState 之前 DCB 要先賦值 DCBlengthDCB dcb = { sizeof(DCB) };
GetCommState(m_hCom, &dcb);
轉載請註明出處,本文鏈接:https://www.uj5u.com/gongcheng/273415.html
上一篇:求幫助double變數存盤和比較
