0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
电子发烧友
开通电子发烧友VIP会员 尊享10大特权
海量资料免费下载
精品直播免费看
优质内容免费畅学
课程9折专享价
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

奇偶校驗(yàn)的優(yōu)缺點(diǎn)及奇偶校驗(yàn)代碼實(shí)現(xiàn)

嵌入式應(yīng)用開發(fā) ? 來源:嵌入式應(yīng)用開發(fā) ? 作者:嵌入式應(yīng)用開發(fā) ? 2022-06-18 18:14 ? 次閱讀

奇偶校驗(yàn)需要一位校驗(yàn)位,即使用串口通信的方式2或方式3(8位數(shù)據(jù)位+1位校驗(yàn)位)。

奇校驗(yàn)(odd parity):讓傳輸?shù)臄?shù)據(jù)(包含校驗(yàn)位)中1的個(gè)數(shù)為奇數(shù)。

即:如果傳輸字節(jié)中1的個(gè)數(shù)是偶數(shù),則校驗(yàn)位為“1”,奇數(shù)相反。

以發(fā)送字符:10101010為例

pYYBAGKtpaGALXtWAABMyPR8Bw0064.jpg

偶校驗(yàn)(even parity):讓傳輸?shù)臄?shù)據(jù)(包含校驗(yàn)位)中1的個(gè)數(shù)為偶數(shù)。

即:如果傳輸字節(jié)中1的個(gè)數(shù)是偶數(shù),則校驗(yàn)位為“0”,奇數(shù)相反。

還是以發(fā)送字符:10101010為例

poYBAGKtpaGASc73AABKhJU49Ck446.jpg

數(shù)據(jù)和校驗(yàn)位發(fā)送給接受方后,接收方再次對(duì)數(shù)據(jù)中1的個(gè)數(shù)進(jìn)行計(jì)算,如果為奇數(shù)則校驗(yàn)通過,表示此次傳輸過程未發(fā)生錯(cuò)誤。如果不是奇數(shù),則表示有錯(cuò)誤發(fā)生,此時(shí)接收方可以向發(fā)送方發(fā)送請(qǐng)求,要求重新發(fā)送一遍數(shù)據(jù)。

優(yōu)缺點(diǎn):

  • 奇偶校驗(yàn)的檢錯(cuò)率只有50%,因?yàn)橹挥衅鏀?shù)個(gè)數(shù)據(jù)位發(fā)生變化能檢測(cè)到,如果偶數(shù)個(gè)數(shù)據(jù)位發(fā)生變化則無能為力了╮(╯﹏╰)╭
  • 奇偶校驗(yàn)每傳輸一個(gè)字節(jié)都需要加一位校驗(yàn)位,對(duì)傳輸效率影響很大。
  • 奇偶校驗(yàn)只能發(fā)現(xiàn)錯(cuò)誤,但不能糾正錯(cuò)誤,也就是說它只能告訴你出錯(cuò)了,但不能告訴你怎么出錯(cuò)了,一旦發(fā)現(xiàn)錯(cuò)誤,只好重發(fā)。
  • 雖然奇偶校驗(yàn)有很多缺點(diǎn),但因?yàn)槠涫褂闷饋硎趾?jiǎn)單,故目前仍被廣泛使用。

應(yīng)用:

如何用編程確定一個(gè)字節(jié)中“1”個(gè)數(shù)的奇偶性?我們可以利用二進(jìn)制數(shù)相加的特點(diǎn):

0+0=0、1+0=1、1+1=0

可以看出,如果我們將一個(gè)字節(jié)的所有位相加

  • 有奇數(shù)個(gè)“1”的字節(jié)的和為1
  • 有偶數(shù)個(gè)“1”的字節(jié)的和為0

由此即可通過編程完成判斷。實(shí)際應(yīng)用中,實(shí)現(xiàn)方法很多,但這是相對(duì)簡(jiǎn)單的一種,這里不再贅述。

代碼實(shí)現(xiàn)部分如下:

#include
#include

unsigned char add(char data)//奇校驗(yàn) 
{
    int i, cnt = 0;

    for (i = 0; i < 7; i++)//一個(gè)char型有7位
    {
        int temp = ((data >> i) & 1);//data >> i是向右移i個(gè)位置得到的值,((data >> i) & 1)是與1不同的個(gè)數(shù)
        cnt += temp;//cnt記錄二進(jìn)制下data中1的個(gè)數(shù)
    }

    unsigned char ans = data << 1;//左移1位 
    
    if (cnt % 2 == 0)//當(dāng)cnt能夠被2整除,即cnt是偶數(shù),即1的個(gè)數(shù)是偶數(shù)
    {
        ans += 1;//在最右邊加1
    }
    else//當(dāng)cnt不能夠被2整除,即cnt是奇數(shù),即1的個(gè)數(shù)是奇數(shù)
    {
        ans += 0;//在最右邊加0
    }
    return ans;
}

