Java基础
Java基础
hello world!
JVM JDK JRE
- jvm是运行Java字节码的虚拟机,jvm针对不同系统给出特定实现,目的是使用相同字节码。
- 字节码指的是由java源文件通过jdk.javac编译得到的java.class文件,java.class无须重新编译即可在不同的操作系统中运行。
- class文件到机器码这一步,jvm类加载器首先加载字节码文件,然后通过解释器逐行解析执行,会比较慢。热点代码引入JIT, 属于运行时编译。当 JIT 编译器完成第一次编译后,其会将字节码对应的机器码保存下来,下次可以直接使用
- JDK是JRE的超集,拥有编译器(javac) 和工具(如javadoc和jdb);JRE是运行时环境,只能运行,不能创建新的程序
Java语法
字符串常量和字符型常量
字符常量相当于一个整型值(ASCII值),字符串常量代表一个地址值
*字符常量只占2个字节,字符串常量zhan *
java泛型
java的泛型是伪泛型,因为java在编译期间,所有泛型信息都会被擦除,就是所谓的类型擦除
泛型类,泛型接口,泛型方法
List<Integer> list = new ArrayList<>(); list.add(1); Class<? extends List> aClass = list.getClass(); Method add = aClass.getDeclaredMethod("add", Object.class); add.invoke(list,"k"); for (Integer integer : list) { System.out.println(integer); }
==和equals的区别
因为 Java 只有值传递,所以,对于 == 来说,不管是比较基本数据类型,还是引用数据类型的变量,其本质比较的都是值,只是引用类型变量存的值是对象的地址。
==: 对于对象比较的是两个内存地址是否一致,对于基本类型比较的是值
equals: 判断两个对象是否相等
1.没有重写equals,那么等价于“==”,重写了equals() ,那么比较的是内容是否相等
// a对应地址 String a = new String("a"); // b对应一个地址 String b = new String("b"); // 放入常量池 String aa = "a"; // 从常量池取值 String bb = "a"; // always false System.out.println(a == aa); // true System.out.println(aa == bb); // true System.out.println(a.equals(b));
String的equals()方法是重写过的,比较的是两者的值。
hashCode() / equals()
- hashCode():作用是获取哈希码,实际返回的是一个int整数
- 对于hashSet,加入一个对象到set中,会先计算hashCode值来判断对象加入的位置,,同时也会与其他已经加入的对象的hashCode比较,如果没有相符的hashCode,set会假设对象没有重复出现。但是出现相同的hashCode值的对象,就会调用equals()方法来检查hashCode相等的对象是否真的相等,如果过两者相等,这不会加入操作。这样会大大减少了equals的次数;
- 重写equals 必须重写hashCode ,因为两个对象相等,则hashCode一定相等;两个对象相等,则equals调用,都返回true;两个对象有相同的hashCode,他们也不一定相等,所以equals方法被覆盖过,则hashCode方法也必须被覆盖。
总而言之,hashCode只是缩小了查找的成本
基本类型的自动装箱和拆箱
装箱:将基本类型用他们对应的引用类型包装起来;
拆箱: 将包装类型转化为基本类型