金慶的專欄
C++博客
::
首頁
::
新隨筆
::
聯(lián)系
::
聚合
::
管理
::
423 隨筆 :: 0 文章 :: 454 評(píng)論 :: 0 Trackbacks
公告
我的隨筆
我的評(píng)論
我參與的隨筆
留言簿
(12)
給我留言
查看公開留言
查看私人留言
隨筆分類
(502)
1. C/C++(166)
(rss)
2. 網(wǎng)游開發(fā)(108)
(rss)
3. Golang(20)
(rss)
4. Linux/Unix(30)
(rss)
5. 軟工與管理(44)
(rss)
6. Python(23)
(rss)
7. Erlang(18)
(rss)
8. Rust(16)
(rss)
9. 其它(77)
(rss)
隨筆檔案
(423)
2023年1月 (1)
2022年11月 (1)
2022年10月 (2)
2022年9月 (1)
2022年4月 (6)
2022年1月 (2)
2021年12月 (4)
2021年11月 (6)
2021年10月 (2)
2021年9月 (2)
2021年8月 (7)
2021年7月 (2)
2021年5月 (2)
2021年3月 (1)
2021年2月 (2)
2021年1月 (1)
2020年12月 (1)
2020年10月 (1)
2020年9月 (5)
2020年8月 (1)
2020年7月 (1)
2020年6月 (1)
2020年4月 (2)
2020年3月 (3)
2020年2月 (3)
2020年1月 (1)
2019年12月 (1)
2019年9月 (2)
2019年4月 (2)
2019年1月 (1)
2018年12月 (1)
2018年11月 (3)
2018年10月 (1)
2018年9月 (3)
2018年8月 (3)
2018年7月 (2)
2018年6月 (4)
2018年5月 (4)
2018年4月 (4)
2018年3月 (1)
2018年1月 (2)
2017年12月 (2)
2017年11月 (3)
2017年10月 (3)
2017年8月 (7)
2017年7月 (1)
2017年6月 (1)
2017年5月 (3)
2017年4月 (3)
2017年3月 (3)
2017年2月 (2)
2017年1月 (2)
2016年12月 (5)
2016年11月 (2)
2016年10月 (2)
2016年9月 (1)
2016年8月 (6)
2016年7月 (3)
2016年6月 (2)
2016年5月 (4)
2016年4月 (2)
2016年3月 (2)
2016年1月 (3)
2015年12月 (2)
2015年11月 (2)
2015年10月 (1)
2015年8月 (2)
2015年7月 (1)
2015年6月 (1)
2015年5月 (4)
2015年4月 (3)
2015年3月 (4)
2015年2月 (5)
2015年1月 (4)
2014年12月 (3)
2014年11月 (3)
2014年10月 (2)
2014年9月 (3)
2014年8月 (1)
2014年4月 (4)
2014年3月 (1)
2014年2月 (4)
2014年1月 (5)
2013年12月 (5)
2013年11月 (5)
2013年9月 (2)
2013年8月 (2)
2013年7月 (2)
2013年6月 (2)
2013年5月 (1)
2013年1月 (2)
2012年12月 (1)
2012年11月 (1)
2012年9月 (1)
2012年8月 (3)
2012年7月 (2)
2012年6月 (1)
2012年4月 (3)
2012年3月 (2)
2012年2月 (3)
2012年1月 (2)
2011年11月 (2)
2011年10月 (3)
2011年9月 (2)
2011年8月 (2)
2011年7月 (3)
2011年6月 (2)
2011年5月 (3)
2011年1月 (2)
2010年12月 (1)
2010年11月 (2)
2010年10月 (2)
2010年9月 (3)
2010年8月 (2)
2010年7月 (3)
2010年6月 (1)
2010年5月 (3)
2010年4月 (3)
2010年3月 (5)
2010年2月 (4)
2010年1月 (4)
2009年12月 (2)
2009年11月 (3)
2009年10月 (4)
2009年9月 (3)
2009年8月 (2)
2009年7月 (4)
2009年6月 (1)
2009年5月 (3)
2009年4月 (4)
2009年3月 (2)
2009年2月 (5)
2009年1月 (1)
2008年12月 (7)
2008年11月 (4)
2008年10月 (1)
2008年9月 (3)
2008年8月 (4)
2008年7月 (3)
2008年6月 (4)
2008年5月 (6)
2008年4月 (7)
2008年3月 (6)
2008年1月 (5)
2007年12月 (7)
2007年11月 (4)
2007年10月 (5)
2007年9月 (6)
2007年8月 (8)
2007年7月 (5)
相冊(cè)
公告照片
搜索
積分與排名
積分 - 659030
排名 - 25
最新評(píng)論
1.?re: boost::asio::spawn 將一統(tǒng)C++網(wǎng)絡(luò)庫(kù)
asio 成為C++首選網(wǎng)絡(luò)庫(kù)
--linda
2.?re: log4cxx中文輸出錯(cuò)誤補(bǔ)丁
評(píng)論內(nèi)容較長(zhǎng),點(diǎn)擊標(biāo)題查看
--金慶
3.?re: mingw編譯OrzNet
能發(fā)送一個(gè)mingw編譯好的OrzNet庫(kù)給我嗎? liuweiqcxy@163.com
謝謝!
--劉威
4.?re: log4cxx中文輸出錯(cuò)誤補(bǔ)丁
評(píng)論內(nèi)容較長(zhǎng),點(diǎn)擊標(biāo)題查看
--bigbad
5.?re: log4cxx中文輸出錯(cuò)誤補(bǔ)丁
評(píng)論內(nèi)容較長(zhǎng),點(diǎn)擊標(biāo)題查看
--bigbad
閱讀排行榜
1.?"multiple definition of" 錯(cuò)誤(11054)
2.?SVN中邪惡的replace(10972)
3.?VS2005編譯libevent(10429)
4.?混音算法的學(xué)習(xí)與研究(10230)
5.?C調(diào)用lua腳本的效率測(cè)試(9019)
評(píng)論排行榜
1.?VC6正在被拋棄(35)
2.?VS2005編譯libevent(21)
3.?"multiple definition of" 錯(cuò)誤(18)
4.?C++引用優(yōu)于指針(17)
5.?ACE與ASIO之間關(guān)于Socket編程的比較(16)
log4cxx中文輸出錯(cuò)誤補(bǔ)丁
log4cxx中文輸出錯(cuò)誤補(bǔ)丁
(金慶的專欄)
已提交Bug:https://issues.apache.org/jira/browse/LOGCXX-399
log4cxx_0.10.0及主干代碼,Windows下輸出中文,發(fā)現(xiàn)有多余輸出。
void main()
{
setlocale(LC_ALL, "");
LOG4CXX_INFO(pLog, "一二"); // log 2 chinese characters.
}
輸出為:一二二。
錯(cuò)誤在 MbstowcsCharsetDecoder::decode().
size_t converted = mbsrtowcs(...
if (converted == (size_t) -1) {
...
} else {
stat = append(out, buf);
in.position(in.position() + converted); // ERROR!
}
mbsrtowcs()返回的是漢字的字?jǐn)?shù),而輸入緩沖區(qū)in的position是按字節(jié)計(jì)數(shù)的,
對(duì)于漢字,position應(yīng)該增加2*converted,而不是converted.
因?yàn)閜osition少增加了一半,所以后半部分字符串會(huì)重復(fù)解碼。
可如下更改:
if (converted == (size_t) -1) {
...
} else {
stat = append(out, buf);
// in.position(in.position() + converted); // ERROR!
if (src)
in.position(src - in.data());
else // mbsrtowcs() set src to NULL.
in.position(in.position() + strnlen(in.current(), in.remaining()));
}
此處的in是個(gè)二進(jìn)制塊,其中可能會(huì)有0,而mbsrtowcs()的輸入應(yīng)該是0結(jié)尾的字符串。
碰到0時(shí),mbsrtowcs()認(rèn)為已經(jīng)成功轉(zhuǎn)換到串尾,并將src重設(shè)為NULL。
代碼中已經(jīng)有對(duì)0的處理。
有可能mbsrtowcs()會(huì)越過輸入緩沖區(qū)的尾部一直讀取,最多為256字節(jié),仍有可能出現(xiàn)垃圾字符。
但是現(xiàn)在的std::string實(shí)現(xiàn)有0結(jié)尾,所有才沒有出錯(cuò)。若要更正這個(gè)錯(cuò)誤,就需要在輸入緩沖區(qū)尾部添0。
posted on 2012-11-19 20:29
金慶
閱讀(1509)
評(píng)論(3)
編輯
收藏
引用
所屬分類:
1. C/C++
評(píng)論
#
re: log4cxx中文輸出錯(cuò)誤補(bǔ)丁
2014-03-06 17:00
bigbad
很有幫助, 頂。
不過最后應(yīng)該寫為:
in.position(in.position() + strnlen(src, in.remaining()));
否則只轉(zhuǎn)255個(gè)wchar_t
回復(fù)
更多評(píng)論
#
re: log4cxx中文輸出錯(cuò)誤補(bǔ)丁
2014-03-06 17:37
bigbad
汗, 上面錯(cuò)了。 最后更新position,應(yīng)該這樣寫
if(src ==NULL)
{
in.position(in.limit());
}
else
{
in.position(in.position() + src - in.current());
}
回復(fù)
更多評(píng)論
#
re: log4cxx中文輸出錯(cuò)誤補(bǔ)丁
2014-05-13 21:15
金慶
@bigbad
src不為空時(shí),position到新的src處,這2種計(jì)算相同:
in.position(in.position() + src - in.current());
in.position(src - in.data());
src為空時(shí),2種計(jì)算不相同:
in.position(in.limit());
in.position(in.position() + strnlen(in.current(), in.remaining()));
當(dāng)in中間有'\0'時(shí),in.limit()會(huì)跳過剩余的輸入串。
回復(fù)
更多評(píng)論
刷新評(píng)論列表
只有注冊(cè)用戶
登錄
后才能發(fā)表評(píng)論。
【推薦】100%開源!大型工業(yè)跨平臺(tái)軟件C++源碼提供,建模,組態(tài)!
相關(guān)文章:
How are dtLinks created in NavMesh
C++ parameter passing rules
Naming Conventions for Accessors
Visual Studio 2019 Compiler Hangs
Fbx File Format Identifier
查找內(nèi)存錯(cuò)誤
std::thread 中的異常會(huì)丟失調(diào)用棧
用賦值代替 protobuf CopyFrom()
vs2017 linux 編譯輸出改成 vs 格式
為 LiteIDE 添加選中標(biāo)記
網(wǎng)站導(dǎo)航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Powered by:
C++博客
Copyright © 金慶
久久人人爽人人爽人人片AV不
|
久久国产乱子伦免费精品
|
人人狠狠综合久久亚洲高清
|
亚洲人成网站999久久久综合
|
国产精品久久久久久久人人看
|
亚洲а∨天堂久久精品
|
99久久精品免费看国产一区二区三区
|
久久精品卫校国产小美女
|
久久综合亚洲欧美成人
|
精品久久人人妻人人做精品
|
久久精品国产亚洲AV大全
|
午夜精品久久久久久久无码
|
99久久无色码中文字幕
|
伊人久久大香线蕉精品不卡
|
91精品观看91久久久久久
|
中文字幕无码精品亚洲资源网久久
|
亚洲国产精品无码久久青草
|
好久久免费视频高清
|
久久狠狠爱亚洲综合影院
|
久久精品国产第一区二区三区
|
亚洲国产成人久久综合碰
|
香港aa三级久久三级
|
亚洲色欲久久久综合网
|
久久人人青草97香蕉
|
久久国产V一级毛多内射
|
久久精品男人影院
|
国产精品一区二区久久精品
|
99久久99久久精品国产片果冻
|
亚洲?V乱码久久精品蜜桃
|
久久影院午夜理论片无码
|
久久久久18
|
亚洲Av无码国产情品久久
|
亚洲伊人久久成综合人影院
|
久久精品国产免费
|
97久久精品无码一区二区天美
|
久久久久人妻一区精品色
|
亚洲级αV无码毛片久久精品
|
久久99精品久久久久久野外
|
国产呻吟久久久久久久92
|
国内精品久久久久久久coent
|
99久久精品国产综合一区
|