Java的一些细节语法(不定时更新。。。)
可信考试Java相关题目
ConcurrentHashMap不允许key为null,但是HashMap是可以的。TreeMapkey不支持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来进行对应的适配。关于Java里面的
<? extends Obj>协变和<? super Obj>逆变的详细解释:static class Parent{
} static class FirstChild extends Parent{
} static class SecondChild extends Parent{ } static class FirstGrandChild extends FirstChild{ } static class FirstGrand2Child extends FirstChild{
} static class SecondGrandChild extends SecondChild{ } static class SecondGrand2Child extends SecondChild{ } public static void main(String[] args) {
//指定了上界
List<? extends FirstChild> parentList = new ArrayList<>();
List<FirstChild> firstChildList = new ArrayList<>();
firstChildList.add(new FirstGrandChild());
firstChildList.add(new FirstGrandChild());
//Parent没有继承FirstChild
// parentList = new ArrayList<Parent>();
//这个是可以的,因为parentList表示该list存储了Parent或者其子类
parentList = firstChildList;
//下面这个是不可以的,因为该list存储了Parent或者其子类,那么尝试添加FirstChild就会出错,因为继承了Parent的不仅有FirstChild还有SecondChild。
// 上面把List<FirstChild>赋值给List<? extends Parent>后,如果添加可以成功的话,那么根据Java泛型实现的方式,就可以添加SecondChild及其子类,
// 这明显是违背Java的语法规则的,所以这种情况下只能添加null。这称之为协变
// parentList.add(new FirstChild()); //但是get是可以的,因为指定了上界,所以可以确定成员一定可以转换为FirstChild
FirstChild c = parentList.get(0); //指定了下界
List<? super SecondChild> secondList = new ArrayList<>();
List<Parent> pList = new ArrayList<>();
secondList = pList; //不是SecondChild的父类
// secondGrandList = new ArrayList<SecondGrand2Child>(); //但是不同于协变,add是可以的,因为可以确定的是,secondList里面成员,一定可以转换成SecondChild或者其父类,
// 所以这里的add操作是可以的,这叫做逆变。比如说下面的SecondGrandChild和SecondGrand2Child都是可以转换成SecondChild或者其父类的
secondList.add(new SecondGrandChild());
secondList.add(new SecondGrand2Child()); //相反的,get操作只能返回Object,因为SecondChild的父类不确定,因此无法确定一个具体的类型,但是Object又是所有类的父类,
//因此,get返回的只能是Object对象
Object o = secondList.get(0);
//这个操作是不可以的
// SecondChild child = secondList.get(0); }
Java的一些细节语法(不定时更新。。。)的更多相关文章
- Java专业技能面试问题(不定时更新)
刚看到园友五月的仓颉<面试感悟----一名3年工作经验的程序员应该具备的技能>感觉很不错,不论是为面试跳槽准备,还是打算深化精进自己的技术都可以参考一下.面向工资编程多少也有点道理,虽然技 ...
- Java日志组件logback使用:加载非类路径下的配置文件并设置定时更新
Java日志组件logback使用:加载非类路径下的配置文件并设置定时更新 摘自: https://blog.csdn.net/johnson_moon/article/details/7887449 ...
- Java应用集群下的定时任务处理方案(mysql)
Java应用集群下的定时任务处理方案(mysql) 因为自己有csdn和博客园两个博客, 所以两边都会发一下. csdn地址: http://blog.csdn.net/u012881584/ar ...
- java与c#的语法对比
1,命名空间与包 C#为了把实现相似功能的类组织在一起,引入了命名空间的概念(namespace) Java中与此对应的东西叫做包(package) 2,类的访问控制方面的不同 C#只有两种:publ ...
- [Android Traffic] 调整定时更新的频率(C2DM与退避算法)
转载自: http://blog.csdn.net/kesenhoo/article/details/7395253 Minimizing the Effect of Regular Updates[ ...
- Oracle Sales Cloud:管理沙盒(定制化)小细节2——使用对象触发器更新数字字段
在上一篇 "管理沙盒(定制化)小细节1" 的随笔中,我们使用公式法在 "业务机会" 对象(单头)上建立了 "利润合计" 字段,并将它等于 & ...
- iOS 属性修饰符记录 --不定时更新
重新审视了一下OC在属性修饰符,特意记录一下来.以后不定时更新 > retain:只有在非ARC下才会有效,所有如果在ARC下使用了retain修饰也白搭 如以下的data属性用retain修饰 ...
- Eclipse中java向数据库中添加数据,更新数据,删除数据
前面详细写过如何连接数据库的具体操作,下面介绍向数据库中添加数据. 注意事项:如果参考下面代码,需要 改包名,数据库名,数据库账号,密码,和数据表(数据表里面的信息) package com.ning ...
- linux下svn定时更新项目
方法一.用shell脚本定时更新项目 1.进入网站的根目录,假设项目位置放在/var/www/test cd /var/www/test 2.建立脚本文件update.sh,分两步进行.首先利 ...
随机推荐
- algorithm库介绍之---- stable_sort()方法 与 sort()方法 .
文章转载自:http://www.cnblogs.com/ffhajbq/archive/2012/07/24/2607476.html 关于stable_sort()和sort()的区别: 你发现有 ...
- 重新整理 .net core 实践篇————依赖注入应用[二]
前言 这里介绍一下.net core的依赖注入框架,其中其代码原理在我的另一个整理<<重新整理 1400篇>>中已经写了,故而专门整理应用这一块. 以下只是个人整理,如有问题, ...
- Docker------Idea连接远程并生成和上传镜像
1.Docker开启远程访问连接 备注: 1)Linux是CentOS7版本 2)安装Docker可参考: https://www.cnblogs.com/tianhengblogs/p/125202 ...
- 云计算OpenStack---创建实例(11)
创建实例时,需要先创建网络及实例类型等其它配置: 一.创建虚拟网络(Self-service network) 网络概述图: 网络连接图: 1.创建self-service网络 (1)加载系统变量: ...
- getaddrinfo()函数详解-(转自 cxz2009)
1. 概述IPv4中使用gethostbyname()函数完成主机名到地址解析,这个函数仅仅支持IPv4,且不允许调用者指定所需地址类型的任何信息,返回的结构只包含了用于存储IPv4地址的空间.IPv ...
- Module not found: Error: Can't resolve 'less-loader' in ' xxx' (Day_40)
1. 错误代码: 2. 解决方法: 删除项目文件夹下的node_modules文件夹 执行npm install命令
- 深入剖析 MySQL 自增锁
之前的文章把 InnoDB 中的所有的锁都介绍了一下,包括意向锁.记录锁...自增锁巴拉巴拉的.但是后面我自己回过头去看的时候发现,对自增锁的介绍居然才短短的一段. 其实自增锁(AUTO-INC Lo ...
- ThreadLocal与ThreadLocalMap源码分析
ThreadLocal类 该类主要用于不同线程存储自己的线程本地变量.本文先通过一个示例简单介绍该类的使用方法,然后从ThreadLocal类的初始化.存储结构.增删数据和hash值计算等几个方面,分 ...
- GPU特征处理技术
GPU特征处理技术 GPU和CPU有何不同? 现代片上系统(SoC)通常集成中央处理器(CPU)和图形处理器(GPU).设计不同,这可能更取决于处理的数据集的类型. CPU经过优化,可以一次对几块数据 ...
- Darknet_Yolov3模型搭建
Darknet_Yolov3模型搭建 YOLO(You only look once)是目前流行的目标检测模型之一,目前最新已经发展到V3版本了,在业界的应用也很广泛.YOLO的特点就是"快 ...