青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Jiang's C++ Space

創作,也是一種學習的過程。

   :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
弄C++很多年了,沒想到還居然被這種問題所困,其實不光我了,問了幾個同道中人,都未能很好解釋為什么,不過我還是記錄一下,有知情人士看到的話不妨留言告知。

代碼是hello world級別的,很簡單:
int _tmain(int argc, _TCHAR* argv[])
{
    
int ni = 50;
    unsigned 
int ui = 100;
    
    printf(
"%d\n", ni-ui);
    printf(
"%d\n", (ni-ui)*2);
    printf(
"%d\n", (ni-ui)/2);
    printf(
"%d\n", (ni-(int)ui)/2);
    
return 0;
}
問題:輸出結果是什么?
我預期的輸出結果應該是這樣:
-50
-100
-25
-25
而事實上是:
-50
-100
2147483623
-25
在VC6,VS2005和VS2008上調試過,結果完全一致,這就表示,(ni-ui)/2的結果被認為是一個無符號整型,為什么會這樣呢?我看了一下反匯編……其實,我沒看明白。(匯編沒學好)

這種小問題可能會引發大問題,我最近在設計一個程序,把圖片貼到窗口上,圖片的寬和高被我設計為無符號的,因為寬和高最小為0,不可能是負數,而圖片的繪制位置則有可能是負數,這跟坐標系有關,這樣有符號和無符號之間就有可能出現了上面的那種操作,導致程序出現了一些怪異的行為,通過調試,發現是這個問題。

解決方法很簡單,只要加上一個強制轉換即可,像代碼最后一個printf語句那樣。但為什么這樣我就不太清楚了,是C++的規范,還是編譯器的問題,有其它編譯器的朋友可以試試看。
posted on 2010-06-12 10:43 Jiang Guogang 閱讀(2077) 評論(7)  編輯 收藏 引用 所屬分類: Knowledge

評論

# re: 怪異的有符號/無符號轉換問題 2010-06-12 10:46 mr.huang
太詭異。。。麻煩了。。。我們的工程都很少注意這些。  回復  更多評論
  

# re: 怪異的有符號/無符號轉換問題 2010-06-12 17:45 OwnWaterloo
printf("%d %u\n", ni-ui, ni-ui);
printf("%d %u\n", (ni-ui)*2, (ni-ui)*2);
printf("%d %u\n", (ni-ui)/2, (ni-ui)/2);
printf("%d %u\n", (ni-(int)ui)/2, (ni-(int)ui)/2);

觀察輸出結果, 明白了嗎?  回復  更多評論
  

# re: 怪異的有符號/無符號轉換問題 2010-06-13 10:07 博主
@OwnWaterloo
我的問題如文中所說,“是C++的規范,還是編譯器的問題”,(ni-ui)*2被認為是一個有符號的整型,而為什么(ni-ui)/2卻被認為是一個無符號整型,是C++的規范,還是編譯器的問題?  回復  更多評論
  

# re: 怪異的有符號/無符號轉換問題 2010-06-13 10:36 OwnWaterloo
@博主
規范。

二元操作符始終會將操作數轉換為同一類型計算。

轉換規則很復雜, 但有2點:

1. signed T的rank一定比unsigned T要低
2. int 剛好超過默認參數提升的范圍

所以 int op unsigned 一定是都轉換為unsignd計算。
  回復  更多評論
  

# re: 怪異的有符號/無符號轉換問題 2010-06-20 21:33 gejun
“(ni-ui)*2被認為是一個有符號的整型,而為什么(ni-

ui)/2卻被認為是一個無符號整型,是C++的規范,還是編

譯器的問題?”

hi,Jiang. 又在默默耕耘啦~~

請問你根據什么知道(ni-ui)*2被認為是一個有符號的整

型而(ni-ui)/2卻被認為是一個無符號整型?

如果你是根據printf("%d",XXX)的輸出,那就錯了。因為

printf("%d",XXX)不管XXX是什么類型都會把XXX當做有符

號數輸出的。

我做了個實驗證明之前那位網友所說,int op unsigned

一定是都轉換為unsignd,是對的。

(寫了段代碼來證明那位網友的結論:
unsigned int ui = 1;
int ni = 2;

if((ui - ni)<0){
//如果(ui - ni)被轉換為有符號數就會進入這

個分支
printf("should not see me.\n\r");
})

