2016-03-16 27 views
2

改變數據類型,下面的代碼產生輸出我不理解:Arduino的代碼:換檔位似乎從我的Arduino INT長

void setup(){ 
    Serial.begin(9600); 
    int a = 250; 

    Serial.println(a, BIN); 
    a = a << 8; 
    Serial.println(a, BIN); 
    a = a >> 8; 
    Serial.println(a, BIN); 


} 

void loop(){} 

的輸出是:

11111010 
11111111111111111111101000000000 
11111111111111111111111111111010 

我明白第一行:前導零不會被打印到串行終端。但是,在移位後,數據類型a似乎已經從int變爲long(打印了32位)。預期的行爲是將位移到左側,並且將int移出16位的位簡單地丟棄。將位移回不會將「32位」變量再次變爲「16位」。

移動7個或更少的位置並不顯示這種效果。

我可能應該說我沒有使用Arduino IDE,而是使用了https://github.com/sudar/Arduino-Makefile的Makefile。

這是怎麼回事?我幾乎希望這是「正常」,但我不明白。還是在打印例程中,它只是將16「1」添加到輸出中?

在Arduino的恩諾

+0

如果您想在C++中定義良好的行爲,請考慮'unsigned int'進行移位。 – knivil

+0

是的,這就是我在盯着這個小時後所採取的行動。 – mcenno

回答

1

打印功能號碼定義/arduino-1.0.5/hardware/arduino/cores/arduino/Print.cpp

size_t Print::printNumber(unsigned long n, uint8_t base) { 
    char buf[8 * sizeof(long) + 1]; // Assumes 8-bit chars plus zero byte. 
    char *str = &buf[sizeof(buf) - 1]; 

    *str = '\0'; 

    // prevent crash if called with base == 1 
    if (base < 2) base = 10; 

    do { 
    unsigned long m = n; 
    n /= base; 
    char c = m - base * n; 
    *--str = c < 10 ? c + '0' : c + 'A' - 10; 
    } while(n); 

    return write(str); 
} 

所有其他功能依靠這一個,所以是你的int得到提升爲無符號long當你打印它,而不是當你轉移它。

但是,圖書館是正確的。通過左移8個位置,整數中的負位變成'1',所以當整數值被提升爲無符號長時,運行時正確地用16個額外的'1'而不是'0'來填充它。

如果使用這樣的值並不是數字,而是包含了一些標誌,應使用而不是unsigned int類型INT


ETA:爲了完整性,我將爲第二次移位操作添加進一步的解釋。

一旦您觸摸int號碼中的'負位',當您向右移動時,運行時會用'1'填充數字以保留其負值。向左移動k位置對應於將數字除以2^k,並且由於數字爲負數開始,因此結果必須保持負數。

+0

感謝您的全面回覆。我無法圍繞這種「動態打字」打包頭,很高興看到它只發生在打印階段。 – mcenno

+0

不客氣。 –

1

除了其他答案,整數可能存儲在16位或32位取決於你有什麼arduino。