Java:编码的详解
import java.io.*;
class EncodeStream
{
public static void main(String[] args)throws IOException
{
//writeText();
readText();
}
public static void writeText()throws IOException
{
OutputStreamWriter osw = new OutputStreamWriter(new FileOutputStream("GBK.txt"));//默认是GBK编码
//OutputStreamWriter osw = new OutputStreamWriter(new FileOutputStream("UTF-8.txt"),"utf-8");
//OutputStreamWriter osw = new OutputStreamWriter(new FileOutputStream("Unicode.txt"),"Unicode");
//OutputStreamWriter osw = new OutputStreamWriter(new FileOutputStream("ASCII.txt"),"ASCII");
//OutputStreamWriter osw = new OutputStreamWriter(new FileOutputStream("ISO8859-1.txt"),"ISO8859-1");
osw.write("你好!");
osw.flush();
osw.close();
}
public static void readText()throws IOException
{
InputStreamReader isr = new InputStreamReader(new FileInputStream("GBK.txt"),"GBK");
char[] buf = new char[1024];
int len = 0;
while((len = isr.read(buf))!=-1)
{
String s = new String(buf,0,len);
System.out.println(s);
}
String str = isr.getEncoding();
System.out.println(str);
isr.close();
}
}
import java.util.*;
class EncodeDemo
{
public static void main(String[] args)throws Exception
{
String s = "你好";
//编码
byte[] b1 = s.getBytes("GBK");//[-60, -29, -70, -61]四个字节
//byte[] b1 = s.getBytes("UTF-8");//[-28, -67, -96, -27, -91, -67]六个字节
//byte[] b1 = s.getBytes("Unicode");//[-2, -1, 79, 96, 89, 125]
//byte[] b1 = s.getBytes("ISO8859-1");//[63, 63]两个字节
//System.out.println(Arrays.toString(b1)); //解码
String str1 = new String(b1,"ISO8859-1");//应该是GBK的编码,结果解成了ISO8859-1编码,此时会出现乱码,需要重新编码解码
System.out.println(str1);//发现乱码结果是???? //对乱码再一次编码
byte[] b2 = str1.getBytes("ISO8859-1");
System.out.println(Arrays.toString(b2));//[-60, -29, -70, -61] //再一次解码
String str2 = new String(b2);
System.out.println(str2);//你好
}
}
class EncodeDemo2
{
public static void main(String[] args)throws Exception
{
String s = "联通";//这两个字出现GDK编码和UTF-8编码重复的现象 byte[] by = s.getBytes("gbk"); for(byte b: by)
{
System.out.println(Integer.toBinaryString(b&255));
}
}
}
/*
11000001
10101010
11001101
10101000
以上复合UTF-8的编码
*/
import java.io.*;
import java.util.*;
class Student implements Comparable<Student>
{
private String name;
private int math;
private int English;
private int Chinese;
private int ScoreSum;
Student(String name,int math,int English,int Chinese)
{
this.name = name;
this.math = math;
this.English = English;
this.Chinese = Chinese;
ScoreSum = math+English+Chinese;
}
public String getname()
{
return name;
}
public int getScoreSum()
{
return ScoreSum;
}
public int hashCode()
{
return name.hashCode()+ScoreSum*78;
}
public boolean equals(Object obj)
{
if(!(obj instanceof Student))
throw new RuntimeException("不是学生对象!");
Student s = (Student)obj;
return this.name.equals(s.name) && this.ScoreSum==s.ScoreSum;
}
public int compareTo(Student s)
{
int num = new Integer(this.ScoreSum).compareTo(new Integer(s.ScoreSum));
return num==0? this.name.compareTo(s.name):num;
}
public String toString()
{
return "Student["+name+","+math+","+English+","+Chinese+"]";
}
}
class StudentInfoTool
{
public static Set<Student> getStudent()throws IOException
{
BufferedReader bufr = new BufferedReader(new InputStreamReader(System.in));
Set<Student> stus = new TreeSet<Student>(new Mycomparator());//也可以采用逆转比较器的方法 String line = null;
while((line = bufr.readLine())!=null)
{
if("over".equals(line))
break;
String[] info = line.split(",");
Student stu = new Student(info[0],Integer.parseInt(info[1]),Integer.parseInt(info[2]),Integer.parseInt(info[3]));
stus.add(stu);
}
bufr.close();
return stus;
}
public static void WriteInfo(Set<Student> stus)throws IOException
{
BufferedWriter bufw = new BufferedWriter(new FileWriter("stud.txt"));
//BufferedWriter bufw = new BufferedWriter(new OutputStreamWriter(System.out)); for(Student stu:stus)
{
bufw.write(stu.toString()+"\t");
bufw.write(stu.getScoreSum()+"");
bufw.newLine();
bufw.flush();
}
bufw.close();
}
}
class StudentFileTest
{
public static void main(String[] args)throws IOException
{
Set<Student> set = StudentInfoTool.getStudent();
StudentInfoTool.WriteInfo(set);
}
}
class Mycomparator implements Comparator<Student>
{
public int compare(Student s1,Student s2)
{
if(s1.getScoreSum()>s2.getScoreSum())
return -1;
if(s1.getScoreSum()<s2.getScoreSum())
return 1;
else
return 0;
}
}
/*
输入数据:
zhangsan,78,89,87
lisi,89,86,78
wangwu,78,56,68
zhaoliu,89,99,100
zhouqi,45,68,97 打印结果:
Student[zhaoliu,89,99,100] 288
Student[zhangsan,78,89,87] 254
Student[lisi,89,86,78] 253
Student[zhouqi,45,68,97] 210
Student[wangwu,78,56,68] 202
*/
Java:编码的详解的更多相关文章
- JAVA IO 类库详解
JAVA IO类库详解 一.InputStream类 1.表示字节输入流的所有类的超类,是一个抽象类. 2.类的方法 方法 参数 功能详述 InputStream 构造方法 available 如果用 ...
- Java :内部类基础详解
可以将一个类的定义放在另一个类的定义内部,这就是内部类. 第一次见面 内部类我们从外面看是非常容易理解的,无非就是在一个类的内部在定义一个类. public class OuterClass { pr ...
- Java web Cookie详解(持久化+原理详解+共享问题+设置中文+发送多个Cookie)
Java web Cookie详解 啥是cookie? 查询有道词典得: web和饼干有啥关系? 这个谜底等等来为大家揭晓 会话技术 web中的会话技术类似于生活中两个人聊天,不过web中的会话指的是 ...
- Java 字符串格式化详解
Java 字符串格式化详解 版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 文中如有纰漏,欢迎大家留言指出. 在 Java 的 String 类中,可以使用 format() 方法 ...
- Java 序列化Serializable详解
Java 序列化Serializable详解(附详细例子) Java 序列化Serializable详解(附详细例子) 1.什么是序列化和反序列化Serialization(序列化)是一种将对象以一连 ...
- Java String类详解
Java String类详解 Java字符串类(java.lang.String)是Java中使用最多的类,也是最为特殊的一个类,很多时候,我们对它既熟悉又陌生. 类结构: public final ...
- 最新java数组的详解
java中HashMap详解 http://alex09.iteye.com/blog/539545 总结: 1.就像引用类型的数组一样,当我们把 Java 对象放入数组之时,并不是真正的把 Java ...
- 转:Java HashMap实现详解
Java HashMap实现详解 转:http://beyond99.blog.51cto.com/1469451/429789 1. HashMap概述: HashMap是基于哈希表的M ...
- 淘宝JAVA中间件Diamond详解(2)-原理介绍
淘宝JAVA中间件Diamond详解(二)---原理介绍 大家好,通过第一篇的快速使用,大家已经对diamond有了一个基本的了解.本次为大家带来的是diamond核心原理的介绍,主要包括server ...
- 【转】 java中HashMap详解
原文网址:http://blog.csdn.net/caihaijiang/article/details/6280251 java中HashMap详解 HashMap 和 HashSet 是 Jav ...
随机推荐
- 标准非STL之bitset
template <size_t N> class bitset; BitsetA bitset stores bits (elements with only two possible ...
- 20145129 《Java程序设计》第5周学习总结
20145129 <Java程序设计>第5周学习总结 教材学习内容总结 语法与继承架构 使用try.catch Java中所有错误都会被打包为对象,可以尝试(try)捕捉(catch)代表 ...
- “我爱淘”冲刺阶段Scrum站立会议8
完成任务: 今天最大的成功就是解决了昨天的问题,可以将xml文件的内容解析出来显示到软件中. 计划任务: 可以通过webservice将数据库中的内容解析出来,通过查询可以得到想要的内容. 遇到问题: ...
- C#预编译指令
近日工作涉及到于外部系统交互,对方提供接口:但是在双方系统未联调时,引用外部DLL,相关类实例化,提示异常错误(错误消息正常):后面操作无法进行,那如何写调试代码,即在调试时不运行某段代码,而在正式发 ...
- char a[] = "hello"; char c[] = {'h','e','l','l','o'}; int b[] = {1, 2, 3, 4, 5};的长度区别,及内存中空间开辟情况
1, char a[] = "hello"; char c[] = {'h','e','l','l','o'}; int b[] = {1, 2, 3, 4, 5}; 数组是开辟一 ...
- HDU 5446 Unknown Treasure Lucas+中国剩余定理
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5446 Unknown Treasure 问题描述 On the way to the next se ...
- BitMap排序
问题描述: BitMap排序思想: 用1bit位标记某个元素对应的值 优点: 效率高,不允许进行比较和移位 ...
- Poj 1029 分类: Translation Mode 2014-04-04 10:18 112人阅读 评论(0) 收藏
False coin Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 16418 Accepted: 4583 Descr ...
- matrix_last_acm_1
password 123 A http://acm.hust.edu.cn/vjudge/contest/view.action?cid=96950#problem/A 题意:n个数初始ai,m次操作 ...
- [错误代码:0x80070002]IIS7及以上伪静态报错404
故障现象:DTCMS开启伪静态功能,VS2010预览正常,发布到IIS后报错404.0错误 (WIN7,WIN8,SERVER2008).模块IISWebCore通知MapRequestHandler ...