回到你說的問題。那輸出結果到底是什么?

把你代碼中的%d換成%x就真相大白了。

printf("%x\n", ni-ui);
printf("%x\n", (ni-ui)*2);
printf("%x\n", (ni-ui)/2);
printf("%x\n", (ni-(int)ui)/2);

輸出結果如下:
ffffffce
ffffff9c
7fffffe7
ffffffe7

那對于你說有問題的那兩句話,
(ni-ui)/2輸出為7fffffe7
(ni-(int)ui)/2)輸出為ffffffe7
為什么會有這個差異?
請看看匯編代碼。

在計算(ni-ui)/2時,編譯器使用shr來計算結果。shr是

邏輯右移,右移的同時高位填0,所以得到7fffffe7。
在計算(ni-(int)ui)/2時,編譯器使用sar來計算結果。

sar是算術右移,右移的同時保留符號位,所以得到

ffffffe7。

那為什么(ni-ui)/2采用shr而(ni-(int)ui)/2采用sar?
我想就像前面那位網友說的,(ni-ui)被轉換為無符號數

,所以編譯器采用shr忽略符號位;而(ni-(int)ui)被強

制轉換為有符號數,所以編譯器采用了sar以考慮符號位


  回復  更多評論
  

# re: 怪異的有符號/無符號轉換問題 2010-06-21 08:29 pmerofc
(ni-ui)*2被認為是一個有符號的整型,而為什么(ni-ui)/2卻被認為是一個無符號整型

(ni-ui)*2 , (ni-ui)/2 都是 unsigned

原因就是OwnWaterloo說的類型轉換

至于輸出-100,那完全是%d的緣故  回復  更多評論
  

