std::vector 大小否定悖論:揭曉
在一個令人費解的程序中,我們觀察到比較-1
儘管std::vector理解無符號整數型別
std::vector 的 size 成員傳回無符號整數型別。無符號整數類型專門表示正整數,缺乏儲存負值的能力。當無符號類型遇到負值時,它會透過稱為補碼轉換的過程自動轉換為大的正值。比較中的型別提升
在比較中-1 說明性範例以下程式碼片段示範了基本類型上的相同行為:#include <iostream> int main() { std::cout << std::boolalpha; unsigned int a = 0; int b = -1; std::cout << (b < a) << "\n"; // prints false }
結論
總而言之,在原始std::vector 比較中觀察到的令人費解的行為是由負整數的類型提升引起的與無符號類型提升引起的與無符號類型提升引起的與無符號類型提升所引起的相比。負整數被有效地轉換為大的正值,從而導致意外的結果。最佳實踐是,在未明確將有符號值轉換為無符號類型的情況下,避免比較有符號和無符號整數。以上是為什麼 `std::vector` 的 `-1 < a.size()` 計算結果為 False?的詳細內容。更多資訊請關注PHP中文網其他相關文章!