在j2me开发过程中,我们经常会把一个文字信息保存在txt格式的文本文件中做为资源。这样便于修改和管理。那么读取它们对于一些刚接触j2me的朋友会有些困难。前几天研究了下,看了一些兄弟的文章和代码,总结出3种方法分别读取unicode,utf-8,unicode big endian格式的文件...本文没考虑读取的效率问题。
这三种方法都能读取中文和英文字符.用来存放的数组长度视文本长度而定....
另外还有一些只能读取英文字符的方法就不列举出来了.
一、读取unicode格式
| private string read_uni(string resource) { byte word_uni[]=new byte[1024]; string strreturn=""; inputstream is; try { is=getclass().getresourceasstream(resource); is.read(word_uni); is.close(); stringbuffer stringbuffer = new stringbuffer(""); for (int j = 0; j < word_uni.length; ) { int k = word_uni[j++]; //注意在这个地方进行了码制的转换 if (k < 0) k += 256; int l = word_uni[j++]; if (l < 0) l += 256; char c = (char) (k + (l << 8)); //把高位和低位数组装起来 stringbuffer.append(c); } strreturn=stringbuffer.tostring(); } catch(ioexception e) { e.printstacktrace(); } finally { is=null; } return strreturn; } |
(图片较大,请拉动滚动条观看)
读取unicode big endian格式时,采用readchar()方法读取,所以存放时使用char数组存放。
注意:在文本的末尾加上'$'表示文本的结束。
另外代码第10行dis.skip(2)是略过文件头2个字符,如果用microsoft notepad保存的一定存在这两个头字符。
当然,可以使用ultraedit可以先删掉这两个头字符,然后使用新建文件,复制粘贴,保存为其它格式.这样两个头字符就没了..
| private string read_uni_b_e(string resource) { char word_uni_b_e[]=new char[1024]; string strreturn=""; datainputstream dis; try { dis=new datainputstream(getclass().getresourceasstream(resource)); int counter=0; dis.skip(2); char temp; while(true) { temp=dis.readchar(); if(temp=='$') break; word_uni_b_e[counter++]=temp; } dis.close(); strreturn=string.valueof(word_uni_b_e,0,counter); } catch(exception e) { system.out.println("read_uni_b_e error!"+e.getmessage()); } finally { dis=null; } return strreturn; } |
以上3种方法测试平台:
| operation system: microsoft windows xp professional service pack 1 emulator: sun wireless toolkit 2.2 beta defaultcolorphone |
闽公网安备 35060202000074号