探索printf 與字元十六進位列印的奇怪行為
在程式設計領域,人們可能會遇到在其中列印單字節的情況使用printf 的十六進位格式會產生意想不到的結果。當使用字元向量作為像素資料時,就會出現一個奇怪的例子。嘗試使用“%1x”修飾符列印單一字元通常會導致令人困惑的結果。
揭開謎團
謎團在於所表現出的類型提升行為通過 printf。當字元 (char) 作為可變參數函數傳遞給 printf 時,通常會將其提升為整數 (int)。但是,「%x」修飾符需要無符號整數 (unsigned int) 作為輸入。這種不一致會導致未定義的行為。
為了修正此問題並確保可預測的結果,必須將字元明確轉換為無符號整數。以下修改說明了解決方案:
printf(" 0x%1x ", (unsigned)pixel_data[0] );
值得注意的是,在這種情況下,字段寬度為 1 的實用性有限,因為十六進位表示始終需要至少一位數字。
對簽章和未簽章資料的影響
在char 被指定為有符號、負數的平台上字元值在提升時將轉換為大的無符號整數值。為了避免這種情況,請考慮對像素資料使用 unsigned char 或採用 unsigned int 轉換或基於遮罩的零擴充。以下是替代方法的範例:
printf(" 0x%x ", (unsigned)(unsigned char)pixel_data[0] ); printf(" 0x%x ", (unsigned)pixel_data[0] & 0xffU );
這些解決方案可確保將位元組值按所需轉換為無符號整數,從而獲得一致的預期輸出。
以上是為什麼「printf」在將單一字元列印為十六進位時會產生意外結果?的詳細內容。更多資訊請關注PHP中文網其他相關文章!