麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > C > 正文

如何判斷C語言算術運算的越界問題

2020-02-24 14:38:23
字體:
來源:轉載
供稿:網友

? ? ? 大量的安全漏洞是由于計算機算術運算的微妙細節引起的, 具體的C語言, 諸如符號數和無符號數之間轉換, 算術運算的越界都會導致不可預知的錯誤和安全漏洞, 具體的案例數不勝數.

? ? ? 作為一個系統程序員, 有必要對這些細節有深入的了解. 本篇參考csapp, 主要介紹如何判斷算術運算的越界問題.

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


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


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


問題二: 無符號數的減法越界問題
[定理]

?

?

?


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

3. C語言保證 -x = ~x+1; 可以驗證這種方式與上面公式等價.
4. s=x-y = x+(-y). 那么 不會溢出 等價于 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);
}


問題三: 無符號數的乘法越界問題
[定理]

?


[理解]
等價條件可以相互推導即可.


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


問題四: 有符號數的加法越界問題
[定理]
對于兩個有符號數x, y. 越界的等價條件是x,y為負數, x+y為正數或者x,y為正數, x+y為負數.
[理解]
這個定理比較容易.

?

?


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


問題五: 有符號數的減法越界問題
[定理]

?


[理解]
同無符號的減法一樣, 只是加法逆元的定義不同, 但是位模式是一樣的. 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 }


問題六: 有符號數的乘法越界問題
[定理]
完全同無符號的乘法一樣.

?

?


/* 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); /* 直接調用 */
}

? ? ? 以上就是關于如何判斷C語言算術運算的越界問題的全部內容,更多內容請繼續關注武林技術頻道網站!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 中日无线码1区 | 毛片118极品美女写真 | 久久综合精品视频 | 久久精品一级 | 国产精品亚洲精品日韩已方 | 免费观看黄色一级视频 | 精品国产一区二区三区四区在线 | 久久老司机精品视频 | 在线成人免费网站 | 国产资源在线免费观看 | 中文字幕在线观看1 | 国产噜噜噜噜噜久久久久久久久 | 国产精品久久久久国产精品三级 | 欧美1区2区在线观看 | 国产精品剧情一区二区三区 | 国产一级一区二区 | 欧美日韩电影在线 | 七首小情歌泰剧在线播放 | 黄色片网站免费在线观看 | 国产亚洲欧美日韩在线观看不卡 | 午夜激情视频免费 | 成人区精品一区二区婷婷 | 欧美特黄a | 日本黄色一级电影 | 黄色成人短视频 | 毛片视频在线免费观看 | 成人午夜免费av | 黄色影院 | 色视频在线 | 欧美一区2区三区4区公司二百 | 国产精品自在线拍 | 国产精品一区二区三区在线播放 | 久草在线资源福利站 | 毛片国产 | 成码无人av片在线观看网站 | 国产精品久久久久久久久久了 | 精品国产一区二区三区四 | 成年免费观看视频 | 在线a| 亚洲成人在线视频网站 | 久久久久久久.comav |