提防iostream使用中的一个“陷阱”
先看下面的示例代碼:
template < typename T > void test()
{
?T o;
?for(T i = numeric_limits< T >::min(); i < numeric_limits< T >::max(); ++i)
?{
??stringstream stream;
??stream << i;
??stream >> o;
??assert(i == o);
?}
}
試著按下面這樣調(diào)用它:
test< int >();
一點(diǎn)問題都沒有。
再這樣調(diào)用:
test< char >();
你會(huì)發(fā)現(xiàn)當(dāng)i=9的時(shí)候,assert在大聲地“抱怨”,這種情況下,我們受了stream“放進(jìn)去什么,拿出來也是什么”的假相的迷惑,往stream放進(jìn)去一個(gè)(char)9,是拿不出來任何東西的!
或許你說,“好的,我知道了,stream對字符的處理和數(shù)值的處理不一樣”,我們再來看一個(gè)例子:
test< BYTE >();
這種情況下,我們一樣的被BYTE迷惑了,BYTE是我們一廂情愿定義的“數(shù)值”類型,實(shí)際上,只是一個(gè)unsigned char而已,會(huì)被iostream當(dāng)作char一樣處理。
注:上面的例子只在VC 7.1下、用MS版的STL測試過,別的版本的STL會(huì)如何處理char和BYTE,我自己沒有測試過,不敢下結(jié)論。
另外,我注意到boost::lexical_cast(V 1.31.0)也沒有對char和BYTE做特殊處理。
posted on 2004-10-15 10:38 浙林龍哥 閱讀(...) 評論(...) 編輯 收藏轉(zhuǎn)載于:https://www.cnblogs.com/huqingyu/archive/2004/10/15/52551.html
總結(jié)
以上是生活随笔為你收集整理的提防iostream使用中的一个“陷阱”的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 有一种道理叫“实践”
- 下一篇: 云中家园FTP搜索站点开通