动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
电脑书籍下载:程序设计书籍 | 数据库教程书籍 | 平面与多媒体书籍 | 网络通讯书籍 | 系统管理书籍 | 网络安全书籍 | 认证考试书籍
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ Java教程 ]的信息



本月文章推荐
.初学者如何开发出一个高质量的J2.
.[JAVA100例]071、使用JDOM操作XML.
.归并排序算法的JAVA实现.
.静态成员.
.Javascript实例教程(19) 使用HoT.
.Tuxedo配置管理简要说明.
.sun Technical Training NOTE.
.在JAVA中连接Sybase数据库的例子.
.Java进阶:JNI使用技巧点滴积累.
.使用JavaWebStart.
.JBuilder Editor中光标不能正确定.
.如何用Java编写自己的库(3).
.在Java中动态执行类的静态方法.
.java 学习笔记.
.如何让JBuilder运行在JDK1.4之上.
.Java初学者入门需掌握的30个基本.
.用主类合并线程.
.步入J2EE架构和过程基础教程(1).
.Java小程序源文件的组成.
.JDBMonitor全攻略.

Java语言中字符的处理

发表日期:2008-1-5 |



  ----摘要:本文主要讨论了Java语言中字符的非凡表达形式,尤其是中文信息的表达处理,阐述了字符处理的要害是要将十六位Unicode字符,转换为本地下层平台,也就是运行Java虚拟处理机的平台能够理解的字符形式。
  ----要害词:Java、字符、8位、16位、Unicode字符集
  
  ----Java是一种编程语言、一个运行系统、一套开发工具和一个应用程序编程界面(API)。Java建立在C++的熟悉、有用的特征之上,而取消了C++的复杂的、危险的和多余的元素。它是一个更安全、更简单、更轻易使用的语言。
  
  1、Java的字符表达
  
  ----Java语言和C语言对字符进行了互不相同的描述,Java使用16位的Unicode字符集(该标准描述了许多语言的各种不同字符),因此Java字符是一个16位的无符号整数,字符变量用来存放单个字符,而不是完整的字符串。
  
  ----一个字符(character),就是单个字母(letter),许多字母构成一个单词,一组单词组成句子,以此类推。但是对于含有诸如中文信息的字符,就不是那么简单了。
  
  ----Java的基本的char类型被定义成无符号的16位,它是Java中唯一的一个无符号类型。使用16位表达字符的主要原因是要让Java能够支持任何Unicode字符,因此而使得Java适用于描述或显示任何被Unicode支持的语言,可移植性也就会更好。但是,能够支持某种语言的字符串显示,和能够正确打印某种语言的字符串,经常是两个不同的问题。由于Oak(Java最初的代号)开发组的主要环境是Unix系统和某些源于Unix的系统,所以对开发人员来说,最为方便实用的字符集是ISOLatin-1。相应地,这一开发组就带有Unix遗传性,也就导致了Java的I/O系统在很大程度上以Unix的流概念为模型,而在Unix系统中,每一种I/O设备都是用一串8比特的流来表示。这种在I/O系统方面取模于Unix的做法,使得Java语言拥有16位的Java字符,而却只有8位的输入设备,这样就给Java带来了些不足。因此在任何一处Java字符串按8位来读入或写出的地方,都得有一小段程序代码,被称为"劈(hack)",来将8位的字符映射成为16位Unicode,或将16位的Unicode劈成8位字符。
  
  2、问题及解决
  
  ----我们要实现从一个文件读取信息,尤其是读取含有中文信息的文件,并将读取到的信息显示在屏幕上,一般我们使用FileInputStream函数打开文件、readChar函数读入字符。如下:
  
  
  import java.io.*;
  public class rf{
   public static void main(String args[]) {
   FileInputStream fis;
   DataInputStream dis;
   char c;
  
   try {
   fis = new FileInputStream("xinxi.txt");
   dis = new DataInputStream(fis);
   while (true) {
   c = dis.readChar();
   System.out.print(c);
   System.out.flush();
   if (c == '\n') break;
   }
   fis.close();
   } catch (Exception e) { }
   System.exit(0);
   }
  }
  
  ----但是事实上,运行这一程序,所能得到的输出结果是一堆无用的乱码。不能正确输出xinxi.txt文件内容,其原因是readChar函数读入的是16位的Unicode字符,而System.out.print却将其当作八位的ISO latin-1字符输出。
  
  ----Java 1.1版本引入了一套全新的Readers和Writers接口来处理字符。我们可以利用InputStreamReader类而不是DataInputStream来处理文件。修改上面的程序如下:
  import java.io.*;
  
  
  public class rf {
   public static void main(String args[]) {
   FileInputStream fis;
   InputStreamReader irs;
   char ch;
  
   try {
   fis = new FileInputStream("xinxi.txt");
   irs = new InputStreamReader(fis);
   while (true) {
   ch = (char) irs.read();
   System.out.print(c);
   System.out.flush();
   if (ch == '\n') break;
   }
   fis.close();
   } catch (Exception e) { }
   System.exit(0);
   }
  }
  
  ----这样才能正确输出xinxi.txt中的文本(尤其是中文信息)。另外,当xinxi.txt文件来自不同的机器,即来自不同操作平台(或汉字内码不同)的机器,比如: 文件来自客户端(客户端上传文件给服务器),而读取文中信息的操作由服务器端执行。假如用上面的程序来实现这一功能,就有可能仍然不能得到正确的结果。其原因就是输入编码转换失败,我们还需要进行如下的改动:
  
  
   ......
   int c1;
   int j=0;
   StringBuffer str=new StringBuffer();
   char lll[][]= new char[20][500];
   String ll="";
   try {
   fis = new FileInputStream("fname.txt");
   irs = new InputStreamReader(fis);
   c1=irs.read(lll[1],0,50);
   while (lll[1][j]!=' ') {
   str.append(lll[1][j]);
   j=j+1;
   }
   ll=str.toString();
   System.out.println(ll);
   } catch (IOException e) {
   System.out.println(e.toString());}
   ......
  
  ----这样,输出的结果就正确了。当然,上面的程序是不完整的,只是说明了一下解决的方法。
  
  ----总之,Java语言中字符处理,尤其是中文信息的处理,比较非凡。在Java中,字符处理的要害是要将十六位Unicode字符,转换为本地下层平台也就是运行Java虚拟处理机的平台能够理解的字符形式。
