Java基础拾遗(二)
(尊重劳动成果,转载请注明出处:http://blog.csdn.net/qq_25827845/article/details/76358523冷血之心的博客)
马上就要秋招了,新的一轮笔试面试马上就要开始轰炸了,在这关键的节骨眼上,要做到查缺补漏,夯实基础,特此总结~
友情链接:
- Java集合相关知识
- HashMap和Hashtable的区别
- HashMap没有考虑同步,是线程不安全的;Hashtable使用了synchronized关键字,是线程安全的;
- 前者允许null作为Key;后者不允许null作为Key
- HashMap如何处理hash冲突?
- 拉链法
- 线性探测再散列法
- 二次探测再散列法
- 伪随机探测再散列法
- HashMap的长度为什么是2的幂次方?
- 通过将Key的hash值与length-1进行&运算,实现了当前Key的定位,2的幂次方可以减少冲突(碰撞)的次数,提高HashMap查询效率
- 如果length为2的次幂 则length-1 转化为二进制必定是11111……的形式,在于h的二进制与操作效率会非常的快,而且空间不浪费;如果length不是2的次幂,比如length为15,则length-1为14,对应的二进制为1110,在于h与操作,最后一位都为0,而0001,0011,0101,1001,1011,0111,1101这几个位置永远都不能存放元素了,空间浪费相当大,更糟的是这种情况中,数组可以使用的位置比数组长度小了很多,这意味着进一步增加了碰撞的几率,减慢了查询的效率!这样就会造成空间的浪费。
- ConcurrentHashMap和HashTable的区别?
- ConcurrentHashMap结合了HashMap和HashTable二者的优势。HashMap没有考虑同步,hashtable考虑了同步的问题。但是hashtable在每次同步执行时都要锁住整个结构。 ConcurrentHashMap锁的方式是稍微细粒度的。 ConcurrentHashMap将hash表分为16个桶(默认值),诸如get,put,remove等常用操作只锁当前需要用到的桶。
- ConcurrentHashMap的具体实现方式:
- 该类包含两个静态内部类HashEntry和Segment;
- 前者用来封装映射表的键值对,后者用来充当锁的角色;
- Segment是一种可重入的锁ReentrantLock,每个Segment守护一个HashEntry数组里得元素,当对HashEntry数组的数据进行修改时,必须首先获得对应的Segment锁。
- 常用集合的初始容量和加载因子
- List
- ArrayList的初始容量是10;加载因子为0.5; 扩容增量:原容量的 0.5倍+1;一次扩容后长度为16
- Vector初始容量为10,加载因子是1。扩容增量:原容量的 1倍,如 Vector的容量为10,一次扩容后是容量为20
- Set
- HashSet,初始容量为16,加载因子为0.75; 扩容增量:原容量的 1 倍; 如 HashSet的容量为16,一次扩容后容量为32
- Map
- HashMap,初始容量16,加载因子为0.75; 扩容增量:原容量的 1 倍; 如 HashMap的容量为16,一次扩容后容量为32
- HashMap扩容是指链表中的元素个数超过了16*0.75=12之后开始扩容
- List
- List和Set的区别:
- List元素是有序的,可以重复
- Set元素是无序的,不可以重复
- 集合分类:
- Map接口和Collection接口是所有集合框架的父接口;
- Collection接口的子接口包括:Set接口和List接口;
- Map接口的实现类主要有:HashMap、TreeMap、Hashtable、ConcurrentHashMap以及Properties等
- Set接口的实现类主要有:HashSet、TreeSet、LinkedHashSet等
- List接口的实现类主要有:ArrayList、LinkedList、Stack以及Vector等
- Map接口和Collection接口是所有集合框架的父接口;
- Set接口
- HashSet
- 通过元素的hashCode和equals方法保证元素的唯一性
- 添加的元素,必须实现了这两个方法,缺一不可
- TreeSet
- 让元素自身具备比较性
- 让元素实现Comparable接口,覆盖compareTo方法。
- 让集合自身具备比较性
- 自定义一个比较器类,实现Comparator接口,覆盖compare方法,建立集合对象时,将比较器传入。
- Comparable接口和Comparator接口的比较
- 前者简单,但是如果需要重新定义比较类型时,需要修改源代码。
- 后者不需要修改源代码,自定义一个比较器,实现自定义的比较方法。
- 让元素自身具备比较性
- HashSet
- Iterator和ListIterator的区别是什么?
- 前者可以遍历list和set集合;后者只能用来遍历list集合
- 前者只能前向遍历集合;后者可以前向和后向遍历集合
- 后者实现了前者,增加了一些新的功能。
- Java集合的快速失败机制“fail-fast”
- 是java集合的一种错误检测机制,当多个线程对集合进行结构上的改变的操作时,有可能会产生fail-fast机制。
- 例如:假设存在两个线程(线程1、线程2),线程1通过Iterator在遍历集合A中的元素,在某个时候线程2修改了集合A的结构(是结构上面的修改,而不是简单的修改集合元素的内容),那么这个时候程序就会抛出 ConcurrentModificationException 异常,从而产生fail-fast机制。
- 迭代器在遍历时直接访问集合中的内容,并且在遍历过程中使用一个 modCount 变量。集合在被遍历期间如果内容发生变化,就会改变modCount的值。每当迭代器使用hashNext()/next()遍历下一个元素之前,都会检测modCount变量是否为expectedmodCount值,是的话就返回遍历;否则抛出异常,终止遍历。
- 解决办法:
- 在遍历过程中,所有涉及到改变modCount值得地方全部加上synchronized。
- 使用CopyOnWriteArrayList来替换ArrayList
- 通过底层拷贝数组,在拷贝的数组上进行操作
- 修改完成之后,改变原有数据
- 是java集合的一种错误检测机制,当多个线程对集合进行结构上的改变的操作时,有可能会产生fail-fast机制。
- Java集合的安全失败机制“fail-safe”
- 采用安全失败机制的集合容器,在遍历时不是直接在集合内容上进行访问,而是先复制原有集合内容,在拷贝的集合上进行遍历
- java.util.concurrent包下的容器都是安全失败的,可以在多线程下并发使用,并发修改。
- HashMap和Hashtable的区别
- Java基础知识点
- JDK8有哪些新特性?
- Lambda表达式和函数式接口:
- Lambda表达式(也称为闭包),允许我们将函数当成参数传递给某个方法,或者把代码本身当做数据处理;
- 函数式接口:指的是只有一个函数的接口,java.lang.Runnable和java.util.concurrent.Callable就是函数式接口的例子;java8提供了一个特殊的注解@Functionallnterface来标明该接口是一个函数式接口
- 引入重复注解: Java 8中使用@Repeatable注解定义重复注解
- 更好的类型判断:Value.defaultValue( )
- 注解的使用场景拓宽
- 加入了新的包java.time包,包含了所有关于日期、时间、时区、持续时间和时钟操作的类
- Lambda表达式和函数式接口:
- 面向对象的含义
- 面向对象是一种思想,可以将复杂问题简单化。让我们从执行者变为了指挥者。使用封装、继承、多态来实现程序设计。
- 封装
- 继承
- 多态:指一个程序中同名的多个不同方法共存的情况
- 通过子类对父类方法的覆盖实现
- 通过同一个类中方法的重载实现(重载包括参数个数不同、参数类型不同和参数顺序不同三种情况)
- 通过将子类的对象作为父类的对象实现
- Java序列化和反序列化:
- 序列化:把对象转换为字节序列的过程
- 反序列化:把字节序列恢复为对象的过程
- 对象序列化包括如下步骤:
- 创建一个对象输出流,它可以包装一个其他类型的目标输出流,如文件输出流
- 通过对象输出流的writeObject()方法写对象
- 对象反序列化的步骤如下:
- 创建一个对象输入流,它可以包装一个其他类型的源输入流,如文件输入流
- 通过对象输入流的readObject()方法读取对象
- Java反射机制
- 反射机制:在运行中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性。即动态获取信息和动态调用对象方法的功能称为反射机制。
- 反射机制的作用
- 在运行时判断任意一个对象所属的类
- 在运行时构造一个类的对象
- 在运行时判断任意一个类所具有的成员变量和方法
- 在运行时调用任意一个对象的方法,生成动态代理
- 与反射相关的类;
- Class:表示类
- Field:表示成员变量
- Method:表示方法
- Constructor:表示构造器
- 抽象类和接口的区别:
- 抽象类中可以没有抽象方法;接口中的方法必须是抽象方法;
- 抽象类中可以有普通的成员变量;接口中的变量必须是static final类型的,必须被初始化,接口中只有常量,没有变量!!!
- 抽象类只能单继承,接口可以继承多个父接口;
- 特殊运算符
- ~X表示的意思是:加1取反。 ~3=-4 ~-2=1
- 移位运算符:<<和>>和>>>
- 字节流和字符流的区别:
- 字节流处理单元为1个字节,操作字节和字节数组
- 字符流处理单元为2个字节,操作字符、字符串或字符数组
- 字节流用来处理二进制数据,因为要处理很多文本数据,所以提出了字符流
- 字节流在操作的时候本身是不会用到缓冲区(内存)的,是与文件本身直接操作的,而字符流在操作的时候是使用到缓冲区的
- 字节流在操作文件时,即使不关闭资源(close方法),文件也能输出,但是如果字符流不使用close方法的话,则不会输出任何内容,说明字符流用的是缓冲区,并且可以使用flush方法强制进行刷新缓冲区,这时才能在不close的情况下输出内容
- 正则表达式
- 四大方法:
- 匹配:String matches(regex)用规则来匹配整个字符串
- 切割:String split(regex)
- 替换:String replaceAll(regex,str)
- 获取:
- 将正则表达式封装成对象 Pattern p = Pattern.compile(regex)
- 让正则对象和要操作的字符串相关联 Matcher m = p.matcher(String)
- 关联后,获取正则匹配引擎 while(m.find()){System.out.println(m.group( ));}
- 通过引擎对符合规则的子串进行取出操作
[abc] a、b 或 c(简单类) [^abc] 任何字符,除了 a、b 或 c(否定) [a-zA-Z] a 到 z 或 A 到 Z,两头的字母包括在内(范围) [a-d[m-p]] a 到 d 或 m 到 p:[a-dm-p](并集) [a-z&&[def]] d、e 或 f(交集) [a-z&&[^bc]] a 到 z,除了 b 和 c:[ad-z](减去) [a-z&&[^m-p]] a 到 z,而非 m 到 p:[a-lq-z](减去) . 任何字符(与行结束符可能匹配也可能不匹配) \d 数字:[0-9] \D 非数字: [^0-9] \s 空白字符:[ \t\n\x0B\f\r] \S 非空白字符:[^\s] \w 单词字符:[a-zA-Z_0-9] \W 非单词字符:[^\w] X+ X,一次或多次 X{n} X,恰好 n 次 X{n,} X,至少 n 次 X{n,m} X,至少 n 次,但是不超过 m 次
- 四大方法:
- 基本数据类型分别占多少字节
- 不使用新变量,交换两个变量的值,比如有两个变量a和b。
- 基于加减法:
- a = a+b ;
- b = a-b ;
- a = a-b ;
- 基于异或运算:
- a = a^b ;
- b = a^b ;
- a = a^b ;
- 基于加减法:
- Java类加载机制:
- 定义:
- 类加载指将类的.class文件中的二进制数据读入到内存中,将其放在运行时数据区的方法区内,然后在堆区创建一个java.lang.Class对象,用来封装类在方法区内的数据结构。
- 类的生命周期:
- 加载--验证--准备--解析--初始化--使用--卸载
- 加载:
- 查找并加载类的二进制数据
- 验证:
- 确保被加载的类的正确性
- 文件格式验证
- 元数据 验证
- 字节码验证
- 符号引用验证
- 确保被加载的类的正确性
- 准备:
- 为类的静态变量分配内存,并将其初始化为默认值
- 假设一个类变量的定义为public static int val = 3;,那么变量val在准备阶段过后的初始值不是3而是0。
- 解析:
- 把类中符号引用转换为直接引用
- 初始化:
- 为类的静态变量赋予正确的初始值,JVM负责对类进行初始化,主要对类变量进行初始化。
- 类加载器:
- 启动类加载器Bootstrap ClassLoader
- 扩展类加载器ExtClassloader
- 应用类加载器AppClassLoader
- 自定义加载器
- 类加载器的职责:
- 全盘负责
- 父类委托
- 缓存机制
- 父类委托机制:(双亲委派模型)
- 如果一个类加载器收到了类加载的请求,它首先不会自己去尝试加载这个类,而是把请求委托给父加载器去完成,依次向上,因此,所有的类加载请求最终都应该被传递到顶层的启动类加载器中,只有当父加载器在它的搜索范围中没有找到所需的类时,即无法完成该加载,子加载器才会尝试自己去加载该类。
- 意义:
- 系统类防止内存中出现多份同样的字节码
- 保证java程序安全稳定运行
- Java中类的加载有三种方法:
- 命令行启动应用时候由JVM初始化加载
- 通过Class.forName( )方法动态加载
- 通过ClassLoader.loadClass( )方法动态加载
- 定义:
- JDK8有哪些新特性?
如果对你有帮助,记得点赞哦~欢迎大家关注我的博客,可以进群366533258一起交流学习哦~
本群给大家提供一个学习交流的平台,内设菜鸟Java管理员一枚、精通算法的金牌讲师一枚、Android管理员一枚、蓝牙BlueTooth管理员一枚、Web前端管理一枚以及C#管理一枚。欢迎大家进来交流技术。
Java基础拾遗(二)的更多相关文章
- Java基础拾遗(二) — 关于equals(),hashcode()和 ==
这里分别讲==和equals()的关系,以及equals()和hashcode()的关系 讲解之前,需要先明白对象的内容.对象的引用,基本类型,引用类型这几个概念,此处不做解释 一.==和equals ...
- Java基础拾遗(一)
(尊重劳动成果,转载请注明出处:http://blog.csdn.net/qq_25827845/article/details/76358391冷血之心的博客) 马上就要秋招了,新的一轮笔试面试马上 ...
- java 基础知识二 基本类型与运算符
java 基础知识二 基本类型与运算符 1.标识符 定义:为类.方法.变量起的名称 由大小写字母.数字.下划线(_)和美元符号($)组成,同时不能以数字开头 2.关键字 java语言保留特殊含义或者 ...
- java基础(二章)
java基础(二章) 一,变量 1.变量是内存中的一个标识符号,用于存储数据 2.变量命名规则 l 必须以字母.下划线 _ .美元符号 $ 开头 l 变量中,可以包括数字 l 变量中,不能出现特 ...
- Java基础十二--多态是成员的特点
Java基础十二--多态是成员的特点 一.特点 1,成员变量. 编译和运行都参考等号的左边. 覆盖只发生在函数上,和变量没关系. Fu f = new Zi();System.out.println( ...
- java基础-多线程二
java基础-多线程二 继承thread和实现Runnable的多线程每次都需要经历创建和销毁的过程,频繁的创建和销毁大大影响效率,线程池的诞生就可以很好的解决这一个问题,线程池可以充分的利用线程进行 ...
- JAVA基础(二)—— 常用的类与方法
JAVA基础(二)-- 常用的类与方法 1 Math类 abs ceil floor 绝对值 大于等于该浮点数的最小整数 小于等于该浮点数的最大整数 max min round 两参数中较大的 两参数 ...
- Java实习生常规技术面试题每日十题Java基础(二)
目录 1. JAVA 的反射机制的原理. 2.静态嵌套类(Static Nested Class)和内部类(Inner Class)的不同? 3.如何将String类型转化成Number类型. 4.什 ...
- Java基础系列二:Java泛型
该系列博文会告诉你如何从入门到进阶,一步步地学习Java基础知识,并上手进行实战,接着了解每个Java知识点背后的实现原理,更完整地了解整个Java技术体系,形成自己的知识框架. 一.泛型概述 1.定 ...
随机推荐
- VisualStudio下如何编译和使用最新版本的OpenCV(修正版)
OpenCV是托管于GitHub的开源项目,本文具体解决一个问题,就是“获取最新版本的OpenCV,并且在自己的项目中使用起来" 最新版本 2017年3月31日 BY:jsxyhelu ...
- 20145312 《Java程序设计》第10周学习总结
20145312 <Java程序设计>第10周学习总结 学习总结 一. 什么是网络编程 网络编程就是在两个或两个以上的设备(例如计算机)之间传输数据.程序员所作的事情就是把数据发送到指定的 ...
- 20145314郑凯杰 《Java程序设计》课程总结
20145314郑凯杰 <Java程序设计>课程总结 每周读书笔记链接汇总 ①寒假预习--"helloworld" ②第一周读书笔记 ③第二周读书笔记 ④第三周读书笔记 ...
- 20145327 《Java程序设计》第十周学习总结
20145327 <Java程序设计>第十周学习总结 教材学习内容总结 网络编程就是运行在不同计算机中两个程序之间的数据交换. 网络中的每个设备都会有一个唯一的数字标识,这个就是IP地址. ...
- DCU项目总结
1.什么是DCU 在某些基站无法覆盖的地方,如大型体育馆内部1楼.2楼..,此时通过DCU为这些地方提供信号 2.DCU组成 3.我们需要做的 PC通过进入UMPT网关,在一个网页中使用自定义指令集控 ...
- vscode调试pomelo和pomelo使用vscode调试
使用vscode 通过端口remote attach进行调试 pomelo. 0. 网上好多调试pomelo的都是webstorm.或者vscode调试node的教程.但没找到vscode调试pome ...
- UVa 11549 计算器谜题(Floyd判圈算法)
https://vjudge.net/problem/UVA-11549 题意: 有一个老式计算器,只能显示n位数字,输入一个整数k,然后反复平方,如果溢出的话,计算器会显示结果的最高n位.如果一直这 ...
- [eclipse]Syntax error on tokens, delete these tokens问题解决
错误:Syntax error on tokens, delete these tokens 出现这样的错误一般是括号.中英文字符.中英文标点.代码前面的空格,尤其是复制粘贴的代码,去掉即可. 如下图 ...
- 搭建selenium + Python环境的总结:
安装Python+Selenium 写博客是一个不错的选择,首先,是担心自己忘掉,其次,可以供大家做一个参考: 其实,这是自己第一次搭建Python环境(之前用了一周的Idle),还是比较容易的吧: ...
- LR----实现WebService测试
测试WebService时,需要导入WSDL:同SoapUI WSDL:http://ws.webxml.com.cn/webservices/DomesticAirline.asmx?wsdl 场景 ...