在計算機系統中,整形數據一律用補碼來存儲,其原因在於,使用補碼可以將符號位和數據位統一處理,與此同時,加法和減法也可以統一處理。
1)正數的原碼、反碼和補碼相同;
2)負數的反碼:原碼的符號位不變,數據位按位取反;
3)負數的補碼:反碼+1(如果+1後要進位,要一直往前進位,包括符號位)。
在DSP中的測試代碼如下:
// Initialization
uint16_t test1 = 10;
int16_t test2 = -10;
uint16_t test3 = 65000;
// Update data
test1 = (uint16_t)test2;
test2 = (int16_t)test3;
測試結果如下:
分析:
10、-10以及6500三個數在計算機存儲單元裏的存儲格式如下表所示,從該表不難看出,將-10強制轉換爲uint16_t格式後,轉換後的數據應爲65526,與上述測試結果一致。同理,將65000強制轉換爲int16_t格式後,轉換後的數據應爲-536,與測試結果一致。
總之,不同類型的整形數據之間的強制轉換歸根到底就是一條:按存儲單元中的存儲格式直接傳送。因而,對於交流信號,負數通過Modbus通信傳送給上位機顯示時,在DSP中可以先強制轉換爲uint16_t格式,然後上位機程序再強制轉換爲int16_t格式即可。