欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

c語(yǔ)言算術(shù)運(yùn)算符越界問(wèn)題解決方案

 更新時(shí)間:2012年11月14日 12:01:10   作者:  
大量的安全漏洞是由于計(jì)算機(jī)算術(shù)運(yùn)算的微妙細(xì)節(jié)引起的, 具體的C語(yǔ)言, 諸如符號(hào)數(shù)和無(wú)符號(hào)數(shù)之間轉(zhuǎn)換, 算術(shù)運(yùn)算的越界都會(huì)導(dǎo)致不可預(yù)知的錯(cuò)誤和安全漏洞, 具體的案例數(shù)不勝數(shù).
大量的安全漏洞是由于計(jì)算機(jī)算術(shù)運(yùn)算的微妙細(xì)節(jié)引起的, 具體的C語(yǔ)言, 諸如符號(hào)數(shù)和無(wú)符號(hào)數(shù)之間轉(zhuǎn)換, 算術(shù)運(yùn)算的越界都會(huì)導(dǎo)致不可預(yù)知的錯(cuò)誤和安全漏洞, 具體的案例數(shù)不勝數(shù).

作為一個(gè)系統(tǒng)程序員, 有必要對(duì)這些細(xì)節(jié)有深入的了解. 本篇參考csapp, 主要介紹如何判斷算術(shù)運(yùn)算的越界問(wèn)題.

(雖然本篇的代碼經(jīng)過(guò)大量的測(cè)試, 但本人仍然無(wú)法保證代碼的正確性, 希望大家糾錯(cuò)).
講解的原則是"擺定理, 不證明, 寫(xiě)代碼". 具體的證明過(guò)程在csapp中有詳細(xì)的講解, 也不是太難. 主要使用關(guān)鍵定理來(lái)寫(xiě)代碼. Go~
問(wèn)題一: 無(wú)符號(hào)數(shù)的加法越界問(wèn)題
[定理]


[理解]
這個(gè)定理比較容易, 也比較能讓人接受. 不解釋啦.

復(fù)制代碼 代碼如下:

/* Determine whether arguments can be added without overflow */
int uadd_ok(unsigned int x, unsigned int y)
{
return !(x+y < x);
}

問(wèn)題二: 無(wú)符號(hào)數(shù)的減法越界問(wèn)題
[定理]


[理解]
1. 計(jì)算機(jī)中沒(méi)有減法, x-y = x+(-y), 這里的-y就是上述的y的加法逆元. 不管是有符號(hào)還是無(wú)符號(hào), 都是轉(zhuǎn)換為加法運(yùn)算. 只是加法逆元的定義不同.

3. C語(yǔ)言保證 -x = ~x+1; 可以驗(yàn)證這種方式與上面公式等價(jià).
4. s=x-y = x+(-y). 那么 不會(huì)溢出 等價(jià)于 y不為0 或者 !uadd_ok(x, -y).


復(fù)制代碼 代碼如下:

/* Determine whether argumnts can be substracted without overflow */
int usub_ok(unsigned int x, unsigned int y)
{
return !y || !uadd_ok(x, -y);
}

問(wèn)題三: 無(wú)符號(hào)數(shù)的乘法越界問(wèn)題
[定理]


[理解]
等價(jià)條件可以相互推導(dǎo)即可.

復(fù)制代碼 代碼如下:

/* Determine whether arguments can be multiplied without overflow */
int umul_ok(unsigned int x, unsigned int y)
{
unsigned int p = x * y;
return !x || p/x==y;
}

問(wèn)題四: 有符號(hào)數(shù)的加法越界問(wèn)題
[定理]
對(duì)于兩個(gè)有符號(hào)數(shù)x, y. 越界的等價(jià)條件是x,y為負(fù)數(shù), x+y為正數(shù)或者x,y為正數(shù), x+y為負(fù)數(shù).
[理解]
這個(gè)定理比較容易.
復(fù)制代碼 代碼如下:

/* Determine whether arguments can be added without overflow */
int tadd_ok(int x, int y)
{
return !(x<0&&y<0&&x+y>0 || x>0&&y>0&&x+y<0);
}

問(wèn)題五: 有符號(hào)數(shù)的減法越界問(wèn)題
[定理]


[理解]
同無(wú)符號(hào)的減法一樣, 只是加法逆元的定義不同, 但是位模式是一樣的. C語(yǔ)言可以保證-x=~x+1. 同樣也分兩種情況討論.見(jiàn)代碼.

