JAVA字符集编码备忘

iso-8859-1是JAVA网络传输使用的标准字符集,而gb2312是标准中文字符集,当你作出提交表单等需要网络传输的操作的时候,就需要把iso-8859-1转换为gb2312字符集显示,否则如果按浏览器的gb2312 格式来解释iso-8859-1字符集的话,由于2者不兼容,所以会是乱码.

------------------------------------------------------------------------------------------------------------------------------------------------

常用编码名称 说明
ASCII 7位:与ascii7相同
ISO8859-1: 与 8859_1,ISO-8859-1,ISO_8859-1等相同
GB2312-80 16位:与gb2312,gb2312-1980等相同
UTF8 与UTF-8相同
GBK :注意:兼容GB2312

------------------------------------------------------------------------------------------------------------------------------------------------
ISO-8859-1:属于单字节编码,最多能表示的字符范围是0-255,应用于英文系列,无法表示中文字符。

GB2312/GBK:这就是汉字的国标码,GBK提供了20902个汉字,专门用来表示汉字,是双字节编码,而英文字母和ISO8859-1一致(兼容ISO8859-1编码)。其中gbk编码能够用来同时表示繁体字和简体字,而GB2312只能表示简体字,GBK是兼容GB2312编码的。

unicode:这是最统一的编码,可以用来表示所有语言的字符,而且是定长双字节(也有四字节的)编码,包括英文字母在内。所以可以说它是不兼容ISO8859-1编码的,也不兼容任何编码。

UTF:考虑到unicode编码不兼容ISO8859-1编码,而且容易占用更多的空间:因为对于英文字母,unicode也需要两个字节来表示。所以unicode不便于传输和存储。因此而产生了utf编码,utf编码兼容iso8859-1编码,同时也可以用来表示所有语言的字符,不过,UTF编码是不定长编码,每一个字符的长度从1-6 个字节不等。另外,UTF编码自带简单的校验功能。一般来讲,英文字母都是用一个字节表示,而汉字使用三个字节。

注意,虽然说utf是为了使用更少的空间而使用的,但那只是相对于unicode编码来说,如果已经知道是汉字,则使用GB2312/GBK无疑是最节省的。不过另一方面,值得说明的是,虽然utf编码对汉字使用3个字节,但即使对于汉字网页,utf编码也会比unicode编码节省,因为网页中包含了很多的英文字符。

------------------------------------------------------------------------------------------------------------------------------------------------

对于浏览器的URL参数传递,通常使用UTF-8编码。
UTF-8编码:URLEncoder.encode(url, "UTF-8");
UTF-8解码:URLDecoder.decode(url, "UTF-8");

------------------------------------------------------------------------------------------------------------------------------------------------

XML文件读写同于文件读写,但应注意确保XML头中声明如<? xml version=”1.0” encoding=”gb2312” ?>与文件编码保持一致。

------------------------------------------------------------------------------------------------------------------------------------------------

1、对于JSP,确定头部加上 <%@ page contentType="text/html;charset=gb2312"%>这样的标签。
2、对于Servlet,确定 设置setContentType (“text/html; charset=gb2312”),以上两条用于使得输出汉字没有问题。
3、为输出HTML head中加一个 <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> ,让浏览器正确确定HTML编码。

------------------------------------------------------------------------------------------------------------------------------------------------

Unicode与各编码之间的直接转换:

Unicode和GBK:每个汉字转换为两个字节,且是可逆的,即通过字节可以转换回字符串
Unicode和UTF-8:每个汉字转换为三个字节,且是可逆的,即通过字节可以转换回字符串
Unicode和ISO-8859-1:当存在汉字时转换失败,[color=red]非可逆[/color], 即通过字节不能再转换回字符串

String str = new String("中文字符");
String str1 = new String(str.getBytes("gb2312"),"gb2312");
String str2 = new String(str.getBytes("utf8"),"utf8");
String str3 = new String(str.getBytes("8859_1"),"8859_1");
System.out.println(str1);
System.out.println(str2);
System.out.println(str3);

输出结果:
[color=red]中文字符
中文字符
????[/color]

------------------------------------------------------------------------------------------------------------------------------------------------

linux默认编码

这里所说的linux默认编码,是指运行时的环境变量。两个重要的环境变量是LC_ALL和LANG,默认编码会影响到java URLEncode的行为,下面有描述。

建议都设置为"zh_CN.UTF-8"。

------------------------------------------------------------------------------------------------------------------------------------------------

Oracle数据库一般使用ISO8859_1
如果String中是UNICODE字符,写入读出时需要转码
写入:String newStr = new String(oldStr.getByte(“GB2312”), “ISO8859_1”);
读出:String newStr = new String(oldStr.getByte(“ISO8859_1”),”GB2312”);

------------------------------------------------------------------------------------------------------------------------------------------------
。。。。。。。。。。。。。。。待添加。。。。。。。。。。。。。
基于遗传算法的微电网调度(风、光、蓄电池、微型燃气轮机)(Matlab代码实现)内容概要:本文档介绍了基于遗传算法的微电网调度模型,涵盖风能、太阳能、蓄电池和微型燃气轮机等多种能源形式,并通过Matlab代码实现系统优化调度。该模型旨在解决微电网中多能源协调运行的问题,优化能源分配,降低运行成本,提高可再生能源利用率,同时考虑系统稳定性与经济性。文中详细阐述了遗传算法在求解微电网多目标优化问题中的应用,包括编码方式、适应度函数设计、约束处理及算法流程,并提供了完整的仿真代码供复现与学习。此外,文档还列举了大量相关电力系统优化案例,如负荷预测、储能配置、潮流计算等,展示了广泛的应用背景和技术支撑。; 适合人群:具备一定电力系统基础知识和Matlab编程能力的研究生、科研人员及从事微电网、智能电网优化研究的工程技术人员。; 使用场景及目标:①学习遗传算法在微电网调度中的具体实现方法;②掌握多能源系统建模与优化调度的技术路线;③为科研项目、毕业设计或实际工程提供可复用的代码框架与算法参考; 阅读建议:建议结合Matlab代码逐段理解算法实现细节,重点关注目标函数构建与约束条件处理,同时可参考文档中提供的其他优化案例进行拓展学习,以提升综合应用能力。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值