金慶的專欄
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 © 金慶
青青草国产97免久久费观看
|
亚洲AV无码久久
|
日日狠狠久久偷偷色综合免费
|
久久强奷乱码老熟女网站
|
狠狠综合久久AV一区二区三区
|
国产精品久久久久9999高清
|
欧美午夜A∨大片久久
|
色播久久人人爽人人爽人人片aV
|
四虎亚洲国产成人久久精品
|
久久久久无码精品国产
|
欧美久久亚洲精品
|
99久久成人18免费网站
|
人妻精品久久久久中文字幕69
|
国产精品美女久久久免费
|
久久永久免费人妻精品下载
|
狠狠色丁香婷婷久久综合
|
国产精品成人无码久久久久久
|
国产三级久久久精品麻豆三级
|
亚洲精品国产自在久久
|
久久电影网
|
精品久久久无码中文字幕天天
|
91精品国产色综合久久
|
人妻少妇久久中文字幕一区二区
|
成人综合久久精品色婷婷
|
日韩va亚洲va欧美va久久
|
久久久久久极精品久久久
|
99久久国产综合精品五月天喷水
|
久久99久久成人免费播放
|
精品综合久久久久久97超人
|
久久婷婷人人澡人人爽人人爱
|
精品久久久久久国产三级
|
久久国产乱子伦精品免费午夜
|
欧美777精品久久久久网
|
国产成人精品综合久久久
|
99麻豆久久久国产精品免费
|
久久久国产精品亚洲一区
|
国内精品久久久久久久涩爱
|
久久亚洲色一区二区三区
|
亚洲欧美久久久久9999
|
精品久久久久久无码不卡
|
久久成人国产精品免费软件
|