• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            力為的技術博客

            聯系 聚合 管理
              154 Posts :: 1 Stories :: 561 Comments :: 0 Trackbacks

             

            默認情況下,用科學計數法表示實數,輸出的指數位數為3。如何控制使其只輸出2位指數位?VC6下如何?VC2005又如何?

            在VC2005下,運行庫提供一個函數_set_output_format可以控制printf輸出的實數的指數位,要輸

            出2位指數位需要這樣設置:
            unsigned int  old_exponent_format = _set_output_format(_TWO_DIGIT_EXPONENT);
            使用完恢復原來設置:
            _set_output_format(old_exponent_format);

            在VC6中沒有此函數,相同功能的函數我也沒有發現。
            在C++標準庫中的stream中,我也沒有找到這樣的格式控制符。為了在VC6下完成此功能,最后只能

            選擇曲線救國的道路了——刪除一個0。

            1、對于printf這樣的輸出解決方法:

            void EraseZeroPlus(std::string& str, string::size_type pos)
            {
                
            string::size_type  pos1= str.find("E+", pos);

                
            if(pos1 == string::npos)
                    
            return;
                
                pos1 
            +=2;
                str.erase(pos1, 
            1);

                EraseZeroPlus(str, pos1);
            }

            void EraseZeroMinus(std::string& str, string::size_type pos)
            {
                
            string::size_type  pos1= str.find("E-", pos);

                
            if(pos1 == string::npos)
                    
            return;
                
                pos1 
            +=2;
                str.erase(pos1, 
            1);

                EraseZeroMinus(str, pos1);
            }


            void EraseZero(char* szBuf, FILE* pFile)
            {
                
            string str(szBuf);
                EraseZeroPlus(str, 
            0);
                EraseZeroMinus(str, 
            0);
                fputs(str.c_str(), pFile);
            }

             

            2、對于stream這樣的輸出解決方法:
            這里只是考慮輸出文件的情況。
            .h file

            template<class _E, class _Tr = std::char_traits<_E> >
            class my_ofstream  : public std::basic_ofstream<_E, _Tr>
            {
            public:
                my_ofstream()
            {m_nPrecision = 5}
                
            explicit my_ofstream(const char *_S,
                    ios_base::openmode _M 
            = out | trunc) 
                    : std::basic_ofstream
            <_E, _Tr>(_S, _M)
                
            {
                    m_nPrecision 
            = 5;
                }

                
            void set_precision(int nPre)
                
            {
                    m_nPrecision 
            = nPre;
                }

                
            int get_precision(void)
                
            {
                    
            return m_nPrecision;
                }

                
            virtual ~my_ofstream(){}
            private:
                
            int m_nPrecision;
            }
            ;

            typedef my_ofstream
            <char> myofstream;

            // overload operator for double and float value    
            myofstream& operator<< (myofstream& strm, float value);
            myofstream
            & operator<< (myofstream& strm, double value);

            .cpp file:
            void erase_one_zero(std::string& str)
            {
                
            using namespace std;
                
            string::size_type  pos= str.length() - 3;
                str.erase(pos, 
            1);
            }

            myofstream
            & operator<< (myofstream& strm, const float value)
            {
                
            using namespace std;
                
                ostringstream oss;
                oss 
            << scientific << showpoint << setprecision(strm.get_precision()) << value;
                std::
            string str(oss.str());
                erase_one_zero(str);
                
                strm 
            << str;
                
                
            return strm;
            }


            myofstream
            & operator<< (myofstream& strm,  const double value)
            {
                
            using namespace std;
                
                ostringstream oss;
                oss 
            << scientific << showpoint << setprecision(strm.get_precision()) << value;
                std::
            string str(oss.str());
                erase_one_zero(str);
                
                strm 
            << str;
                
                
            return strm;
            }

            test code:
            int main(int argc, char* argv[])
            {
                
            using namespace std;

                myofstream fout(
            "out.txt");
                fout 
            << "out put scientific format: \n";
                fout 
            << 3654.002 << endl;
                fout 
            << 0.145f << endl;

                fout.set_precision(
            6);
                fout 
            << 3654.002 << endl;
                fout 
            << 0.145f << endl;    

                
            return 0;
            }

            VC6下,不知還有沒有更好的辦法……
            posted on 2005-12-18 20:39 力為 閱讀(5862) 評論(0)  編輯 收藏 引用 所屬分類: 4. C++ FAQ
            天堂久久天堂AV色综合| 久久国产精品无码HDAV| 日韩久久久久中文字幕人妻| 欧美性猛交xxxx免费看久久久| 久久综合伊人77777| 午夜精品久久久久久99热| 97久久久精品综合88久久| 久久久久久一区国产精品| 久久AV高潮AV无码AV| 久久久久久毛片免费看| 麻豆亚洲AV永久无码精品久久| 九九久久99综合一区二区| 人妻精品久久久久中文字幕| 久久亚洲日韩精品一区二区三区| 国产免费福利体检区久久| 无遮挡粉嫩小泬久久久久久久 | 色婷婷狠狠久久综合五月| 婷婷五月深深久久精品| 日产久久强奸免费的看| 久久综合丁香激情久久| 久久精品国产99久久无毒不卡 | 伊人色综合久久天天| 久久精品人人槡人妻人人玩AV| 久久久久亚洲AV成人网人人网站 | 国产巨作麻豆欧美亚洲综合久久| 99999久久久久久亚洲| 蜜臀av性久久久久蜜臀aⅴ麻豆| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 国产精品无码久久综合网| 久久精品蜜芽亚洲国产AV| 亚洲人成精品久久久久| 久久综合亚洲鲁鲁五月天| 亚洲欧美国产日韩综合久久| 国产成人精品久久| 久久久久一本毛久久久| 色综合久久中文字幕综合网| 亚洲午夜福利精品久久| 思思久久99热免费精品6| 久久婷婷国产剧情内射白浆| 2020久久精品亚洲热综合一本| 久久午夜福利无码1000合集|