?? 新建 文本文檔.txt
字號(hào):
int main()
{
using std::string;
const double d = 123.1234567;
string s = boost::lexical_case<string>(d);
std::cout<<s<<std::endl;
return 0;
}
以上程序預(yù)想的結(jié)果是得到:"123.1234567",但是實(shí)際上我們只會(huì)得到"123.123",因?yàn)槟J(rèn)情況下std::stringstream的精度是6。這算是boost::lexical_cast的一個(gè)bug。
阿炯提供一個(gè)解決辦法:
對(duì)頭文件<boost/lexical_cast.hpp>作如下修改:
//....
template<typename Target, typename Source>
Target lexical_cast(Source arg) {
//.....
Target result;
//以上一行是增加內(nèi)容
interpreter.precision(std::numeric_limits<Source>::digits10);
if(!(interpreter<<arg)||!(interpreter>>result)||!(interpreter>>std::ws).eof())
//.........
}
我按照上述方法在我的機(jī)器上怎么也得不到正確結(jié)果。(BCB 6)
就算可行的話(huà),也存在以下問(wèn)題:只能得到一種精度的字符串。
我使用以下方法解決以上的問(wèn)題:
利用C++中的函數(shù)重載機(jī)制,增加一個(gè)函數(shù):
template<typename Target, typename Source>
Target lexical_cast(Source arg)
{
//......
Target result;
if(!(interpreter << arg) || !(interpreter >> result) ||
!(interpreter >> std::ws).eof())
//....
}
template<typename Target, typename Source>
// 下面一行修改了
Target lexical_cast(Source arg,int length)
{
# ifdef BOOST_LEXICAL_CAST_USE_STRSTREAM
std::strstream interpreter; // for out-of-the-box g++ 2.95.2
# else
std::stringstream interpreter;
# endif
Target result;
// 增加下面一行
interpreter.precision( length );
if(!(interpreter << arg) || !(interpreter >> result) ||
!(interpreter >> std::ws).eof())
throw bad_lexical_cast();
return result;
}
}
使用時(shí)如下:
std::string s = boost::lexical_cast<std::string>(123.1234567,10);
即可以得到正確的結(jié)果,而且原來(lái)的函數(shù)不變。
?? 快捷鍵說(shuō)明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號(hào)
Ctrl + =
減小字號(hào)
Ctrl + -