国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C > 正文

如何判斷C語言算術(shù)運(yùn)算的越界問題

2020-02-24 14:38:23
字體:
供稿:網(wǎng)友

? ? ? 大量的安全漏洞是由于計(jì)算機(jī)算術(shù)運(yùn)算的微妙細(xì)節(jié)引起的, 具體的C語言, 諸如符號(hào)數(shù)和無符號(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)算的越界問題.

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


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


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


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

?

?

?


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

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


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


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

?


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


/* 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;
}


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

?

?


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


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

?


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


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


問題六: 有符號(hào)數(shù)的乘法越界問題
[定理]
完全同無符號(hào)的乘法一樣.

?

?


/* 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語言算術(shù)運(yùn)算的越界問題的全部內(nèi)容,更多內(nèi)容請(qǐng)繼續(xù)關(guān)注武林技術(shù)頻道網(wǎng)站!

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 宿迁市| 维西| 涞水县| 林州市| 吉木萨尔县| 丰顺县| 垫江县| 弋阳县| 永定县| 内丘县| 龙井市| 上饶县| 长沙市| 安康市| 句容市| 福泉市| 巴马| 区。| 广宁县| 白沙| 南漳县| 蛟河市| 贵南县| 封开县| 镇原县| 句容市| 临清市| 磐石市| 乌拉特前旗| 新干县| 应城市| 广州市| 自治县| 申扎县| 屏山县| 平舆县| 中卫市| 万年县| 文登市| 黄平县| 黄平县|