WEB开发网      婵犵數濮烽弫鍛婄箾閳ь剚绻涙担鍐叉搐绾剧懓鈹戦悩瀹犲闁汇倗鍋撻妵鍕箛閸洘顎嶉梺绋款儑閸犳劙濡甸崟顖氬唨闁靛ě浣插亾閹烘鈷掗柛鏇ㄥ亜椤忣參鏌″畝瀣暠閾伙絽銆掑鐓庣仭缁楁垿姊绘担绛嬪殭婵﹫绠撻、姘愁樄婵犫偓娴g硶鏀介柣妯款嚋瀹搞儱螖閻樺弶鍟炵紒鍌氱Ч瀹曟粏顦寸痪鎯с偢瀵爼宕煎☉妯侯瀳缂備焦顨嗗畝鎼佸蓟閻旈鏆嬮柣妤€鐗嗗▓妤呮⒑鐠団€虫灀闁哄懐濮撮悾鐤亹閹烘繃鏅濋梺闈涚墕濡瑩顢欒箛鏃傜瘈闁汇垽娼ф禒锕傛煕閵娿儳鍩f鐐村姍楠炴﹢顢欓懖鈺嬬幢闂備浇顫夊畷妯肩矓椤旇¥浜归柟鐑樻尭娴滃綊姊虹紒妯虹仸闁挎洍鏅涜灋闁告洦鍨遍埛鎴︽煙閼测晛浠滃┑鈥炽偢閹鈽夐幒鎾寸彇缂備緡鍠栭鍛搭敇閸忕厧绶炴俊顖滅帛濞呭洭姊绘担鐟邦嚋缂佽鍊垮缁樼節閸ャ劍娅囬梺绋挎湰缁嬫捇宕㈤悽鍛婄厽閹兼番鍨婚埊鏇㈡煥濮樿埖鐓熼煫鍥ュ劤缁嬭崵绱掔紒妯肩畺缂佺粯绻堝畷姗€濡歌缁辨繈姊绘担绛嬪殐闁搞劋鍗冲畷顖炲级閹寸姵娈鹃梺缁樻⒒閳峰牓寮崒鐐寸厱闁抽敮鍋撻柡鍛懅濡叉劕螣鐞涒剝鏂€闂佺粯鍔曞Ο濠囧吹閻斿皝鏀芥い鏃囨閸斻倝鎽堕悙鐑樼厱闁哄洢鍔屾晶顖炴煕濞嗗繒绠婚柡灞界Ч瀹曨偊宕熼鈧▍锝囩磽娴f彃浜炬繝銏f硾椤戝洨绮绘ィ鍐╃厵閻庢稒岣跨粻姗€鏌ㄥ☉妯夹fい銊e劦閹瑩顢旈崟顓濈礄闂備浇顕栭崰鏍礊婵犲倻鏆﹂柟顖炲亰濡茶鈹戦埄鍐ㄧ祷妞ゎ厾鍏樺璇测槈閵忕姈鈺呮煏婢跺牆鍔撮柛鏂款槺缁辨挻鎷呯粙搴撳亾閸濄儳鐭撶憸鐗堝笒閺嬩線鏌熼崜褏甯涢柡鍛倐閺屻劑鎮ら崒娑橆伓 ---闂傚倸鍊搁崐鐑芥倿閿旈敮鍋撶粭娑樺幘濞差亜鐓涢柛娑卞幘椤斿棝姊虹捄銊ユ珢闁瑰嚖鎷�
开发学院WEB开发Jsp Java语言中字符的处理 阅读

Java语言中字符的处理

 2008-01-05 09:49:49 来源:WEB开发网 闂傚倸鍊搁崐椋庢濮橆兗缂氱憸宥堢亱闂佸湱铏庨崰鏍不椤栫偞鐓ラ柣鏇炲€圭€氾拷闂傚倸鍊搁崐椋庣矆娓氣偓楠炲鏁撻悩鎻掔€梺姹囧灩閻忔艾鐣烽弻銉︾厵闁规鍠栭。濂告煕鎼达紕校闁靛洤瀚伴獮鎺楀箣濠靛啫浜鹃柣銏⑶圭壕濠氭煙閻愵剚鐏辨俊鎻掔墛缁绘盯宕卞Δ鍐冣剝绻涘畝濠佺敖缂佽鲸鎹囧畷鎺戭潩閹典焦鐎搁梻浣烘嚀閸ゆ牠骞忛敓锟�婵犵數濮烽弫鍛婃叏椤撱垹绠柛鎰靛枛瀹告繃銇勯幘瀵哥畼闁硅娲熷缁樼瑹閳ь剙岣胯鐓ら柕鍫濇偪濞差亜惟闁宠桨鑳堕崝锕€顪冮妶鍡楃瑐闁煎啿鐖奸崺濠囧即閵忥紕鍘梺鎼炲劗閺呮稒绂掕缁辨帗娼忛埡浣锋闂佽桨鐒﹂幑鍥极閹剧粯鏅搁柨鐕傛嫹闂傚倸鍊搁崐椋庢濮橆兗缂氱憸宥堢亱闂佸湱铏庨崰鏍不椤栫偞鐓ラ柣鏇炲€圭€氾拷  闂傚倸鍊搁崐鐑芥嚄閼哥數浠氱紓鍌欒兌缁垶銆冮崨鏉戠厺鐎广儱顦崡鎶芥煏韫囨洖校闁诲寒鍓熷铏圭磼濡搫顫岄梺鍦拡閸嬪棝鎯€椤忓浂妯勯梺鍝勬湰濞叉ḿ鎹㈠┑濠勭杸闁哄洨濮烽悰銉╂⒒娴e搫甯跺鐟帮攻缁傚秴饪伴崼姘e亾閺冨牆绀冩い蹇庣娴滈箖鏌ㄥ┑鍡涱€楀褜鍠栭湁闁绘ɑ鐟ョ€氼喚绮绘ィ鍐╃厱妞ゆ劑鍊曢弸搴ㄦ煟韫囧鍔滈柕鍥у瀵潙螣閸濆嫬袝婵$偑鍊戦崹娲偡閳哄懎绠栭柍鈺佸暞閸庣喖鏌曢崶褍绨婚柟鍑ゆ嫹
核心提示:摘要:本文主要讨论了java语言中字符的非凡表达形式,尤其是中文信息的表达处理,Java语言中字符的处理,阐述了字符处理的要害是要将十六位Unicode字符,转换为本地下层平台,在Java中,字符处理的要害是要将十六位Unicode字符,也就是运行Java虚拟处理机的平台能够理解的字符形式,要害词:Java、字符、8位

  ----摘要:本文主要讨论了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虚拟处理机的平台能够理解的字符形式。

Tags:Java 字符

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接