unsigned char add_2(char data)//偶校驗(yàn) 
{
    int i, cnt = 0;

    for (i = 0; i < 7; i++)//一個(gè)char型有7位
    {
        int temp = ((data >> i) & 1);//data >> i是向右移i個(gè)位置得到的值,((data >> i) & 1)是與1不同的個(gè)數(shù)
        cnt += temp;//cnt記錄二進(jìn)制下data中1的個(gè)數(shù)
    }

    unsigned char ans = data << 1;//左移1位 
    
    if (cnt % 2 == 0)//當(dāng)cnt能夠被2整除,即cnt是偶數(shù),即1的個(gè)數(shù)是偶數(shù)
    {
        ans += 0;//在最右邊加0
    }
    else//當(dāng)cnt不能夠被2整除,即cnt是奇數(shù),即1的個(gè)數(shù)是奇數(shù)
    {
        ans += 1;//在最右邊加1
    }
    return ans;
}

int main()
{
    char a;
    unsigned char b;
    scanf("%c", &a);
    b = add(a);
    printf("2進(jìn)制結(jié)果表示為:");//輸出b的2進(jìn)制表示
    for (int i = 7; i >= 0; i--) {
        if (((b>>i) & 1) == 1)
            printf("1");
        else
            printf("0");
    } putchar(10);
    
    return 0;
}

審核編輯:符乾江
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 嵌入式C
    +關(guān)注

    關(guān)注

    0

    文章

    6

    瀏覽量

    6864
  • 奇偶校驗(yàn)
    +關(guān)注

    關(guān)注

    0

    文章

    15

    瀏覽量

    8290
