A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 丁林 金牌黑马   /  2011-10-1 12:48  /  2183 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

import java.io.*;
public class TestFileWriter {
  public static void main(String[] args) {
    FileWriter fw = null;
    try {
      fw = new FileWriter("d:\\bak\\unicode.txt");
      for(int c=0;c<=50000;c++){
        fw.write(c);
      }
      fw.close();
    } catch (IOException e1) {
            e1.printStackTrace();
      System.out.println("文件写入错误");
      System.exit(-1);
    }
  }
这个程序写出的是整数。为什么在生成的文件里是unicode编码的一部分,程序写出的是十进制的数字啊?
程序写出的是十进制这个整型的二进制码,对吗?二进制码写出到unicode.txt文件中,打开文件在自己电脑上显示的即为unicode码所表示的字符。不知是不是这样?
计算机是怎么读取显示数据的? 想补计算机这方面的知识应该看些什么内容?不胜感激!

评分

参与人数 1技术分 +1 收起 理由
wangfayin + 1

查看全部评分

1 个回复

倒序浏览
黑马网友  发表于 2011-10-1 13:45:19
沙发
计算机本身只认识0和1这两个数字,0表示关,1表示开。计算机读取数据是按照字节读取的,字节我们是看不懂的,所以为了让我们能够看懂这些字节,于是就把字节和编码表融入在一起,这就形成了字符,字符我们就可以看懂了,例如“a"这就是一个字符,a的二进制字节是1100001,这个字节你是看不懂的,但转成了字符”a"你就可以看懂了。

评分

参与人数 1技术分 +1 收起 理由
wangfayin + 1

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马