c語言校驗和
『壹』 c語言計算檢驗和。。。。。。。。
第一段是將高nleft/2位的數字累加第二段式說 如果nleft=1 sum等於 w的高位第三段 將sum的高十六位移到地十六位 並與原sum的低16位相加然後再把得到的這個數取反 至於這句話sum+=(sum>>16); 我也沒太看懂sum已經剩下低16位了再右移不久是0了嗎 加0有什麼意義呢?這大概是一個校驗碼的生成方法你對照這個方法看代碼應該就很容易理解了我現在看代碼也就是看看代碼再干什麼
『貳』 如何用C語言判斷一個校驗和是否超過8位
放在一個無符4位元組整數里 大於了255說明超過了8位 這時把整數與上ox000000FF就去掉高位了
『叄』 如何校驗和是通過一定的演算法掃描一個數據計算出的一個數值。用C語言
#include<stdio.h>
intQuicksum(char*str)//用指針做校驗函數的參數,來接收被校驗的字元串A;
{
intsum=0,loc=1,i,n;//sum代表校驗和,loc代表每個字元在字元串A里的位置;
char*p;
p=str;//將被校驗字元串A的地址賦值給字元指針p,用p表示位置;
n=strlen(p);//用strlen函數求出A的有效長度;
for(i=0;i<n;i++)//注意循環的次數。體會i<n的意思,保證能計算到每個字元
{
if((*p)==''){p++;loc++;continue;}//如果遇到空格,就將位置指針向後移動一個,跳過空格
//注意loc也要增加一,為了正確記錄每個字元的位置
sum+=((*p-'A')+1)*loc;//如果此處不是空格,就根據校驗計算該位置所代表的和,進行累加
loc++;//將位置指針移動到下一個字元,同時loc也跟著變化
p++;
}
returnsum;//返回校驗和
}
voidmain()
{
intjiaoyanhe;
char*string;
printf("Pleaseinput(A-Z):");
gets(string);//使用gets函數輸入字元串;
jiaoyanhe=Quicksum(string);//調用Quicksum函數進行校驗和的計算。
printf("jiaoyanhe:");
printf("%d ",jiaoyanhe);
}
上機運行的時候,把注釋全刪了吧,要不然可能運行出錯,多體會一下吧,這只是其中的一種方法而已,多上機運行代碼,理解下裡面的邏輯,好運。
『肆』 C語言字元串校驗和
請把問題的描述提供的更具體一些,否則無法提供更詳細的幫助。
就現有的信息來看,有這幾個點:
1.C語言字元串。就是以單位元組字元為內容,用'\0'表示結尾的字元串表示方式。
2.校驗和。由數據計算得到的一個數值,具有以下兩個特性:
a)相同的數據計算出的校驗和結果必定是相同的
b)數據有所變動時,計算出的校驗和一般不相同
常用的校驗和有累加和異或方式。比如,[1,2,3,4,5]這一組數據的累加較驗和就是1+2+3+4+5=15
3.異或。異或是一種二進制(邏輯)運算,定義如下:
1與1、0與0的異或結果為0
1與0、0與1的異或結果為1
如35和27,其二進製表示為:100011和11011。低位對齊後進行異或,結果為:111000,也就是56
4.在C語言中,異或運算的運算符為:^
也就是說35^27的值就是56。
『伍』 校驗和的C語言解答
【temp=temp+*chk8;】
temp加上 chk8地址上的值 再復制給temp
【if(temp<*chk8)】
如果temp小於chk8地址上的值
temp自增
chk8位置自增
*chk8 你可以當它是個變數
chk8 的值是一個地址
chk8++ 指針往後移,後移的大小和指針指向類型大小一樣.
『陸』 用單片機實現三菱變頻器通訊, 通過三菱專用協議通訊,如何用c語言實現協議中的和校驗,請高人指點
#include<stdio.h>
/*校驗和函數*/
intchecksum(constchar*arr,intarrsize)
{
inti=0,sum=0;
for(;i<arrsize;i++)
sum+=(unsignedchar)arr[i];
if(sum>0xff)
{
sum=~sum;
sum+=1;
}
sum&=0xff;
returnsum;
}
intmain(void)
{
charstr[]="hello,world ";
printf("0x%x ",checksum(str,sizeof(str)));
return0;
}
『柒』 C語言累加和校驗
用位運算按位與得出校驗數,參考代碼如下:
#include<stdio.h>
int main()
{
char str[101];
int i,sum;
gets(str);
i=sum=0;
while(str[i]!=0)
sum+=str[i++];
printf("%d",sum&(0x0FF));
return 0;
}
『捌』 C語言程序如何校驗和執行
Ctrl+F9 - Alt+F5 反正不管哪個版本 先組建再編譯 系統就自動檢查是否有錯誤 最後在運行就OK了。
『玖』 這個ip校驗和代碼是什麼意思看不懂!求高手!c語言版的!
這個應該是ICMP協議的checksum
short checksum(ushort buffer int size) //這里定義的是指針吧 unsigned short *buffer,為ICMP的協議類型ICMP_ECHO值為8,size為發送封包大小,因為ip header佔20位元組,所以你發送一個最短的64bytes的數據包,size為44
unsigned long cksum = 0 //32位系統佔4個位元組,32個位,後面有低位和高位運算
while(size> 1)//為什麼size要大於1
{
cksum += buffer++ //這個應該是cksum += *buffer++,指針偏移
size -= sizeof(ushort) //size -= 2,判斷循環執行次數
}
if(size)
{
cksum += (uchar)buffer //如果packet為奇數,例如65,那個再加一次buffer
}
cksum = (cksum> > 16) + (cksum& 0xffff) //將高16bit與低16bit相加(&與運算把最高位去除 得到他的後16位)(整數移位後會只取整數部分)
cksum += (cksum> > 16) //將進位到高位的16bit與低16bit 再相加,為什麼這里不進行與運算????
return (ushort)(~cksum) //~取反(轉換成短整型)
}
『拾』 求高手解析一下一段C語言的校驗和代碼轉成C#後的問題
應該沒問題
c得出的51其實是0x51
c#得出81是十進制的,其實也等於0x51
然後,c#也能uSum = (~uSum) + 1;這么寫 不需要那麼多格式轉換