• <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 力為 閱讀(5844) 評論(0)  編輯 收藏 引用 所屬分類: 4. C++ FAQ
            99久久无色码中文字幕| 亚洲一区精品伊人久久伊人| 亚洲AV无码成人网站久久精品大| 中文精品久久久久人妻不卡| 久久久久人妻精品一区 | 国产精品美女久久久网AV| 99久久www免费人成精品| 久久久精品日本一区二区三区| 久久久无码精品午夜| 久久天天躁狠狠躁夜夜躁2O2O| 97超级碰碰碰碰久久久久| 精品久久久无码人妻中文字幕| 精品久久香蕉国产线看观看亚洲| 久久这里的只有是精品23| 久久亚洲精品视频| 亚洲中文字幕久久精品无码喷水| 国产精品99久久久久久人| 久久亚洲精品无码aⅴ大香| 91超碰碰碰碰久久久久久综合| 亚洲精品乱码久久久久久| 久久久久久久综合综合狠狠| 狠狠色丁香久久综合婷婷| 精产国品久久一二三产区区别| 久久免费国产精品一区二区| 无码人妻久久久一区二区三区| 亚洲国产小视频精品久久久三级 | 亚洲色大成网站www久久九| 国产精品一区二区久久精品无码| 日韩精品久久久久久久电影蜜臀| 免费一级欧美大片久久网| 日韩欧美亚洲综合久久影院d3| 久久国产亚洲精品无码| 亚洲女久久久噜噜噜熟女| 亚洲精品无码久久毛片| 久久久久99精品成人片牛牛影视| 久久99精品综合国产首页| 久久亚洲美女精品国产精品| 久久久久国产精品熟女影院| 午夜精品久久久久久毛片| 亚洲国产精品18久久久久久| 久久亚洲精品成人无码网站|