[問題] 負數處理

作者: dabiddabid (dabid')   2016-04-12 18:41:19
小弟要將兩個Int16數字組成Int32
Int16 a = -30 ;//1111 1111 1110 0010
Int16 b = -19456 ; //1011 0100 0000 0000
現在想把ab組合在一起成Int32(ab)//1111 1111 1110 0010 1011 0100 0000 0000
原本是想將兩個都先ToInt32將a << 16 然後(a | b)
但現在發現負數Int16轉Int32會將前面全部補1
b會變成1111 1111 1111 1111 1011 0100 0000 0000
但我想要的是0000 0000 0000 0000 1011 0100 0000 0000
也就是想要a|b結果是-1920000//11111111111000101011010000000000
但實際現在結果卻是-19456 //11111111111111111011010000000000
請問這要如何解決?
作者: wa007123456 (大笨羊)   2016-04-12 18:48:00
先用正數做 最後再改成負數即可你在新竹?
作者: Litfal (Litfal)   2016-04-12 19:30:00
為什麼b你要轉int32 ?
作者: lucky1lk (賭到沒錢的人)   2016-04-13 08:04:00
當然會補1阿 計算機概論(?)有修過嗎
作者: yeo1987 (Archie)   2016-04-13 19:59:00
a << 16 | (b & 0xFFFF),這樣是你預期的嗎?

Links booklink

Contact Us: admin [ a t ] ucptt.com