• <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
            亚洲va中文字幕无码久久不卡| 日本三级久久网| 2020国产成人久久精品| 国产69精品久久久久APP下载| 日韩av无码久久精品免费| 青青青青久久精品国产| 久久精品免费全国观看国产| 久久成人国产精品免费软件| 亚洲国产精久久久久久久| 亚洲精品国产美女久久久| 精品久久久久久无码中文字幕 | 久久久久免费视频| 无夜精品久久久久久| 久久久久久亚洲精品成人| 久久涩综合| 93精91精品国产综合久久香蕉| 亚洲欧美另类日本久久国产真实乱对白 | 国产成人久久精品激情| 亚洲欧洲中文日韩久久AV乱码| 国产精品久久久久久久久鸭| 国产偷久久久精品专区 | 青青草国产97免久久费观看| 国产精品久久网| 国产美女久久精品香蕉69| 看久久久久久a级毛片| 久久久久久精品久久久久| 久久综合色老色| 日韩va亚洲va欧美va久久| 久久97久久97精品免视看秋霞| 久久精品成人免费网站| 99久久精品午夜一区二区| 久久久久亚洲AV无码永不| 亚洲精品无码专区久久久| 久久久噜噜噜久久中文字幕色伊伊 | 久久久久免费精品国产| 久久91精品国产91| 久久天天躁夜夜躁狠狠| 久久精品国产乱子伦| 欧美牲交A欧牲交aⅴ久久| 99久久精品日本一区二区免费| 久久久久久人妻无码|