国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

idea中使用Inputstream流導(dǎo)致中文亂碼解決方法

瀏覽:6日期:2024-07-09 17:59:47
1.問題描述

idea中使用Inputstream流導(dǎo)致中文亂碼解決方法,當(dāng)然也不一定就是輸入流,可能輸出流或者其他用到了流相關(guān)的字符的都可能出現(xiàn)亂碼,這里有一個(gè)可能的解決辦法。

2. 解決辦法

① idea中找到下面的路徑

File--Settings--Editor--File Encodings

② Transparent native-to-ascii conversion把這個(gè)前面勾上,重新創(chuàng)建文件,執(zhí)行就OK

idea中使用Inputstream流導(dǎo)致中文亂碼解決方法

很多朋友遇到Java FileInputStream讀中文亂碼問題,下面小編在給大家普及下這方便的知識及解決方法。

1、前提

以讀取編碼是GBK的文件為案例,文件內(nèi)容只有中文和中文符號

2、原因

FileInputStream讀中文亂碼是因?yàn)橐粋€(gè)中文對應(yīng)兩個(gè)字節(jié)存儲(chǔ)(負(fù)數(shù)),也就是說,讀取對應(yīng)中文的字節(jié)數(shù)應(yīng)該是偶數(shù); 而英文對應(yīng)一個(gè)字節(jié)存儲(chǔ)。FileInputStream每次讀取一個(gè)數(shù)組長度的字節(jié)時(shí),讀取的中文字節(jié)數(shù)可能是奇數(shù),也就是只讀到中文的一半字節(jié),出現(xiàn)亂碼。

3、解決方法

一次讀取所有字節(jié),此方法不靠譜,因?yàn)椴淮_定總字節(jié)數(shù)。

在輸出時(shí)進(jìn)行判斷,遍歷數(shù)組判斷負(fù)數(shù)的個(gè)數(shù),如果是奇數(shù),說明讀取到中文的一半字節(jié),對數(shù)組進(jìn)行擴(kuò)容再輸出;否則正常輸出

4、代碼案例

package 第二題;import java.io.File;import java.io.FileInputStream;import java.io.FileNotFoundException;import java.io.IOException;import java.io.UnsupportedEncodingException;import java.util.Arrays;​public class MainTest {​public static void main(String[] args) throws UnsupportedEncodingException {// 創(chuàng)建File對象File file = new File('D:filetestfile4.txt');FileInputStream fileInputStream = null;try {// 新建一個(gè)FileInputStream對象fileInputStream = new FileInputStream(file);// 新建一個(gè)字節(jié)數(shù)組byte[] buf = new byte[2];// read(buf):此方法的返回值就是當(dāng)前讀取的字節(jié)個(gè)數(shù),將數(shù)據(jù)讀取到buf數(shù)組// 將readLen變量也就是read方法的返回值,當(dāng)此變量等于-1,則讀到文件末尾int readLen = -1;//讀取文件數(shù)據(jù)while ((readLen = fileInputStream.read(buf)) != -1) {int pos=0;//記錄負(fù)數(shù)的個(gè)數(shù)for(byte v:buf){if(v<0){pos++;}}//負(fù)數(shù)個(gè)數(shù)為偶數(shù),讀取完整,沒有讀取到半個(gè)中文if(pos%2==0){// 將字節(jié)數(shù)組轉(zhuǎn)換成字符串String content = new String(buf, 0, readLen);System.out.print(content);}else {//負(fù)數(shù)個(gè)數(shù)為奇數(shù),讀取不完整,會(huì)亂碼//再讀取下一位字節(jié)int nextByteValue=fileInputStream.read();int nextLen=readLen+1;//字節(jié)數(shù)組擴(kuò)容一位buf= Arrays.copyOf(buf,nextLen);buf[readLen]= (byte) nextByteValue;String content=new String(buf,0,nextLen);System.out.print(content);//奇數(shù),字節(jié)補(bǔ)全//針對數(shù)組擴(kuò)容一個(gè)字節(jié)單元/* buf=Arrays.copyOf(buf, readLen+1);int nextByteValue=fileInputStream.read();buf[readLen]= (byte) nextByteValue;String content = new String(buf, 0, readLen);System.out.print(content);*/}}} catch (FileNotFoundException e) {// 輸出堆棧信息e.printStackTrace();} catch (IOException e) {e.printStackTrace();} finally {try {// 文件輸入流關(guān)閉(釋放資源)fileInputStream.close();} catch (IOException e) {// TODO Auto-generated catch blocke.printStackTrace();}}}}

以上就是idea中使用Inputstream流導(dǎo)致中文亂碼解決方法的詳細(xì)內(nèi)容,更多關(guān)于idea Inputstream流亂碼的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: IDEA
相關(guān)文章:
主站蜘蛛池模板: 博客| 政和县| 健康| 克什克腾旗| 永康市| 松江区| 合作市| 汾阳市| 波密县| 太谷县| 尼勒克县| 旅游| 唐海县| 中阳县| 凯里市| 休宁县| 额济纳旗| 翁牛特旗| 孟连| 迁安市| 枞阳县| 永和县| 江安县| 武乡县| 和静县| 永德县| 双城市| 营口市| 于田县| 西乌珠穆沁旗| 安丘市| 达日县| 兴义市| 九江县| 湘阴县| 太康县| 曲靖市| 临沧市| 萍乡市| 裕民县| 灵山县|