亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Java實現計網循環冗余檢驗算法的方法示例

瀏覽:2日期:2022-08-14 13:43:09
相關知識點

在數據鏈路層傳送的幀中,廣泛使用了循環冗余檢驗 CRC 的檢錯技術。

循環冗余檢驗的原理

在發送端,先把數據劃分為組。假定每組 k 個比特。 在每組 M 后面再添加供差錯檢測用的 n 位冗余碼,然后一起發送出去。

冗余碼的計算

用二進制的模 2 運算進行 2n 乘 M 的運算,這相當于在 M 后面添加 n 個 0。 得到的 (k + n) 位的數除以事先選定好的長度為 (n + 1) 位的除數 P,得出商是 Q 而余數是 R,余數 R 比除數 P 少 1 位,即 R 是 n 位。 將余數 R 作為冗余碼拼接在數據 M 后面,一起發送出去。

接收端對收到的每一幀進行 CRC 檢驗

(1) 若得出的余數 R = 0,則判定這個幀沒有差錯,就接受 (accept)。 (2) 若余數 R ≠ 0,則判定這個幀有差錯,就丟棄。 但這種檢測方法并不能確定究竟是哪一個或哪幾個比特出現了差錯。 只要經過嚴格的挑選,并使用位數足夠多的除數 P,那么出現檢測不到的差錯的概率就很小很小。

Java實現計網循環冗余檢驗算法的方法示例

冗余碼的計算舉例

現在 k = 6, M = 101001。 設 n = 3, 除數 P = 1101, 被除數是 2nM = 101001000。 模 2 運算的結果是:商 Q = 110101,余數 R = 001。 把余數 R 作為冗余碼添加在數據 M 的后面發送出去。發送的數據是:2nM + R,即:101001001,共 (k + n) 位。

模2除法步驟

用除數對被除數最高幾位做模2減,沒有借位; 除數右移一位,若余數最高位為1,商為1,并對余數做模2減。若余數最高位為0,商為0,除數繼續右移一位; 一直做到余數的位數小于除數時,該余數就是最終余數。

Java實現計網循環冗余檢驗算法的方法示例

代碼實現

package computernetwork;// 循環冗余檢驗 Cyclic Redundancy Check (CRC)public class CRC { private int[] generatingCode; // 生成碼 // 設置生成碼 public void setGeneratingCode(String str) {generatingCode = stringToArray(str); } // 獲取幀檢驗序列 public String getFCS(String message) {for (int i = 0; i < generatingCode.length - 1; i++) { message += '0';}return getRemainder(stringToArray(message)); } // 判斷接受碼是否產生跳變 public boolean judge(String res) {return Integer.parseInt(getRemainder(stringToArray(res))) == 0; } // 將01字符串轉換為數組 private int[] stringToArray(String str) {char[] chars = str.toCharArray();int[] res = new int[chars.length];for (int i = 0; i < chars.length; i++) { res[i] = chars[i] - ’0’;}return res; } // 求余數 private String getRemainder(int[] code) {int len = code.length - generatingCode.length + 1;for (int i = 0; i < len; i++) { if (code[i] != 0) {for (int j = 0; j < generatingCode.length; j++) { code[i + j] ^= generatingCode[j];} }}StringBuilder res = new StringBuilder();for (int i = len; i < code.length; i++) { res.append(code[i]);}return res.toString(); }}class TestCRC { public static void main(String[] args) {CRC crc = new CRC();crc.setGeneratingCode('10011');System.out.println(crc.getFCS('1101011011')); // 1110System.out.println(crc.judge('11010110111110')); // trueSystem.out.println(crc.judge('11010110111011')); // false }}總結

到此這篇關于Java實現計網循環冗余檢驗算法的文章就介紹到這了,更多相關Java計網循環冗余檢驗算法內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Java
相關文章:
主站蜘蛛池模板: 夜夜操夜夜爱 | 国产麻豆剧看黄在线观看 | 日韩国产精品欧美一区二区 | 国产成人亚洲综合 | 成人午夜视频免费 | 国产一区二区三区免费视频 | 亚洲激情视频图片 | 中国的毛片 | 麻豆视频免费观看入口 | 日本欧美国产精品 | 成人国产精品免费视频 | 国产亚洲精品国看不卡 | 亚洲综合国产精品 | 毛片毛片大全aaaa | 青青青视频蜜桃一区二区 | 亚洲精品中文字幕乱码一区二区 | 伊人久久久综在合线久久在播 | 最新国产午夜精品视频成人 | 看成年全黄大色黄大片 | 黄色欧美视频在线观看 | 国产福利不卡视频在免费 | 成人永久免费 | 一级黄色录像大片 | 国产真实伦偷精品 | 中文字幕综合久久久久 | 中文字幕一区二区三区四区 | 91大神成人偷拍在线观看 | 亚洲爱色 | 亚洲一级免费毛片 | 日韩欧美影视 | 久久成人小视频 | 黄色网页在线观看 | 一级一级一级一级毛片 | 亚洲欧美一区二区三区 | 日本高清免费不卡视频 | 午夜成年人网站 | 日韩欧美毛片 | 毛片免费观看的视频在线 | 69成人做爰视频在线观看 | 亚洲品质自拍视频 | 国产精品馆 |