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

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

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

瀏覽:2日期:2024-07-09 17:59:47
1.問(wèn)題描述

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讀中文亂碼問(wèn)題,下面小編在給大家普及下這方便的知識(shí)及解決方法。

1、前提

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

2、原因

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

3、解決方法

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

在輸出時(shí)進(jìn)行判斷,遍歷數(shù)組判斷負(fù)數(shù)的個(gè)數(shù),如果是奇數(shù),說(shuō)明讀取到中文的一半字節(jié),對(duì)數(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對(duì)象File file = new File('D:filetestfile4.txt');FileInputStream fileInputStream = null;try {// 新建一個(gè)FileInputStream對(duì)象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ù),讀取完整,沒(méi)有讀取到半個(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ǔ)全//針對(duì)數(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流亂碼的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: IDEA
相關(guān)文章:
主站蜘蛛池模板: 南部县| 康马县| 唐海县| 七台河市| 玉林市| 绥芬河市| 洛浦县| 紫金县| 沁阳市| 姜堰市| 革吉县| 松潘县| 云安县| 白河县| 蓝山县| 卫辉市| 革吉县| 含山县| 尉犁县| 无锡市| 漳州市| 北碚区| 丰都县| 岫岩| 横峰县| 巴彦淖尔市| 衡东县| 武陟县| 钟山县| 旬阳县| 保山市| 拉孜县| 偏关县| 图木舒克市| 梅州市| 阿克陶县| 霍城县| 扎鲁特旗| 黑山县| 香港 | 田阳县|