# re: 怪異的有符號/無符號轉換問題 2010-06-21 15:58 博主
Thank you all.
我已經了解。總結回來就是:有符號和無符號的運算,必須要小心謹慎一些。  回復  更多評論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲人成网站在线播| 黑人巨大精品欧美一区二区小视频 | 欧美+日本+国产+在线a∨观看| 久久成人这里只有精品| 欧美一级视频| 美乳少妇欧美精品| 一本一道久久综合狠狠老精东影业 | 在线欧美一区| 日韩亚洲欧美一区二区三区| 亚洲天堂免费在线观看视频| 欧美一级黄色录像| 香蕉乱码成人久久天堂爱免费| 免费不卡在线观看av| 欧美日韩成人在线视频| 国产精品无码永久免费888| 激情久久久久| 欧美一级播放| 久久精品国亚洲| 国产精品国产福利国产秒拍| 永久555www成人免费| 亚洲欧美综合网| 亚洲人成在线影院| 亚洲视频高清| 午夜精品www| 国产精品久久久久9999吃药| 久久国产精品亚洲va麻豆| 一本大道久久a久久综合婷婷| 久久久久久久综合| 国产亚洲一区二区三区在线观看 | 亚洲少妇诱惑| 欧美亚洲免费高清在线观看| 欧美欧美在线| 亚洲乱码国产乱码精品精98午夜 | 亚洲黄色大片| 欧美成人一品| 久久久久久亚洲精品中文字幕| 亚洲精品小视频在线观看| 欧美777四色影视在线| 欧美日韩一区综合| 中国成人黄色视屏| 久久精品伊人| 午夜精品999| 欧美激情中文字幕在线| 亚洲人成77777在线观看网| 亚洲女人天堂成人av在线| 国产精品国产a| 亚洲欧洲日产国产综合网| 欧美激情一区二区在线| 久久综合色影院| 欧美伊久线香蕉线新在线| 韩日精品视频一区| 亚洲视频欧美在线| 亚洲一区二区三区高清| 久久综合伊人77777| 黄色欧美日韩| 亚洲一区精品在线| 日韩午夜在线播放| 免费一级欧美在线大片| 亚洲国产精品女人久久久| 亚洲福利在线观看| 欧美国产激情| 亚洲男人的天堂在线| 亚洲素人在线| 国模 一区 二区 三区| 一本一道久久综合狠狠老精东影业| 亚洲国产日本| 国产精品视频网址| 中国日韩欧美久久久久久久久| 日韩亚洲欧美高清| 欧美日韩免费观看一区| 亚洲日本va午夜在线电影| 亚洲精品乱码久久久久久蜜桃91| 久久婷婷影院| 亚洲在线观看免费| 久久久久久午夜| 另类av一区二区| 亚洲国产欧美一区二区三区丁香婷| 久久精品国产v日韩v亚洲| 欧美啪啪一区| 在线亚洲高清视频| 欧美亚洲三级| 尤妮丝一区二区裸体视频| 久久伊人精品天天| 亚洲区国产区| 午夜精品福利电影| 国产视频一区二区三区在线观看| 亚洲图片欧洲图片av| 欧美日精品一区视频| 一区二区三区四区国产| 久久久无码精品亚洲日韩按摩| 看片网站欧美日韩| 亚洲精品一区二区网址| 欧美午夜免费电影| 亚洲精品国产精品久久清纯直播| 亚洲视频1区| 国产日本欧美视频| 亚洲一区二区免费看| 老司机成人在线视频| 亚洲精品一级| 国产日产精品一区二区三区四区的观看方式| 欧美一区二区三区在线观看视频 | 激情五月婷婷综合| 欧美激情小视频| 亚洲欧美国产一区二区三区| 蜜桃久久av一区| 亚洲欧美三级在线| 1000部精品久久久久久久久| 欧美日韩精品免费观看视频完整 | 欧美一区亚洲一区| 亚洲国产高清自拍| 久久久久久亚洲精品中文字幕 | 久久国产精品毛片| 亚洲麻豆av| 99视频精品免费观看| 国产亚洲福利| 欧美精品久久久久久久免费观看 | 巨胸喷奶水www久久久免费动漫| 中国日韩欧美久久久久久久久| 麻豆91精品91久久久的内涵| 中国av一区| 日韩视频在线观看| 黄色成人在线免费| 国产精品一区二区男女羞羞无遮挡| 中文无字幕一区二区三区| 欧美国产综合| 亚洲乱码日产精品bd| 国产精品有限公司| 欧美日韩中文字幕日韩欧美| 久久视频精品在线| 欧美一区二区三区四区高清 | 亚洲综合电影| 99re6这里只有精品| 一区二区三区 在线观看视频| 国语精品中文字幕| 国产精品网站在线观看| 欧美日韩一区精品| 欧美日韩免费一区| 欧美精品一区二区在线播放| 久热国产精品| 欧美中文字幕在线| 欧美亚洲一区在线| 校园春色综合网| 亚洲欧美日韩国产一区二区| 99精品久久久| 这里只有视频精品| 亚洲性夜色噜噜噜7777| 亚洲午夜极品| 亚洲视频免费看| 亚洲一区二区精品在线观看| 亚洲综合日韩在线| 午夜在线电影亚洲一区| 性欧美8khd高清极品| 香蕉成人伊视频在线观看| 午夜精品久久| 久久成人精品无人区| 久久三级视频| 欧美成年人在线观看| 亚洲欧美在线aaa| 午夜精品一区二区在线观看 | 欧美大片专区| 亚洲国产专区校园欧美| 亚洲精品一区二区三区不| 日韩午夜黄色| 午夜精品影院| 久久三级视频| 欧美日韩国产综合视频在线观看中文| 欧美日韩国产小视频| 国产精品久久久久久亚洲毛片| 美日韩精品免费观看视频| 欧美极品aⅴ影院| 欧美体内she精视频| 国产亚洲午夜高清国产拍精品| 亚洲第一精品久久忘忧草社区| 亚洲日本理论电影| 亚洲欧美精品suv| 久久久久成人精品| 亚洲欧美精品一区| 麻豆精品网站| 亚洲另类在线一区| 欧美亚洲综合另类| 欧美成人日韩| 国产伦精品免费视频| 影音先锋成人资源站| 中文网丁香综合网| 欧美a级片网站| 亚洲午夜91| 美女视频黄 久久| 国产精品日韩欧美大师| 亚洲国产一区二区在线| 午夜精品久久久99热福利| 欧美激情影院| 欧美一级大片在线观看| 欧美日韩国产综合网| 亚洲电影欧美电影有声小说| 一本大道久久a久久精二百| 久久影院亚洲| 嫩模写真一区二区三区三州| 国产精品99久久久久久久vr| 裸体素人女欧美日韩| 国产在线拍揄自揄视频不卡99|