上一篇:能够在非中文平台上显示汉字吗 人气:309
下一篇:如何在2D Graphics中使用双缓冲 人气:434
浏览全部Java的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-7-24 Sablog-X v2.0 预览版
2008-7-24 帝国备份王EmpireBak 2008 正式版
2008-7-24 网趣网上购物系统时尚版 v8.2
2008-7-24 纵横B2B电子商务系统XYECS!B2B v
2008-7-24 e路小说小偷 v1.2.0723
2008-7-24 凌风美女图片站程序 v2.2
2008-7-24 TOM15电影收索程序
2008-7-24 清风信息自动采集生成系统 v1.0
2008-7-24 QQ邮箱编辑器 v1.0 (小小菜刀ASP
2008-7-19 UltraEdit 简体中文增强版 14.10
2008-7-19 CentOS 5.2 i386 LiveCD
2008-7-19 Snapture多功能相机 v1.4
2008-7-19 iAcces中文输入法 v1.0Build016
2008-7-19 Cookbook烹饪秘籍 v2.5
2008-7-19 苹果专用DVD转换工具 v1.1.59汉化
2008-7-19 Modem修复软件ZiPhone修改版04.0
2008-7-19 AgileMessenger即时通讯工具美化
2008-7-19 Sketches画图软件 v0.7b6破解版


  发表评论
姓 名: 验证码:
内 容:
[ 汉字翻译拼音 ] [ 广告代码 ] [ 符号对照表 ] [ 进制转换 ] [ 经典小工具 ] [ 个税计算 ] [ 汉字简繁转换 ] [ 普通单位换算 ] [ 公制单位换算 ]
[ 生辰老黄历 ] [ 国内电话区号 ] [ 国家代码与域名缩写 ] [ 文字加密解密 ] [ 健康查询 ] [ 万年历 ] [ 手机号码查询 ] [ ip搜索 ] [ Google PR查询 ]
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報
防水工事·改修工事 フットサル大会 探偵