金慶的專欄
C++博客
::
首頁
::
新隨筆
::
聯(lián)系
::
聚合
::
管理
::
423 隨筆 :: 0 文章 :: 454 評論 :: 0 Trackbacks
公告
我的隨筆
我的評論
我參與的隨筆
留言簿
(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)
相冊
公告照片
搜索
積分與排名
積分 - 659023
排名 - 25
最新評論
1.?re: boost::asio::spawn 將一統(tǒng)C++網(wǎng)絡(luò)庫
asio 成為C++首選網(wǎng)絡(luò)庫
--linda
2.?re: log4cxx中文輸出錯(cuò)誤補(bǔ)丁
評論內(nèi)容較長,點(diǎn)擊標(biāo)題查看
--金慶
3.?re: mingw編譯OrzNet
能發(fā)送一個(gè)mingw編譯好的OrzNet庫給我嗎? liuweiqcxy@163.com
謝謝!
--劉威
4.?re: log4cxx中文輸出錯(cuò)誤補(bǔ)丁
評論內(nèi)容較長,點(diǎn)擊標(biāo)題查看
--bigbad
5.?re: log4cxx中文輸出錯(cuò)誤補(bǔ)丁
評論內(nèi)容較長,點(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腳本的效率測試(9019)
評論排行榜
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ù)的,
對于漢字,position應(yīng)該增加2*converted,而不是converted.
因?yàn)閜osition少增加了一半,所以后半部分字符串會重復(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)制塊,其中可能會有0,而mbsrtowcs()的輸入應(yīng)該是0結(jié)尾的字符串。
碰到0時(shí),mbsrtowcs()認(rèn)為已經(jīng)成功轉(zhuǎn)換到串尾,并將src重設(shè)為NULL。
代碼中已經(jīng)有對0的處理。
有可能mbsrtowcs()會越過輸入緩沖區(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)
評論(3)
編輯
收藏
引用
所屬分類:
1. C/C++
評論
#
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ù)
更多評論
#
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ù)
更多評論
#
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()會跳過剩余的輸入串。
回復(fù)
更多評論
刷新評論列表
只有注冊用戶
登錄
后才能發(fā)表評論。
【推薦】100%開源!大型工業(yè)跨平臺軟件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 中的異常會丟失調(diào)用棧
用賦值代替 protobuf CopyFrom()
vs2017 linux 編譯輸出改成 vs 格式
為 LiteIDE 添加選中標(biāo)記
網(wǎng)站導(dǎo)航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Powered by:
C++博客
Copyright © 金慶
国产激情久久久久影院小草
|
日产精品久久久久久久
|
91久久精一区二区三区大全
|
久久成人国产精品二三区
|
segui久久国产精品
|
久久天天躁狠狠躁夜夜av浪潮
|
久久伊人精品一区二区三区
|
久久精品国产99国产精品澳门
|
日韩十八禁一区二区久久
|
久久综合精品国产二区无码
|
国产福利电影一区二区三区久久久久成人精品综合
|
99久久99久久
|
中文字幕精品久久久久人妻
|
亚洲国产精久久久久久久
|
久久久SS麻豆欧美国产日韩
|
国内精品久久久久国产盗摄
|
久久精品国产亚洲77777
|
国产精品无码久久久久
|
久久久国产乱子伦精品作者
|
久久综合色之久久综合
|
国产成人精品久久二区二区
|
一本一本久久A久久综合精品
|
久久精品中文字幕无码绿巨人
|
亚洲国产精品成人久久蜜臀
|
国产午夜精品理论片久久
|
国产精品久久久久国产A级
|
无码任你躁久久久久久老妇App
|
亚洲午夜精品久久久久久人妖
|
MM131亚洲国产美女久久
|
人妻无码精品久久亚瑟影视
|
久久久久无码精品
|
久久国产免费观看精品
|
99久久免费国产精精品
|
国产精品久久久久久吹潮
|
久久人爽人人爽人人片AV
|
无码精品久久久天天影视
|
无码国内精品久久人妻蜜桃
|
人妻少妇久久中文字幕
|
久久99精品久久久久婷婷
|
久久久精品国产sm调教网站
|
久久精品国产99国产精品亚洲
|