博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java 小结3 hashcode和equals I/o问题
阅读量:5805 次
发布时间:2019-06-18

本文共 2726 字,大约阅读时间需要 9 分钟。

我需要把星期天看的一些东西记录下来,要不然会忘记。

hashCode、equals:

   1)每个java对象都有hashCode和equals方法。

java的终极类是object类,那么object类是如何来标注自己呢,就是object这个类是如何来区分对方。就是使用它们的hashcode和equals来推断。

    (hashcode是通过hash算法实现的)

  2)JVM每new一个object,都会讲Object丢到一个Hash(哈希表)里去,这样下次比较或者获取这个对象的时候就可以根据对象的hashcode去这个表来取,可以提高效率。

我们必须知道java是有内存限制的,所以理论上是不可以无限次new的。

    先比较hashcode,如果这个链表上还有其他数据就用equals。

我们可能会问,那直接使用equals不就得,当然,这是可以的。但是我们要看到hashcode的效率问题,hashcode主要的用途就是减少每次调用equals。

 3)关于重写Hashcode和equals的问题:

   一般情况下,我们是不需要重写这两个函数的。想Integer Double这类的对象,java已经为我们重写了这两个函数,这也是为什么只要两个字符串内容一样他们的equals就是一样的,按道理不应该,因为equals比较的是对象的引用。

    需要重写的情况:就是当我们使用map里面的hashmap这类东西的时候,如果我们用自定义类作为键值就必须重写,否则会找不到类。因为类是继承object的,会使用object的hashcode

所以两个值一样的数据,在这里面就会变成两个数。

就是使用自定义的key,才需要重写。

 

I/O:

   File类:可以是文件,也可以是文件目录。通过File类我们可以获取文件的一定属性。

   流:这个反正就是一系列数据,我也说不清。

java的输入输出:(1)字符输出、输入流(Writer、Reader)(2)字节输出、输入流。 (InputStream、OutPutStream)

 (好像还有stdIO)

区别

     (1)读写单位不同

        字节流以字节(8bit)为单位,字符流以字符为单位,每次读取的字节就要看采用的字符映射了。

   (2)处理对象不同

      字节流可以处理所有类型对象(图片,视频,文本。。。)

      字符流只能是字符类型

 

注意:字节流是无法直接转换为字符输出的,因为读取的单位不同,可以将数组字节转换为string了在输出。。

 

 

package com.hxw.io;      import java.io.File;      import java.io.FileInputStream;      import java.io.IOException;      import java.io.InputStream;      public class FileCount {         /**         * 我们写一个检测文件长度的小程序,别看这个程序挺长的,你忽略try catch块后发现也就那么几行而已。         */         publicstatic void main(String[] args) {            //TODO 自动生成的方法存根                   int count=0;  //统计文件字节长度            InputStreamstreamReader = null;   //文件输入流            try{                streamReader=newFileInputStream(new File("D:/David/Java/java 高级进阶/files/tiger.jpg"));                /*1.new File()里面的文件地址也可以写成D:\\David\\Java\\java 高级进阶\\files\\tiger.jpg,前一个\是用来对后一个                * 进行转换的,FileInputStream是有缓冲区的,所以用完之后必须关闭,否则可能导致内存占满,数据丢失。               */                while(streamReader.read()!=-1) {  //读取文件字节,并递增指针到下一个字节                   count++;                }                System.out.println("---长度是: "+count+" 字节");            }catch (final IOException e) {                //TODO 自动生成的 catch 块                e.printStackTrace();            }finally{                try{                   streamReader.close();                }catch (IOException e) {                   //TODO 自动生成的 catch 块                   e.printStackTrace();                }            }         }             }

        上面程序每读取一个自己我都要去用到FileInputStream,我输出的结果是“---长度是: 64982 字节”,那么进行了64982次操作!可能想象如果文件十分庞大,这样的操作肯定会出大问题,所以引出了缓冲区的概念。可以将 streamReader.read()改成streamReader.read(byte[]b)此方法读取的字节数目等于字节数组的长度,读取的数据 被存储在字节数组中,返回读取的字节数 。

       Java I/O默认是不缓冲流的,所谓“缓冲”就是先把从流中得到的一块字节序列暂存在一个被称为buffer的内部字节数组里,然后你可以一下子取到这一整块的 字节数据,没有缓冲的流只能一个字节一个字节读,效率孰高孰低一目了然。有两个特殊的输入流实现了缓冲功能,一个是我们常用的 BufferedInputStream.

 

转载于:https://www.cnblogs.com/GuoJiaSheng/p/3905752.html

你可能感兴趣的文章
[分享]Ubuntu12.04安装基础教程(图文)
查看>>
[Vim] 搜索模式(正则表达式)
查看>>
#HTTP协议学习# (二)基本认证
查看>>
Android开发之线性布局详解(布局权重)
查看>>
WCF
查看>>
django 目录结构修改
查看>>
win8 关闭防火墙
查看>>
Android实例-录音与回放(播放MP3)(XE8+小米2)
查看>>
CSS——(2)与标准流盒模型
查看>>
MYSQL 基本SQL语句
查看>>
C#中的Marshal
查看>>
linux命令:ls
查看>>
Using RequireJS in AngularJS Applications
查看>>
hdu 2444(二分图最大匹配)
查看>>
shell编程笔记六:实现ll命令
查看>>
【SAP HANA】关于SAP HANA中带层次结构的计算视图Cacultation View创建、激活状况下在系统中生成对象的研究...
查看>>
[nodejs] nodejs开发个人博客(五)分配数据
查看>>
《Linux内核修炼之道》 之 高效学习Linux内核
查看>>
Java数据持久层框架 MyBatis之API学习九(SQL语句构建器详解)
查看>>
30分钟Git命令“从入门到放弃”
查看>>