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