C++計算ICMP頭的校驗和實例
更新時間:2014年10月21日 11:30:29 投稿:shichen2014
這篇文章主要介紹了C++計算ICMP頭的校驗和的方法,代碼簡單實用,對于校驗ICMP報文來說有不錯的實用價值,需要的朋友可以參考下
本文實例講述了C++計算ICMP頭的校驗和的方法,分享給大家供大家參考。具體實現(xiàn)代碼如下:
復(fù)制代碼 代碼如下:
USHORT checksum(USHORT* buff, int nSize)
{
unsigned long cksum=0;
//將數(shù)據(jù)以字為單位加到cksum
while (nSize > 1)
{
cksum += *buff++;
nSize -= sizeof(USHORT);
}
//如果為奇數(shù), 將最后一個字?jǐn)U展到雙字,再累加
if (nSize)
{
cksum += *(UCHAR*)buff;
}
//將cksum的高16位與低16位相加,取反后得到校驗和
cksum = (cksum>>16) + (cksum&&0xffff);
cksum += (cksum>>16);
return (USHORT)(~cksum);
}
{
unsigned long cksum=0;
//將數(shù)據(jù)以字為單位加到cksum
while (nSize > 1)
{
cksum += *buff++;
nSize -= sizeof(USHORT);
}
//如果為奇數(shù), 將最后一個字?jǐn)U展到雙字,再累加
if (nSize)
{
cksum += *(UCHAR*)buff;
}
//將cksum的高16位與低16位相加,取反后得到校驗和
cksum = (cksum>>16) + (cksum&&0xffff);
cksum += (cksum>>16);
return (USHORT)(~cksum);
}
希望本文所述對大家的C++程序設(shè)計有所幫助。
相關(guān)文章
C++計算任意權(quán)值的單源最短路徑(Bellman-Ford)
這篇文章主要為大家詳細介紹了C++計算任意權(quán)值的單源最短路徑,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-04-04
C++ 詳細講解stack與queue的模擬實現(xiàn)
C++ Stack(堆棧) 是一個容器類的改編,為程序員提供了堆棧的全部功能,也就是說實現(xiàn)了一個先進后出(FILO)的數(shù)據(jù)結(jié)構(gòu),許多程序都使用了 queue 容器。queue 容器可以用來表示超市的結(jié)賬隊列或服務(wù)器上等待執(zhí)行的數(shù)據(jù)庫事務(wù)隊列2022-04-04
C++中靜態(tài)成員函數(shù)訪問非靜態(tài)成員的實例
這篇文章主要介紹了C++中靜態(tài)成員函數(shù)訪問非靜態(tài)成員的實例的相關(guān)資料,需要的朋友可以參考下2017-07-07
C語言中關(guān)于庫函數(shù) qsort 快排的用法
快速排序Qsort是所有學(xué)習(xí)算法和數(shù)據(jù)結(jié)構(gòu)最基礎(chǔ)的一個部分,也是考試題和面試的一個小重點。本片文章帶你了解Qsort的詳細用法規(guī)則2021-09-09

