一个文本文件,如何知道它是GBK编码、还是UTF-8编码?BOM是什么东西?

本文深入探讨了文本文件编码的奥秘,特别是如何通过检测文件头部的字节序标记(BOM)来判断文件是否采用UTF-8、UTF-16BE或UTF-16LE编码。对于未使用BOM的文件,则默认为本地字符编码,如Windows平台上的GBK。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

( Java 面试题  | Java学习指南 )

我们平时看到的文本文件,虽然都是文本,但有的是GBK编码,有的UTF-8编码。那么,对于一个阅读器,它在读取一个文本文件时如何知道它是GBK还是UTF-8呢?

 

奥秘在于文件头部的几个字节。

规定如下:当以UTF16或UTF-8编码存储时,头部需要添加几个字节作为标识。称为 BOM

UTF8: 头部3个字节 EF BB BF
UTF16BE (Big-Endian) : FE FF 
UTF16LE (Little-Endian) : FF FE

由于UTF-8是我们常见的类型,所以只要关闭UTF-8的BOM即可。

 

当我们自己读取一个文本文件时,便要注意这种事情。要检测头部是否有 EF BB BF ,这三个字节是编码标识,不是有效内容。

final byte[] bom= { (byte)0xEF, (byte)0xBB, (byte)0xBF };
if ( buf[0] == bom[0] && buf[1] == bom[1] && buf[2] == bom[2] )
{
    // It's UTF8 encoded ...
}

反之,如果没有检测到这几种BOM,但是ANSI(本地字符编码)。对于Windows中文版来说,本地编码就是GBK编码。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿发你好

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值