目录
-
ConcurrentHashMap
不允许key为null,但是HashMap
是可以的。TreeMap
key不支持null。 -
以下代码里面,请注意:
Integer a = 150; Integer b = 150; Integer c = 100; Integer d = 100; Integer e = new Integer(100); System.out.println(a == b); //false System.out.println(a == 150); //true 这种是真正的在对比值的大小 System.out.println(c == d); //true System.out.println(c == e); //false
-
Process
类有输出流,输入流,错误流。 -
关于nio里面
Buffer
的duplicate
方法:ByteBuffer buf = ByteBuffer.allocate(100); /** * duplicate函数的官方注释,并不是真正的复制。 * Creates a new byte buffer that shares this buffer's content. * * <p> The content of the new buffer will be that of this buffer. Changes * to this buffer's content will be visible in the new buffer, and vice * versa; the two buffers' position, limit, and mark values will be * independent. * */ ByteBuffer buf2 = buf.duplicate();
-
Java Stream
的数据源有容器,数组和I/O,Stream的中间操作(intermediate function)
并不会直接执行,只有遇到终端操作(terminal function)
才会开始执行。 -
在Java里面,
count = count++
,会导致count++没有效果,这个从字节码层面是可以解释的。0: iconst_0 1: istore_1 // 将0存入到参数1的位置 2: iload_1 //将参数1的位置,也就是0,读取到操作数栈 3: iinc 1, 1 //给参数1的位置的参数直接+1 6: istore_1 //将操作数栈顶,也就是0,存储在参数1的位置 7: getstatic #2 // Field java/lang/System.out:Ljava/io/PrintStream; 10: iload_1 //将参数1的位置,也就是0,读取到操作数栈 11: invokevirtual #3 // Method java/io/PrintStream.println:(I)V 14: return
相对的,
count = ++count
的字节码如下:0: iconst_0 1: istore_1 // 将0存入到参数1的位置 2: iinc 1, 1 // 将参数1的位置,也就是0,直接+1, 5: iload_1 // 读取参数1的位置,也就是1,放在操作数栈 6: istore_1 // 将操作数栈顶的值,也就是1,存储在参数1的位置 7: getstatic #2 // Field java/lang/System.out:Ljava/io/PrintStream; 10: iload_1 // 将参数1的位置,也就是1,读取到操作数1栈 11: invokevirtual #3 // Method java/io/PrintStream.println:(I)V 14: return
注意观察两段代码
iinc
前后的区别。 -
Java的栈帧包括:局部变量表,操作数,动态链接,方法返回地址(注意,不包含本地方法栈)
-
通过
DataSource
对象访问的驱动程序本身不会向DriverManager
注册,且其对象属性是可以进行更改的,如果服务器配置发生了变化,可以通过更新DataSource
来进行对应的适配。