• <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 力為 閱讀(5843) 評論(0)  編輯 收藏 引用 所屬分類: 4. C++ FAQ
            久久久久国产一区二区| 久久久久国产亚洲AV麻豆| 久久亚洲国产成人影院| 午夜精品久久久久久99热| 国产真实乱对白精彩久久| 亚洲精品无码久久久久sm| 久久久91精品国产一区二区三区| 久久午夜福利电影| 久久综合丁香激情久久| 久久se精品一区二区影院| 久久久精品人妻一区二区三区蜜桃| 久久无码AV一区二区三区| 97久久精品人妻人人搡人人玩| 麻豆成人久久精品二区三区免费 | 国产精品热久久毛片| www.久久精品| 欧美国产成人久久精品| 亚洲国产天堂久久综合网站| 2022年国产精品久久久久| 久久天天躁狠狠躁夜夜2020老熟妇 | 99久久99久久精品国产片| 亚洲精品高清国产一线久久 | 久久丫忘忧草产品| 久久精品18| 99热热久久这里只有精品68| 久久国产色AV免费观看| 亚洲国产精品久久久天堂| 国产精品99久久久精品无码| 欧美精品福利视频一区二区三区久久久精品 | 亚洲国产精品成人久久蜜臀| 亚洲精品无码专区久久同性男| 久久99热狠狠色精品一区| 久久久久国产精品麻豆AR影院| 狠狠狠色丁香婷婷综合久久五月| 国产69精品久久久久9999APGF| …久久精品99久久香蕉国产| 精品综合久久久久久888蜜芽| 久久综合狠狠综合久久激情 | 久久精品国产精品国产精品污| 青青草国产精品久久久久| 93精91精品国产综合久久香蕉 |