收藏 0人收藏

    評(píng)論

    相關(guān)推薦

    請(qǐng)問DAC3484的LVDS數(shù)字接口如何區(qū)分4個(gè)信道?

    我會(huì)使用WORD-WIDE FORMAT格式,F(xiàn)PGA輸出數(shù)字信號(hào)給DAC3484,但是如何區(qū)分A B C D4個(gè)信道啊,時(shí)鐘DDR的雙沿只能區(qū)分兩個(gè),4個(gè)還需要一個(gè)指示信號(hào)?。縟atasheet看不出來,F(xiàn)RAMEP/N SYNCP/N講的不是很明白好像說是同步和奇偶校驗(yàn)用的。
    發(fā)表于 01-09 06:07

    RAID 5 磁盤陣列的組成

    奇偶校驗(yàn)信息來提高性能和容錯(cuò)能力。 RAID 5的基本概念 RAID 5是一種基于奇偶校驗(yàn)的RAID級(jí)別,它將數(shù)據(jù)和奇偶校驗(yàn)信息分布在多個(gè)磁盤上。這種分布方式允許RAID 5陣列在一塊磁盤發(fā)生故障時(shí)繼續(xù)運(yùn)行,并能夠重建丟失的數(shù)
    的頭像 發(fā)表于 12-27 17:06 ?982次閱讀

    RAID 5 技術(shù)優(yōu)勢(shì)與應(yīng)用

    在現(xiàn)代數(shù)據(jù)中心和企業(yè)級(jí)存儲(chǔ)解決方案中,數(shù)據(jù)的可靠性、性能和可用性是至關(guān)重要的。RAID 5 作為一種流行的 RAID 配置,通過在多個(gè)硬盤上分散數(shù)據(jù)和奇偶校驗(yàn)信息,提供了這些關(guān)鍵特性。 一、RAID
    的頭像 發(fā)表于 12-27 17:01 ?1069次閱讀

    dac161p997這幾個(gè)寄存器全配置為0,當(dāng)發(fā)生錯(cuò)誤時(shí),dac161p997會(huì)不會(huì)依據(jù)錯(cuò)誤的數(shù)據(jù)進(jìn)行輸出?

    請(qǐng)問dac161p997這幾個(gè)寄存器全配置為0,當(dāng)發(fā)生錯(cuò)誤時(shí)(比如奇偶校驗(yàn)),dac161p997會(huì)不會(huì)依據(jù)錯(cuò)誤的數(shù)據(jù)進(jìn)行輸出?
    發(fā)表于 12-06 08:12

    raid 硬盤陣列優(yōu)缺點(diǎn)

    、提高性能或兩者兼顧。以下是關(guān)于RAID硬盤陣列的優(yōu)缺點(diǎn)的介紹: RAID的優(yōu)點(diǎn): 數(shù)據(jù)冗余和容錯(cuò)能力 : RAID 1(鏡像)和RAID 5(帶奇偶校驗(yàn)的條帶)等配置可以在硬盤故障時(shí)保護(hù)數(shù)據(jù)不丟失,因?yàn)閿?shù)據(jù)在多個(gè)硬盤上有備份。 RAID 6(雙
    的頭像 發(fā)表于 11-12 09:33 ?1617次閱讀

    如何通過I2C加載TPS2388x SRAM和奇偶校驗(yàn)代碼

    電子發(fā)燒友網(wǎng)站提供《如何通過I2C加載TPS2388x SRAM和奇偶校驗(yàn)代碼.pdf》資料免費(fèi)下載
    發(fā)表于 09-06 11:16 ?0次下載
    如何通過I2C加載TPS2388x SRAM和<b class='flag-5'>奇偶校驗(yàn)</b><b class='flag-5'>代碼</b>

    Traveo T2G SRAM不是32位的嗎?如何得到一個(gè)64位的?

    在進(jìn)行sram的ecc故障注入的時(shí)候,需要計(jì)算其ecc校驗(yàn)值,在手冊(cè)上有這樣的描述 10.3.4 由軟件生成 ECC 奇偶校驗(yàn) 要注入 ECC 錯(cuò)誤以生成故障,必須由軟件生成 ECC 奇偶校驗(yàn)
    發(fā)表于 06-03 08:49

    8位到9位奇偶校驗(yàn)總線收發(fā)器ABT8338數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《8位到9位奇偶校驗(yàn)總線收發(fā)器ABT8338數(shù)據(jù)表.pdf》資料免費(fèi)下載
    發(fā)表于 05-30 10:02 ?0次下載
    8位到9位<b class='flag-5'>奇偶校驗(yàn)</b>總線收發(fā)器ABT8338數(shù)據(jù)表

    奇偶校驗(yàn)發(fā)生器/校驗(yàn)器和3態(tài)輸出的16位收發(fā)器ABT16657數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《帶奇偶校驗(yàn)發(fā)生器/校驗(yàn)器和3態(tài)輸出的16位收發(fā)器ABT16657數(shù)據(jù)表.pdf》資料免費(fèi)下載
    發(fā)表于 05-30 09:45 ?0次下載
    帶<b class='flag-5'>奇偶校驗(yàn)</b>發(fā)生器/<b class='flag-5'>校驗(yàn)</b>器和3態(tài)輸出的16位收發(fā)器ABT16657數(shù)據(jù)表

    8位到9位奇偶校驗(yàn)總線收發(fā)器SN74BCT29854數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《8位到9位奇偶校驗(yàn)總線收發(fā)器SN74BCT29854數(shù)據(jù)表.pdf》資料免費(fèi)下載
    發(fā)表于 05-29 09:50 ?0次下載
    8位到9位<b class='flag-5'>奇偶校驗(yàn)</b>總線收發(fā)器SN74BCT29854數(shù)據(jù)表

    奇偶校驗(yàn)發(fā)生器/校驗(yàn)器和3態(tài)輸出的八進(jìn)制收發(fā)器SN74F657數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《帶奇偶校驗(yàn)發(fā)生器/校驗(yàn)器和3態(tài)輸出的八進(jìn)制收發(fā)器SN74F657數(shù)據(jù)表.pdf》資料免費(fèi)下載
    發(fā)表于 05-29 09:44 ?0次下載
    帶<b class='flag-5'>奇偶校驗(yàn)</b>發(fā)生器/<b class='flag-5'>校驗(yàn)</b>器和3態(tài)輸出的八進(jìn)制收發(fā)器SN74F657數(shù)據(jù)表

    奇偶校驗(yàn)器和雙3態(tài)輸出的3.3-V 12位通用總線驅(qū)動(dòng)器SN74ALVCH16903數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《帶奇偶校驗(yàn)器和雙3態(tài)輸出的3.3-V 12位通用總線驅(qū)動(dòng)器SN74ALVCH16903數(shù)據(jù)表.pdf》資料免費(fèi)下載
    發(fā)表于 05-29 09:31 ?0次下載
    帶<b class='flag-5'>奇偶校驗(yàn)</b>器和雙3態(tài)輸出的3.3-V 12位通用總線驅(qū)動(dòng)器SN74ALVCH16903數(shù)據(jù)表

    雙8位至9位奇偶校驗(yàn)總線收發(fā)器ABT16833數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《雙8位至9位奇偶校驗(yàn)總線收發(fā)器ABT16833數(shù)據(jù)表.pdf》資料免費(fèi)下載
    發(fā)表于 05-24 09:29 ?0次下載
    雙8位至9位<b class='flag-5'>奇偶校驗(yàn)</b>總線收發(fā)器ABT16833數(shù)據(jù)表

    做lora通訊用到usart,配置時(shí)遇到的usart奇偶校驗(yàn)問題求解

    今天做lora通訊,用到usart,配置時(shí)發(fā)現(xiàn)usart奇偶校驗(yàn)困惑。假如CR1->M、CR1->PCE、CR1->PS均置位即發(fā)送9位數(shù)據(jù)(含最高
    發(fā)表于 05-20 08:30

    8位到9位奇偶校驗(yàn)總線收發(fā)器數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《8位到9位奇偶校驗(yàn)總線收發(fā)器數(shù)據(jù)表.pdf》資料免費(fèi)下載
    發(fā)表于 05-15 09:33 ?0次下載
    8位到9位<b class='flag-5'>奇偶校驗(yàn)</b>總線收發(fā)器數(shù)據(jù)表

    電子發(fā)燒友

    中國電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會(huì)員交流學(xué)習(xí)
    • 獲取您個(gè)性化的科技前沿技術(shù)信息
    • 參加活動(dòng)獲取豐厚的禮品