2016-04-01 13 views
4

私は最近、cout.setf(ios :: fixed)と関係があるこの奇妙な問題を経験しました。原因を突き止めるのにかなり時間がかかりましたし、もっと学ぶためにここで尋ねると思いました。cout.setf(ios :: fixed)が浮動小数点を16進数に変更するのはなぜですか?

問題はこれです。cout.setf(ios :: fixed)を使用すると、すべての浮動小数点数が16進数で表示されます。なぜこれが起こるのですか? ios :: baseのドキュメントは、これが(少なくとも私にとっては)起こることを暗示していないようです。私はg ++ 5.3.0を使用しており、下に貼り付けたのは最小の例と出力です。私は

cout.setf(ios::fixed, ios::floatfield); 

cout.setf(ios::fixed); 

を変更したときに、問題が消えること

#include <iostream> 
    #include <complex> 

    using namespace std; 

    int main(int argc, char const *argv[]) 
    { 
    complex<double> I(0.0, 1.0); 
    double pi = M_PI; 

    cout.setf(ios::scientific); 
    cout<<" I is "<<I<<endl; 
    cout<<" Exp(I Pi) "<<exp(I*pi)<<endl; 
    cout<<" Cos(Pi) "<<cos(pi)<<endl<<endl; 

    cout.setf(ios::fixed); 
    cout<<" I is "<<I<<endl; 
    cout<<" Exp(I Pi) "<<exp(I*pi)<<endl; 
    cout<<" Cos(Pi) "<<cos(pi)<<endl<<endl; 

    return 0; 
    } 

出力

I is (0.000000e+00,1.000000e+00) 
Exp(I Pi) (-1.000000e+00,1.224647e-16) 
Cos(Pi) -1.000000e+00 

I is (0x0p+0,0x1p+0) 
Exp(I Pi) (-0x1p+0,0x1.1a62633145c07p-53) 
Cos(Pi) -0x1p+0 

See the live sample here

注意

答えて

7

あなたに言ったからです。 setf documentation on cppreference.comから

科学 - 固定と組み合わせた場合、科学表記法、または16進表記を使用して浮動小数点型を生成する:参照std::scientific
固定 - 固定された表記法を使用して浮動小数点型を生成します、または科学と組み合わせた場合の六角記法:std::fixed

したがって、std::fixedを設定する場合は、std::floatfieldstd::floatfieldであるため、std::floatfieldのアンマスク処理は行わないでください。std::floatfieldstd::scientific|std::fixed|(std::scientific|std::fixed)|0です)、16進表記を避ける必要があります。

+1

もう一度稲妻:D、+1しかし、 –

+0

_reading_のために! –

+0

ありがとう!恥ずかしい間違い。 – vijayshankarv

関連する問題