Verilog 運算子優先順序引發的血案

2021-07-28 04:45:22 字數 760 閱讀 2576

今天翻譯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 型別右結合 邏輯操作符 左 算術運算子 左 算術運...