VB Modbus RTU CRC 校驗


 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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM