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,分两步进行.首先利 ...
随机推荐
- (四)Jira Api对接:缺陷分析和任务分析
迭代进行期间或者结束后,在我们的测试日报或者测试报告中需要体现缺陷详细情况,甚至大家工作效率情况.本文就讨论下如何通过jira api获取缺陷信息并进行分析,同时获取需求子任务情况来了解测试和开发的工 ...
- OO第1.2次作业·魔鬼的三角函数化简
多年以后,面对办公室的屏幕,我会回忆起开始肝第二周OO作业的那个遥远的下午.那时的程序是一个一两百行的符号求导,基类与接口在包里一字排开,工整的注释一望到底 谁能想到,接下来的十几个小时我要经历什么样 ...
- Redis数据持久化—RDB持久化与AOF持久化
目录 Redis数据持久化-RDB持久化与AOF持久化 RDB持久化 RDB文件的创建 RDB文件的载入 自动间隔性保存 检查保存条件是否满足 AOF持久化 AOF持久化的实现 AOF文件的载入与数据 ...
- redis分布式锁-可重入锁
redis分布式锁-可重入锁 上篇redis实现的分布式锁,有一个问题,它不可重入. 所谓不可重入锁,即若当前线程执行某个方法已经获取了该锁,那么在方法中尝试再次获取锁时,就会获取不到被阻塞. 同一个 ...
- 003.Ansible配置文件管理
一 配置文件的优先级 ansible的配置文件名为ansible.cfg,它一般会存在于四个地方: ANSIBLE_CONFIG:首先,Ansible命令会检查该环境变量,及这个环境变量将指向的配置文 ...
- 019.Python函数sorted,filter和推导式
一 sorted函数 sorted(iterable,reverse=False,key=函数) 功能:排序 参数: iterable:可迭代性数据(常用:容器类型数据,range对象,迭代器) re ...
- 10.14 ssh:安全地远程登录主机
ssh命令 是openssh套件中的客户端连接工具,可以使用ssh加密协议实现安全的远程登录服务器,实现对服务器的远程管理,Windows中的替代工具为Xshell.putty.SecureCRT等. ...
- opencv——PCA(主要成分分析)数学原理推导
引言: 最近一直在学习主成分分析(PCA),所以想把最近学的一点知识整理一下,如果有不对的还请大家帮忙指正,共同学习. 首先我们知道当数据维度太大时,我们通常需要进行降维处理,降维处理的方式有很多种, ...
- Java基础之第二章变量
1. 变量介绍 变量是程序的基本组成单位 概念 变量相当于内存中一个数据存储空间的表示,可以通过变量名可以访问到变量(值). 变量使用 声明变量 int a; 赋值 a = 20; public cl ...
- 阿里云服务器安装Docker并部署nginx、jdk、redis、mysql
阿里云服务器安装Docker并部署nginx.jdk.redis.mysql 一.安装Docker 1.安装Docker的依赖库 yum install -y yum-utils device-map ...