奇偶校驗位是數據通信中常用的一種錯誤檢測方法,根據被傳輸的一組二進制代碼中「1」的個數是奇數還是偶數來進行校驗。奇偶校驗位可以分為兩種類型:奇校驗和偶校驗。
奇校驗:在奇校驗中,校驗位被設置為使得整個位元組(包括校驗位)中「1」的個數為奇數。如果原始數據中「1」的個數已經是奇數,那麼校驗位就設置為0,使得總的「1」的個數為偶數。反之,如果原始數據中「1」的個數是偶數,校驗位就設置為1,使總的「1」的個數變為奇數。
偶校驗:在偶校驗中,校驗位被設置為使得整個位元組(包括校驗位)中「1」的個數為偶數。如果原始數據中「1」的個數已經是偶數,那麼校驗位就設置為0,保持總的「1」的個數為偶數。如果原始數據中「1」的個數是奇數,校驗位就設置為1,使總的「1」的個數變為偶數。
這兩種方法都可以檢測出數據傳輸過程中單個位的錯誤,但如果同時有兩個位發生錯誤,奇偶校驗就無法檢測出來了。因此,它只能檢測出錯誤,但不能糾正錯誤。
除了基本的奇偶校驗,還有更複雜的校驗方法,如循環冗餘校驗(crc)等,這些方法可以檢測出更多位的錯誤,並具有一定的錯誤糾正能力。
奇校驗:在奇校驗中,校驗位被設置為使得整個位元組(包括校驗位)中「1」的個數為奇數。如果原始數據中「1」的個數已經是奇數,那麼校驗位就設置為0,使得總的「1」的個數為偶數。反之,如果原始數據中「1」的個數是偶數,校驗位就設置為1,使總的「1」的個數變為奇數。
偶校驗:在偶校驗中,校驗位被設置為使得整個位元組(包括校驗位)中「1」的個數為偶數。如果原始數據中「1」的個數已經是偶數,那麼校驗位就設置為0,保持總的「1」的個數為偶數。如果原始數據中「1」的個數是奇數,校驗位就設置為1,使總的「1」的個數變為偶數。
這兩種方法都可以檢測出數據傳輸過程中單個位的錯誤,但如果同時有兩個位發生錯誤,奇偶校驗就無法檢測出來了。因此,它只能檢測出錯誤,但不能糾正錯誤。
除了基本的奇偶校驗,還有更複雜的校驗方法,如循環冗餘校驗(crc)等,這些方法可以檢測出更多位的錯誤,並具有一定的錯誤糾正能力。