unsigned char を使用した cout の予測できない動作の背後にある謎を明らかにする
プログラミングでは、予期しない出力がフラストレーションや混乱につながることがよくあります。次のコードを考えてみましょう。
#include<iostream> #include<stdio.h> using namespace std; int main() { unsigned char a; a = 1; printf("%d", a); cout << a; }
このコードは、unsigned char 変数 'a' に格納されている値、つまり 1 を出力するように設計されています。ただし、実行すると、「1」の後に一見したようにいくつかの文字が出力されます。ランダムな文字。このシナリオでは、cout の動作が printf とは異なるのはなぜですか?
その答えは、unsigned char の性質にあります。 0 ~ 31 の値が割り当てられた ASCII 文字は印刷不可能とみなされます。値 1 に割り当てられた文字は印刷不可能な文字であり、cout はとにかく印刷を試みます。文字が印刷可能かどうかを判断するには、std::isprint 関数を使用できます。
std::cout << std::isprint(a) << std::endl;
このステートメントは、文字が印刷不可能であることを示す 0 (false) を出力します。
この問題を解決し、cout に a の値を 1 として出力させるには、それを unsigned にキャストします。 integer:
cout << static_cast<unsigned>(a) << std::endl;
このキャストは、印刷不可能な文字を対応する符号なし整数値に変換し、cout が 1 を正しく出力するようにします。
以上が`unsigned char` を処理するときに、`cout` は予期しない文字を出力するのに、`printf` は出力しないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。