復(fù)制代碼 代碼如下:

/* Determine whether arguments can be subtracted without overflow */
int tsub_ok(int x, int y)
{
  #if 0
  if (y == INT_MIN)
  return x<0;
  else
  return tadd_ok(x, -y);
  #endif
  return y==INT_MIN&&x<0 || y!=INT_MIN&&tadd_ok(x, -y);
}

問(wèn)題六: 有符號(hào)數(shù)的乘法越界問(wèn)題
[定理]
完全同無(wú)符號(hào)的乘法一樣.
復(fù)制代碼 代碼如下:

/* Determine whether arguments can be multiplied without overflow. */
int tmul_ok(int x, int y)
{
#if 0
int p = x * y;
return !x || p/x==y;
#endif
return umul_ok(x, y); /* 直接調(diào)用 */
}

相關(guān)文章

  • 深入解析C語(yǔ)言中常數(shù)的數(shù)據(jù)類型

    深入解析C語(yǔ)言中常數(shù)的數(shù)據(jù)類型

    C語(yǔ)言中常數(shù)的數(shù)據(jù)類型,需要的朋友可以過(guò)來(lái)參考下。希望對(duì)大家有所幫助
    2013-10-10
  • C語(yǔ)言利用棧實(shí)現(xiàn)對(duì)后綴表達(dá)式的求解

    C語(yǔ)言利用棧實(shí)現(xiàn)對(duì)后綴表達(dá)式的求解

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言利用棧實(shí)現(xiàn)對(duì)后綴表達(dá)式的求解,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • 劍指offer之判斷鏈表是否包含環(huán)

    劍指offer之判斷鏈表是否包含環(huán)

    今天小編就為大家分享一篇關(guān)于劍指offer之判斷鏈表是否包含環(huán),小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-02-02
  • C語(yǔ)言簡(jiǎn)明講解歸并排序的應(yīng)用

    C語(yǔ)言簡(jiǎn)明講解歸并排序的應(yīng)用

    這篇文章主要介紹了 c語(yǔ)言排序之歸并排序,歸并就是把兩個(gè)或多個(gè)序列合并,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05
  • C語(yǔ)言?模擬實(shí)現(xiàn)memcpy與memmove函數(shù)詳解

    C語(yǔ)言?模擬實(shí)現(xiàn)memcpy與memmove函數(shù)詳解

    這篇文章主要介紹了C語(yǔ)言詳解如何模擬內(nèi)存函數(shù),用到了mencpy與memmove兩個(gè)函數(shù),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2022-04-04
  • C++輸出斐波那契數(shù)列的兩種實(shí)現(xiàn)方法

    C++輸出斐波那契數(shù)列的兩種實(shí)現(xiàn)方法

    以下是對(duì)C++中輸出斐波那契數(shù)列的兩種實(shí)現(xiàn)方法進(jìn)行了詳細(xì)的介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助
    2013-10-10
  • C語(yǔ)言算法練習(xí)之?dāng)?shù)組求素?cái)?shù)

    C語(yǔ)言算法練習(xí)之?dāng)?shù)組求素?cái)?shù)

    這篇文章主要為大家介紹了C語(yǔ)言算法練習(xí)中數(shù)組求素?cái)?shù)的實(shí)現(xiàn)方法,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)C語(yǔ)言有一定幫助,需要的可以參考一下
    2022-09-09
  • C語(yǔ)言操作符基礎(chǔ)知識(shí)詳解

    C語(yǔ)言操作符基礎(chǔ)知識(shí)詳解

    這篇文章主要以圖文結(jié)合的方式為大家詳細(xì)介紹了C語(yǔ)言位運(yùn)算基礎(chǔ)知識(shí),感興趣的小伙伴們可以參考一下,希望能給你帶來(lái)幫助
    2021-10-10
  • vscode配置C++環(huán)境的圖文教程

    vscode配置C++環(huán)境的圖文教程

    這篇文章主要介紹了vscode配置C++環(huán)境的教程圖文詳解,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-04-04
  • C++實(shí)現(xiàn)LeetCode(126.詞語(yǔ)階梯之二)

    C++實(shí)現(xiàn)LeetCode(126.詞語(yǔ)階梯之二)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(126.詞語(yǔ)階梯之二),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07

最新評(píng)論