Public Function Chr_crc(data() As Byte) As String '*RTU方式的CRC校驗計算 Dim CrcJ As Long Dim i As Integer Dim j As Integer CrcJ = 65535 '*CRCj賦值65535 For i = 0 To UBound(data) '- 2 '*循環參加校驗的字節個數 CrcJ = CrcJ Xor data(i) '*每個字節與CRCj的當前值異或 For j = 0 To 7 '*循環八次 If CrcJ Mod 2 = 1 Then '*如果CRCj當前值除2的余數等於1 判斷最低位是否為1 CrcJ = CrcJ \ 2 '*則CRCj當前值除2 右移 CrcJ = CrcJ Xor 40961 '*CRCj當前值與40961異或 Else CrcJ = CrcJ \ 2 '*如果CRCj當前值最低位不等於1 則只右移 End If Next j Next i Chr_crc = Right("0000" + Hex(CrcJ), 4) '*計算的CRCj當前值轉換為十六進制 Chr_crc = Right(Chr_crc, 2) + Left(Chr_crc, 2) '*低字節放在前面,高字節放在后面 End Function