新書推薦:
《
世界航空地理(世界国别与区域地理研究丛书)
》
售價:HK$
244.2
《
学术的中心:英法德美
》
售價:HK$
87.4
《
为什么要读人类学
》
售價:HK$
77.3
《
井邑无衣冠 : 地方视野下的唐代精英与社会
》
售價:HK$
95.2
《
星地融合移动通信系统与关键技术从5G NTN到6G的卫星互联网发展
》
售價:HK$
212.6
《
妈妈,你好吗?(一封写给妈妈的“控诉”信,日本绘本奖作品)
》
售價:HK$
42.6
《
保守主义:为传统而战
》
售價:HK$
154.6
《
不同境遇的36岁:无尽与有限+人生半熟
》
售價:HK$
112.0
|
編輯推薦: |
本书在手,Java程序员笑傲江湖!
面试在即,Java知识点很凌乱?
别急,本书精选重要知识点为你精细讲解:
JVM原理、Java基础;
并发编程、数据结构和算法;
网络与负载均衡;;
数据库与分布式事务
分布式缓存原理及应用;
设计模式原理及实现。
除了原理讲解,还有Java实现!
面试时的原理 动手实现脑海已就位,整装待发!
互联网寒冬怕什么!
另外,作者亲授掌握本书知识点技巧:
----3周:细读本书,详细理解书中的知识点、代码和架构图。
----2天:对着本书目录回忆知识点,及时查漏补缺。
----3小时:复习本书,以充分掌握本书知识点。
我想,你应该会更快!加油!
|
內容簡介: |
本书是对Java程序员面试必备知识点的总结,详细讲解了JVM原理、多线程、数据结构和算法、分布式缓存、设计模式等面试必备知识点,在讲解时不拖泥带水,力求精简。
本书总计9章,第1章讲解JVM原理,涉及JVM运行机制、JVM内存模型、常用垃圾回收算法和JVM类加载机制等内容;第2章讲解Java基础知识,涉及集合、异常分类及处理、反射、注解、内部类、泛型和序列化等内容;第3章讲解Java并发编程知识,涉及Java多线程的工作原理及应用、Java线程池的工作原理及应用,以及锁、进程调度算法等内容;第4章讲解数据结构知识,涉及栈、队列、链表、散列表、二叉树、红黑树、图和位图等内容;第5章讲解Java中的常用算法,涉及二分查找、冒泡排序、插入排序、快速排序、希尔排序、归并排序、桶排序、基数排序等算法;第6章讲解网络与负载均衡原理,涉及TCPIP、HTTP、常用负载均衡算法和LVS原理等内容;第7章讲解数据库及分布式事务原理,涉及数据库存储引擎、数据库并发操作和锁、数据库分布式事务等内容;第8章讲解分布式缓存的原理及应用,涉及分布式缓存介绍、Ehcache原理及应用、Redis原理及应用、分布式缓存设计的核心问题等内容;第9章讲解设计模式,涉及常见的23种经典设计模式。
本书可作为Java程序员的技术面试参考用书,也可作为Java程序员、技术经理和架构师的日常技术参考用书。
|
關於作者: |
王磊,现任国内某知名互联网公司大数据技术架构师,有十余年丰富的物联网及大数据研发和技术架构经验,对物联网及大数据的原理和技术实现有深刻的理解。长期从事海外项目的研发和交付工作,对异地多活数据中心的建设及高可用、高并发系统的设计有丰富的实战经验。
|
目錄:
|
第1章 JVM 1
1.1 JVM的运行机制 1
1.2 多线程 2
1.3 JVM的内存区域 3
1.3.1 程序计数器:线程私有,无内存溢出问题 4
1.3.2 虚拟机栈:线程私有,描述Java方法的执行过程 4
1.3.3 本地方法区:线程私有 5
1.3.4 堆:也叫作运行时数据区,线程共享 5
1.3.5 方法区:线程共享 5
1.4 JVM的运行时内存 6
1.4.1 新生代:Eden区、ServivorTo区和ServivorFrom区 7
1.4.2 老年代 8
1.4.3 永久代 8
1.5 垃圾回收与算法 9
1.5.1 如何确定垃圾 9
1.5.2 Java中常用的垃圾回收算法 10
1.6 Java中的4种引用类型 13
1.7 分代收集算法和分区收集算法 14
1.7.1 分代收集算法 14
1.7.2 分区收集算法 15
1.8 垃圾收集器 15
1.8.1 Serial垃圾收集器:单线程,复制算法 16
1.8.2 ParNew垃圾收集器:多线程,复制算法 16
1.8.3 Parallel Scavenge垃圾收集器:多线程,复制算法 16
1.8.4 Serial Old垃圾收集器:单线程,标记整理算法 16
1.8.5 Parallel Old垃圾收集器:多线程,标记整理算法 17
1.8.6 CMS垃圾收集器 18
1.8.7 G1垃圾收集器 18
1.9 Java网络编程模型 19
1.9.1 阻塞IO模型 19
1.9.2 非阻塞IO模型 19
1.9.3 多路复用IO模型 20
1.9.4 信号驱动IO模型 21
1.9.5 异步IO模型 21
1.9.6 Java IO 21
1.9.7 Java NIO 22
1.10 JVM的类加载机制 28
1.10.1 JVM的类加载阶段 28
1.10.2 类加载器 29
1.10.3 双亲委派机制 30
1.10.4 OSGI 32
第2章 Java基础 33
2.1 集合 33
2.1.1 List:可重复 34
2.1.2 Queue 34
2.1.3 Set:不可重复 35
2.1.4 Map 36
2.2 异常分类及处理 39
2.2.1 异常的概念 39
2.2.2 异常分类 40
2.2.3 异常处理方式:抛出异常、使用try catch捕获并处理异常 41
2.3 反射机制 42
2.3.1 动态语言的概念 42
2.3.2 反射机制的概念 43
2.3.3 反射的应用 43
2.3.4 Java的反射API 43
2.3.5 反射的步骤 43
2.3.6 创建对象的两种方式 45
2.3.7 Method的invoke方法 45
2.4 注解 46
2.4.1 注解的概念 46
2.4.2 标准元注解:@Target、@Retention、@Documented、@Inherited 46
2.4.3 注解处理器 47
2.5 内部类 49
2.5.1 静态内部类 49
2.5.2 成员内部类 50
2.5.3 局部内部类 51
2.5.4 匿名内部类 51
2.6 泛型 52
2.6.1 泛型标记和泛型限定:E、T、K、V、N、? 53
2.6.2 泛型方法 53
2.6.3 泛型类 54
2.6.4 泛型接口 55
2.6.5 类型擦除 56
2.7 序列化 56
2.7.1 Java序列化API的使用 57
2.7.2 序列化和反序列化 58
第3章 Java并发编程 59
3.1 Java线程的创建方式 59
3.1.1 继承Thread类 59
3.1.2 实现Runnable接口 60
3.1.3 通过ExecutorService和Callable实现有返回值的线程 61
3.1.4 基于线程池 62
3.2 线程池的工作原理 62
3.2.1 线程复用 63
3.2.2 线程池的核心组件和核心类 63
3.2.3 Java线程池的工作流程 65
3.2.4 线程池的拒绝策略 66
3.3 5种常用的线程池 68
3.3.1 newCachedThreadPool 68
3.3.2 newFixedThreadPool 68
3.3.3 newScheduledThreadPool 69
3.3.4 newSingleThreadExecutor 69
3.3.5 newWorkStealingPool 69
3.4 线程的生命周期 70
3.4.1 新建状态:New 71
3.4.2 就绪状态:Runnable 71
3.4.3 运行状态:Running 71
3.4.4 阻塞状态:Blocked 71
3.4.5 线程死亡:Dead 72
3.5 线程的基本方法 72
3.5.1 线程等待:wait方法 72
3.5.2 线程睡眠:sleep方法 73
3.5.3 线程让步:yield方法 73
3.5.4 线程中断:interrupt方法 73
3.5.5 线程加入:join方法 74
3.5.6 线程唤醒:notify方法 75
3.5.7 后台守护线程:setDaemon方法 75
3.5.8 sleep方法与wait方法的区别 76
3.5.9 start方法与run方法的区别 76
3.5.10 终止线程的4种方式 77
3.6 Java中的锁 79
3.6.1 乐观锁 79
3.6.2 悲观锁 79
3.6.3 自旋锁 80
3.6.4 synchronized 81
3.6.5 ReentrantLock 89
3.6.6 synchronized和ReentrantLock的比较 94
3.6.7 Semaphore 95
3.6.8 AtomicInteger 96
3.6.9 可重入锁 97
3.6.10 公平锁与非公平锁 97
3.6.11 读写锁:ReadWriteLock 98
3.6.12 共享锁和独占锁 98
3.6.13 重量级锁和轻量级锁 99
3.6.14 偏向锁 99
3.6.15 分段锁 100
3.6.16 同步锁与死锁 100
3.6.17 如何进行锁优化 100
3.7 线程上下文切换 101
3.7.1 上下文切换 102
3.7.2 引起线程上下文切换的原因 102
3.8 Java阻塞队列 103
3.8.1 阻塞队列的主要操作 104
3.8.2 Java中的阻塞队列实现 108
3.9 Java并发关键字 113
3.9.1 CountDownLatch 113
3.9.2 CyclicBarrier 114
3.9.3 Semaphore 116
3.9.4 volatile关键字的作用 117
3.10 多线程如何共享数据 119
3.10.1 将数据抽象成一个类,并将对这个数据的操作封装在类的方法中 119
3.10.2 将Runnable对象作为一个类的内部类,将共享数据作为这个类的成员变量 121
3.11 ConcurrentHashMap并发 122
3.11.1 减小锁粒度 122
3.11.2 ConcurrentHashMap的实现 123
3.12 Java中的线程调度 123
3.12.1 抢占式调度 123
3.12.2 协同式调度 124
3.12.3 Java线程调度的实现:抢占式 124
3.12.4 线程让出CPU的情况 125
3.13 进程调度算法 125
3.13.1 优先调度算法 125
3.13.2 高优先权优先调度算法 126
3.13.3 时间片的轮转调度算法 127
3.14 什么是CAS 128
3.14.1 CAS的概念:比较并交换 128
3.14.2 CAS的特性:乐观锁 128
3.14.3 CAS自旋等待 129
3.15 ABA问题 129
3.16 什么是AQS 130
3.16.1 AQS的原理 130
3.16.2 state:状态 131
3.16.3 AQS共享资源的方式:独占式和共享式 131
第4章 数据结构 133
4.1 栈及其Java实现 133
4.2 队列及其Java实现 136
4.3 链表 138
4.3.1 链表的特点 139
4.3.2 单向链表的操作及其Java实现 139
4.3.3 双向链表及其Java实现 143
4.3.4 循环链表 146
4.4 散列表 146
4.4.1 常用的构造散列函数 147
4.4.2 Hash的应用 148
4.5 二叉排序树 148
4.5.1 插入操作 149
4.5.2 删除操作 149
4.5.3 查找操作 151
4.5.4 用Java实现二叉排序树 151
4.6 红黑树 155
4.6.1 红黑树的特性 156
4.6.2 红黑树的左旋 156
4.6.3 红黑树的右旋 157
4.6.4 红黑树的添加 157
4.6.5 红黑树的删除 158
4.7 图 159
4.7.1 无向图和有向图 159
4.7.2 图的存储结构:邻接矩阵 160
4.7.3 图的存储结构:邻接表 161
4.7.4 图的遍历 162
4.8 位图 164
4.8.1 位图的数据结构 164
4.8.2 位图的Java实现 165
第5章 Java中的常用算法 167
5.1 二分查找算法 167
5.1.1 二分查找算法的原理 168
5.1.2 二分查找算法的Java实现 168
5.2 冒泡排序算法 169
5.2.1 冒泡排序算法的原理 169
5.2.2 冒泡排序算法的Java实现 170
5.3 插入排序算法 171
5.3.1 插入排序算法的原理 171
5.3.2 插入排序算法的Java实现 172
5.4 快速排序算法 173
5.4.1 快速排序算法的原理 173
5.4.2 快速排序算法的Java实现 174
5.5 希尔排序算法 175
5.5.1 希尔排序算法的原理 176
5.5.2 希尔排序算法的Java实现 177
5.6 归并排序算法 178
5.6.1 归并排序算法的原理 178
5.6.2 归并排序算法的Java实现 178
5.7 桶排序算法 180
5.7.1 桶排序算法的原理 180
5.7.2 桶排序算法的Java实现 181
5.8 基数排序算法 182
5.8.1 基数排序算法的原理 182
5.8.2 基数排序算法的Java实现 183
5.9 其他算法 184
5.9.1 剪枝算法 184
5.9.2 回溯算法 186
5.9.3 最短路径算法 186
第6章 网络与负载均衡 188
6.1 网络 188
6.1.1 OSI七层网络模型 188
6.1.2 TCPIP四层网络模型 189
6.1.3 TCP三次握手四次挥手 190
6.1.4 HTTP的原理 195
6.1.5 CDN的原理 199
6.2 负载均衡 201
6.2.1 四层负载均衡与七层负载均衡的对比 201
6.2.2 负载均衡算法 203
6.2.3 LVS的原理及应用 205
6.2.4 Nginx反向代理与负载均衡 211
第7章 数据库及分布式事务 214
7.1 数据库的基本概念及原则 214
7.1.1 存储引擎 214
7.1.2 创建索引的原则 216
7.1.3 数据库三范式 217
7.1.4 数据库事务 218
7.1.5 存储过程 219
7.1.6 触发器 219
7.2 数据库的并发操作和锁 220
7.2.1 数据库的并发策略 220
7.2.2 数据库锁 220
7.2.3 数据库分表 223
7.3 数据库分布式事务 223
7.3.1 CAP 223
7.3.2 两阶段提交协议 224
7.3.3 三阶段提交协议 225
7.3.4 分布式事务 227
第8章 分布式缓存的原理及应用 230
8.1 分布式缓存介绍 230
8.2 Ehcache的原理及应用 231
8.2.1 Ehcache的原理 231
8.2.2 Ehcache的应用 234
8.3 Redis的原理及应用 235
8.3.1 Redis的原理 235
8.3.2 Redis的应用 249
8.4 分布式缓存设计的核心问题 252
8.4.1 缓存预热 253
8.4.2 缓存更新 253
8.4.3 缓存淘汰策略 253
8.4.4 缓存雪崩 253
8.4.5 缓存穿透 254
8.4.6 缓存降级 255
第9章 设计模式 256
9.1 设计模式简介 256
9.2 工厂模式的概念及Java实现 259
9.3 抽象工厂模式的概念及Java实现 261
9.4 单例模式的概念及Java实现 265
9.5 建造者模式的概念及Java实现 268
9.6 原型模式的概念及Java实现 271
9.7 适配器模式的概念及Java实现 274
9.8 装饰者模式的概念及Java实现 280
9.9 代理模式的概念及Java实现 282
9.10 外观模式的概念及Java实现 284
9.11 桥接模式的概念及Java实现 288
9.12 组合模式的概念及Java实现 291
9.13 享元模式的概念及Java实现 293
9.14 策略模式的概念及Java实现 296
9.15 模板方法模式的概念及Java实现 299
9.16 观察者模式的概念及Java实现 302
9.17 迭代器模式的概念及Java实现 305
9.18 责任链模式的概念及Java实现 308
9.19 命令模式的概念及Java实现 312
9.20 备忘录模式的概念及Java实现 315
9.21 状态模式的概念及Java实现 317
9.22 访问者模式的概念及Java实现 320
9.23 中介者模式的概念及Java实现 324
9.24 解释器模式的概念及Java实现 328
|
內容試閱:
|
本书是对Java程序员面试必备知识点的总结,详细讲解了JVM原理、多线程、数据结构和算法、分布式缓存、设计模式等内容,希望读者能通过阅读本书对Java的基础原理有更深入、全面的理解。
面试官通常会在短短两小时内对面试者的知识结构进行全面了解,面试者在回答问题时如果拖泥带水且不能直击问题的本质,则很难充分表现自己,最终影响面试结果。针对这种情况,本书在讲解知识点时不拖泥带水,力求精简,详细介绍了Java程序员面试时常被问及的核心知识点。
章节架构
本书共9章,各章所讲内容如下。
第1章讲解JVM原理,涉及JVM运行机制、JVM内存模型、常用垃圾回收算法和JVM类加载机制等内容。
第2章讲解Java基础知识,涉及集合、异常分类及处理、反射、注解、内部类、泛型和序列化等内容。
第3章讲解Java并发编程知识,涉及Java多线程的工作原理及应用、Java线程池的工作原理及应用,以及锁、进程调度算法等内容。
第4章讲解数据结构知识,涉及栈、队列、链表、散列表、二叉树、红黑树、图和位图等内容。
第5章讲解Java中的常用算法,涉及二分查找、冒泡排序、插入排序、快速排序、希尔排序、归并排序、桶排序、基数排序等算法。
第6章讲解网络与负载均衡原理,涉及TCPIP、HTTP、常用负载均衡算法和LVS原理等内容。
第7章讲解数据库及分布式事务原理,涉及数据库存储引擎、数据库并发操作和锁、数据库分布式事务等内容。
第8章讲解分布式缓存的原理及应用,涉及分布式缓存介绍、Ehcache原理及应用、Redis原理及应用、分布式缓存设计的核心问题等内容。
第9章讲解设计模式,涉及常见的23种经典设计模式。
阅读建议
本书目录细致,建议读者在阅读本书之后以目录作为参考温故而知新,达到融会贯通的目的。建议读者花3周进行细读,详细理解书中的知识点、代码和架构图;再花两天进行复习,对着目录回忆知识点,对想不起来的部分及时查漏补缺;在面试前再花3小时进行复习,以充分掌握本书知识点。这样,读者就能对书中每个知识点的广度和深度理解更充分,在面试时胸有成竹、百战不殆。
致谢
感谢电子工业出版社博文视点的张国霞编辑,她的鼓励和引导对本书的写作和出版有很大的帮助;感谢王晓栋,是他关注并向编辑提出了本书的出版价值。
写技术书籍是很耗费精力的,笔者常常因为一行代码或者一张图能否准确表达含义而思考再三。出于工作的原因,笔者只能在晚上和周末写作,写作难度很大,所以十分感谢妻子张艳娇女士,没有她的鼓励和支持,本书很难顺利出版;也十分感谢家人和朋友在工作和生活中对笔者的关心和帮助。
王磊
|
|