今天翻譯matlab**時需要用移位和加法實現乘法,發現乙個非常奇怪的問題
需要計算的是 x = 3*a,將a左移一位與a相加,
verilog**如下:
x <= a + a
<<1
;
**出來的結果 x = 4*a,
如果**為:
x <= a
<<1 + a
;
**結果為 x = 0。
曉明同學告訴我,要加括號才可以,因為優先順序問題,算術操作符優先順序高於移位。
下面兩個式子效果一樣,結果為四倍的a
x <= a + a
<<1
;x <= (a + a) <<2
;
下面兩個式子效果一樣,結果為0
x <= a
<<1 + a
;x <= a
<
只有下面這樣才對,兩種寫法沒有區別。
x <= a + (a
<<1);
x <= (a
<<1) + a
;
以前沒有用verilog算過數,沒有注意過這種問題,以後要注意。
圖來自與非網
運算子優先順序 C 運算子優先順序
c 運算子優先順序 優先順序運算子 描述方向1 scope resolution 範圍解析 left to right 2 suffix postfix increment and decrement 字首 字尾遞增和遞減 function call 函式呼叫 array subscripting ...
運算子優先順序 Python 運算子優先順序
python 運算子優先順序 運算子描述 lambda lambda表示式 or布林 或 and布林 與 not x 布林 非 in,not in 成員測試 is,is not 同一性測試 比較 按位或 按位異或 按位與 移位 加法與減法 乘法 除法與取餘 x,x 正負號 x 按位翻轉 指數 x.a...
運算子優先順序 PHP運算子優先順序
php運算子優先順序 結合方向 運算子附加資訊 非結合clone new clone 和 new左 array 非結合 遞增 遞減運算子 非結合 int float string array object bool 型別非結合 instanceof 型別右結合 邏輯操作符 左 算術運算子 左 算術運...