1 回答

TA貢獻(xiàn)883條經(jīng)驗(yàn) 獲得超454個(gè)贊
哈哈,這個(gè)很有意思。因?yàn)槲矣X得也不應(yīng)該 find 到,所以我就在我這里試了下,果然沒找到!
可你卻找到了!那么我猜得這是編碼問題(因?yàn)槲夷J(rèn)用的是 UTF-8 編碼),而且我猜你是在 Windows 系統(tǒng)下。我據(jù)此去查了下‘硚’的編碼,果然如此。這個(gè)結(jié)果非常有趣,我說一下:
Windows 使用的 ANSI 編碼會(huì)將一個(gè)漢字編碼為兩字節(jié)?!俺~”這個(gè)字的編碼是 b3 7e?!啊钡木幋a是 7e,恰好是硚編碼的第二個(gè)字節(jié)!
而 string 表示的是 char 字符串,也就是會(huì)把每個(gè)字符當(dāng)作 char 來處理——即會(huì)按字節(jié)來處理,所以 find 按 char 來查找就找到了 7e!
一般來說,涉及漢字的編碼會(huì)比較復(fù)雜,在初學(xué)做字符串的實(shí)驗(yàn)時(shí)不要用漢字!
P.S. 如果你一定要用漢字的話,就要用能夠處理“寬字符”的庫函數(shù)。std::wstring 是保存寬字符的字符串,在寫字符串字面量時(shí)在前面加上 L 表示其為寬字符串:
std::wstring?wchn?=?L"硚"; std::wstring?wtilde?=?L"~"; cout?<<?wchns.find(wtilde)?<<?endl;
這樣應(yīng)該就找不到了。 不過在初學(xué)時(shí)還是盡量避免用漢字吧!
- 1 回答
- 0 關(guān)注
- 1478 瀏覽
添加回答
舉報(bào)