_sidebar.md 44.6 KB
Newer Older
1
* 基础篇
H
hollis.zhl 已提交
2

3 4 5 6 7 8 9 10 11 12 13 14 15 16
    * 面向对象
    
        * 什么是面向对象
        
            * [面向对象与面向过程](/basics/object-oriented/object-oriented-vs-procedure-oriented.md)
        
            * [面向对象的三大基本特征](/basics/object-oriented/characteristics.md)
        
            * [面向对象的五大基本原则](/basics/object-oriented/principle.md)
            
        * 封装、继承、多态
            * [什么是多态](/basics/object-oriented/polymorphism.md)
            
            * [方法重写与重载](/basics/object-oriented/overloading-vs-overriding.md)
H
hollis.zhl 已提交
17 18
            
            * Java的继承与实现
19 20 21 22 23 24 25 26
        
            * [Java的继承与组合](/basics/object-oriented/inheritance-composition.md)
        
            * [构造函数与默认构造函数](/basics/object-oriented/constructor.md)
            
            * [类变量、成员变量和局部变量](/basics/object-oriented/variable.md)
            
            * [成员变量和方法作用域](/basics/object-oriented/scope.md)
H
hollis.zhl 已提交
27 28 29 30 31 32
            
        * 平台无关性
        
            * [Java如何实现的平台无关性的](/basics/object-oriented/platform-independent.md)
            
            * [JVM还支持哪些语言](/basics/object-oriented/jvm-language.md)
33
        
H
hollis.zhl 已提交
34 35 36 37 38 39
        * 值传递
    
            * [值传递、引用传递](/basics/object-oriented/java-pass-by.md)
    
            * [为什么说Java中只有值传递](/basics/object-oriented/why-pass-by-reference.md)
      
40 41 42
    * Java基础知识
        
        * 基本数据类型
H
hollis.zhl 已提交
43

44
            * [8种基本数据类型](/basics/java-basic/basic-data-types.md)
H
hollis.zhl 已提交
45

46
            * [整型中byte、short、int、long的取值范围](/basics/java-basic/integer-scope.md)
H
hollis.zhl 已提交
47

48
            * [什么是浮点型?](/basics/java-basic/float.md)
H
hollis.zhl 已提交
49

50
            * [什么是单精度和双精度?](/basics/java-basic/single-double-float.md)
H
hollis.zhl 已提交
51

52 53 54 55 56 57 58
            * [为什么不能用浮点型表示金额?](/basics/java-basic/float-amount.md)

        * 自动拆装箱

            * [自动拆装箱](/basics/java-basic/boxing-unboxing.md)

            * [Integer的缓存机制](/basics/java-basic/integer-cache.md)
H
hollis.zhl 已提交
59 60
            
            * 如何正确定义接口的返回值(boolean/Boolean)类型及命名(success/Success)
61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76

        * String

            * [字符串的不可变性](/basics/java-basic/final-string.md)

            * [JDK 6和JDK 7中substring的原理及区别](/basics/java-basic/substring.md)

            * replaceFirst、replaceAll、replace区别

            * [String对“+”的重载](/basics/java-basic/string-append.md)

            * [字符串拼接的几种方式和区别](/basics/java-basic/string-concat.md)

            * [String.valueOf和Integer.toString的区别](/basics/java-basic/value-of-vs-to-string.md)

            * [switch对String的支持](/basics/java-basic/switch-string.md)
H
hollis.zhl 已提交
77
            
78
            * 字符串池
H
hollis.zhl 已提交
79
            
80
            * 常量池(运行时常量池、Class常量池)
H
hollis.zhl 已提交
81
            
82
            * intern
H
hollis.zhl 已提交
83
            
84
        * Java中各种关键字
H
hollis.zhl 已提交
85
        
86
            * transient
H
hollis.zhl 已提交
87
            
88
            * instanceof
H
hollis.zhl 已提交
89
            
90
            * volatile
H
hollis.zhl 已提交
91
            
92
            * synchronized
H
hollis.zhl 已提交
93
            
94
            * final
H
hollis.zhl 已提交
95
            
96
            * static
H
hollis.zhl 已提交
97
            
98
            * const 
H
hollis.zhl 已提交
99
            
100 101
        * 集合类
        
H
hollis.zhl 已提交
102 103
            * [Collection和Collections区别](/basics/java-basic/Collection-vs-Collections.md)
            
104 105
            * 常用集合类的使用
            
H
hollis.zhl 已提交
106 107
            * [Set和List区别?](/basics/java-basic/set-vs-list.md)
        
108 109 110 111
            * [ArrayList和LinkedList和Vector的区别](/basics/java-basic/arraylist-vs-linkedlist-vs-vector.md) 
            
            * [SynchronizedList和Vector的区别](/basics/java-basic/synchronizedlist-vector.md)
            
H
hollis.zhl 已提交
112 113
            * [Set如何保证元素不重复?](/basics/java-basic/set-repetition.md)
            
114 115
            * [HashMap、HashTable、ConcurrentHashMap区别](/basics/java-basic/HashMap-HashTable-ConcurrentHashMap.md)
            
H
hollis.zhl 已提交
116
            * Java 8中Map相关的红黑树的引用背景、原理等
117
            
H
hollis.zhl 已提交
118
            * HashMap的容量、扩容、hash等原理
119 120 121 122 123 124 125 126 127
            
            * [Java 8中stream相关用法](/basics/java-basic/stream.md)
            
            * Apache集合处理工具类的使用
            
            * 不同版本的JDK中HashMap的实现的区别以及原因
            
            * [Arrays.asList获得的List使用时需要注意什么](/basics/java-basic/Arrays-asList.md)
            
H
hollis.zhl 已提交
128 129
            * Collection如何迭代 
            
130 131
            * [Enumeration和Iterator区别](/basics/java-basic/Enumeration-vs-Iterator.md)
            
H
hollis.zhl 已提交
132 133
            * 如何在遍历的同时删除ArrayList中的元素
            
134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163
            * [fail-fast 和 fail-safe](/basics/java-basic/fail-fast-vs-fail-safe.md)
            
            * [CopyOnWriteArrayList](/basics/java-basic/CopyOnWriteArrayList.md)
            
            * [ConcurrentSkipListMap](/basics/java-basic/ConcurrentSkipListMap.md)

        * 枚举

            * [枚举的用法](/basics/java-basic/enum-usage.md)
            
            * [枚举的实现](/basics/java-basic/enum-impl.md)
            
            * [枚举与单例](/basics/java-basic/enum-singleton.md)
            
            * Enum类
            
            * [Java枚举如何比较](/basics/java-basic/enum-compare.md)
            
            * [switch对枚举的支持](/basics/java-basic/enum-switch.md)
            
            * [枚举的序列化如何实现](/basics/java-basic/enum-serializable.md)
            
            * [枚举的线程安全性问题](/basics/java-basic/enum-thread-safe.md)
            
        * IO
            
            * [字符流、字节流](/basics/java-basic/byte-stream-vs-character-stream.md)
            
            * [输入流、输出流](/basics/java-basic/input-stream-vs-output-stream.md)
            
H
hollis.zhl 已提交
164 165
            * 字节流和字符流之间的相互转换
            
166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200
            * [同步、异步](/basics/java-basic/synchronized-vs-asynchronization.md)
            
            * [阻塞、非阻塞](/basics/java-basic/block-vs-non-blocking.md)
            
            * [Linux 5种IO模型](/basics/java-basic/linux-io.md)
            
            * [BIO、NIO和AIO的区别、三种IO的用法与原理](/basics/java-basic/bio-vs-nio-vs-aio.md)
            
            * netty
            
        * 反射
        
            * [反射](/basics/java-basic/reflection.md)与工厂模式、 
        
            * [反射有什么作用](/basics/java-basic/usage-of-reflection.md)
        
            * [Class类](/basics/java-basic/Class.md)
        
            * `java.lang.reflect.*`
            
        * 动态代理
            
            * [静态代理](/basics/java-basic/static-proxy.md)
            
            * [动态代理](/basics/java-basic/dynamic-proxy.md)
            
            * [动态代理和反射的关系](/basics/java-basic/dynamic-proxy-vs-reflection.md)
            
            * [动态代理的几种实现方式](/basics/java-basic/dynamic-proxy-implementation.md)
            
            * [AOP](/basics/java-basic/aop-vs-proxy.md)
           
        * 序列化
           
           * [什么是序列化与反序列化](basics/java-basic/serialize.md)
H
hollis.zhl 已提交
201
           
202
           * [Java如何实现序列化与反序列化](basics/java-basic/serialize-in-java.md)
H
hollis.zhl 已提交
203
           
204
           * [Serializable 和 Externalizable 有何不同](basics/java-basic/diff-serializable-vs-externalizable.md)
H
hollis.zhl 已提交
205
           
206
           * 为什么序列化
H
hollis.zhl 已提交
207
           
208
           * [serialVersionUID](basics/java-basic/serialVersionUID.md)
H
hollis.zhl 已提交
209
           
210
           * [为什么serialVersionUID不能随便改](basics/java-basic/serialVersionUID-modify.md)
H
hollis.zhl 已提交
211
           
212
           * [transient](basics/java-basic/transient.md)
H
hollis.zhl 已提交
213
           
214
           * [序列化底层原理](basics/java-basic/serialize-principle.md)
H
hollis.zhl 已提交
215 216 217
           
           * [序列化如何破坏单例模式](basics/java-basic/serialize-singleton.md)
           
218
           * [protobuf](basics/java-basic/protobuf.md)
H
hollis.zhl 已提交
219
           
220 221 222 223 224
           * 为什么说序列化并不安全
           
        * 注解
           
           * [元注解](/basics/java-basic/meta-annotation.md)
H
hollis.zhl 已提交
225
           
226
           * [自定义注解](/basics/java-basic/custom-annotation.md)
H
hollis.zhl 已提交
227
           
228
           * Java中常用注解使用
H
hollis.zhl 已提交
229
           
230 231
           * 注解与反射的结合
           
H
hollis.zhl 已提交
232
           * [如何自定义一个注解?](/basics/java-basic/create-annotation.md)
233 234 235 236 237 238
           
           * [Spring常用注解](/basics/java-basic/annotation-in-spring.md)
            
        * 泛型
            
            * [什么是泛型](/basics/java-basic/generics.md)
H
hollis.zhl 已提交
239
            
240
            * [类型擦除](/basics/java-basic/type-erasue.md)
H
hollis.zhl 已提交
241
            
242
            * [泛型带来的问题](/basics/java-basic/generics-problem.md)
H
hollis.zhl 已提交
243
            
244
            * [泛型中K T V E ? object等的含义](/basics/java-basic/k-t-v-e.md)
H
hollis.zhl 已提交
245
            
246 247 248
            * 泛型各种用法
            
            * [限定通配符和非限定通配符](/basics/java-basic/Wildcard-Character.md)
H
hollis.zhl 已提交
249
            
250 251 252 253 254 255 256 257 258
            * [上下界限定符extends 和 super](/basics/java-basic/extends-vs-super.md)
            
            * [`List<Object>`和原始类型`List`之间的区别?](/basics/java-basic/genericity-list.md)
            
            * [`List<?>`和`List<Object>`之间的区别是什么?](/basics/java-basic/genericity-list-wildcard.md)
            
        * 单元测试
            
            * junit
H
hollis.zhl 已提交
259 260 261
            
            * junit 和Spring 的结合
            
262
            * mock
H
hollis.zhl 已提交
263
            
264
            * mockito
H
hollis.zhl 已提交
265
            
266 267 268 269 270 271 272 273 274
            * 内存数据库(h2)
            
        * 正则表达式
            
            * `java.lang.util.regex.*`
            
        * 常用的Java工具库
            
            * `commons.lang`
H
hollis.zhl 已提交
275
            
276
            * `commons.*...` 
H
hollis.zhl 已提交
277
            
278
            * `guava-libraries` 
H
hollis.zhl 已提交
279
            
280 281 282 283 284
            * `netty`
            
        * API&SPI
            
            * API
H
hollis.zhl 已提交
285
            
286 287 288
            * [API和SPI的关系和区别](/basics/java-basic/api-vs-spi.md)
            
            * [如何定义SPI](/basics/java-basic/create-spi.md)
H
hollis.zhl 已提交
289
            
290 291 292 293 294
            * [SPI的实现原理](/basics/java-basic/spi-principle.md)
            
        * 异常
            
            * [Error和Exception](/basics/java-basic/error-vs-exception.md)
H
hollis.zhl 已提交
295
            
296
            * [异常类型](/basics/java-basic/exception-type.md)
H
hollis.zhl 已提交
297
            
298
            * [异常相关关键字](/basics/java-basic/keyword-about-exception.md)
H
hollis.zhl 已提交
299
            
300
            * [正确处理异常](/basics/java-basic/handle-exception.md)
H
hollis.zhl 已提交
301
            
302
            * [自定义异常](/basics/java-basic/define-exception.md)
H
hollis.zhl 已提交
303
            
304
            * [异常链](/basics/java-basic/exception-chain.md)
H
hollis.zhl 已提交
305
            
306
            * [try-with-resources](/basics/java-basic/try-with-resources.md)
H
hollis.zhl 已提交
307
            
308 309 310 311 312
            * [finally和return的执行顺序](/basics/java-basic/order-about-finllly-return.md)
            
        * 时间处理
            
            * [时区](/basics/java-basic/time-zone.md)
H
hollis.zhl 已提交
313
            
314
            * [冬令时和夏令时](/basics/java-basic/StandardTime-vs-daylightSavingTime.md)
H
hollis.zhl 已提交
315
            
316 317 318 319
            * [时间戳](/basics/java-basic/timestamp.md)
            * Java中时间API
            
            * [格林威治时间](/basics/java-basic/GMT.md)
H
hollis.zhl 已提交
320
            
321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345
            * [CET,UTC,GMT,CST几种常见时间的含义和关系](/basics/java-basic/CET-UTC-GMT-CST.md)
            
            * [SimpleDateFormat的线程安全性问题](/basics/java-basic/simpledateformat-thread-safe.md)
            
            * [Java 8中的时间处理](/basics/java-basic/time-in-java8.md)
            
            * [如何在东八区的计算机上获取美国时间](/basics/java-basic/get-los_angeles-time.md)
            
            * [yyyy和YYYY有什么区别?](/basics/java-basic/YYYY-vs-yyyy.md)
            
        * 编码方式
            
            * [什么是ASCII?](/basics/java-basic/ASCII.md)
            
            * [Unicode](/basics/java-basic/UNICODE.md)
            
            * [有了Unicode为啥还需要UTF-8](/basics/java-basic/why-utf8.md)
            
            * [UTF8、UTF16、UTF32区别](/basics/java-basic/UTF8-UTF16-UTF32.md)
            
            * 有了UTF8为什么还需要GBK?
            
            * [GBK、GB2312、GB18030之间的区别](/basics/java-basic/gbk-gb2312-gb18030.md)
            
            * [URL编解码](/basics/java-basic/url-encode.md)
H
hollis.zhl 已提交
346
            
347 348 349 350 351 352 353 354 355 356
            * [Big Endian和Little Endian](/basics/java-basic/big-endian-vs-little-endian.md)
            
            * 如何解决乱码问题
            
        * 语法糖
            
            *  [Java中语法糖原理、解语法糖](/basics/java-basic/syntactic-sugar.md)
            
            *  [语法糖介绍](/basics/java-basic/syntactic-sugar.md)
            
H
hollis.zhl 已提交
357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376
        * JMS
            
            * 什么是Java消息服务
            
            * JMS消息传送模型
            
        * JMX
            
            * java.lang.management.* 
            
            * javax.management.*
            
        * Java 8
            
            * lambda表达式
            
            * Stream API
            
            * 时间API
            
377 378 379
        * 阅读源代码
            
            * String
H
hollis.zhl 已提交
380
            
381
            * Integer
H
hollis.zhl 已提交
382
            
383
            * Long
H
hollis.zhl 已提交
384
            
385
            * Enum
H
hollis.zhl 已提交
386
            
387
            * BigDecimal
H
hollis.zhl 已提交
388
            
389
            * ThreadLocal
H
hollis.zhl 已提交
390
            
391
            * ClassLoader & URLClassLoader
H
hollis.zhl 已提交
392
            
393
            * ArrayList & LinkedList
H
hollis.zhl 已提交
394
            
395
            * HashMap & LinkedHashMap & TreeMap & CouncurrentHashMap
H
hollis.zhl 已提交
396
            
397 398 399 400 401 402 403 404 405 406 407 408 409
            * HashSet & LinkedHashSet & TreeSet
            
    * Java并发编程
            
        * 并发与并行
            
            * [什么是并发](/basics/concurrent-coding/concurrent.md)
            
            * [什么是并行](/basics/concurrent-coding/parallel.md)
            
            * [并发与并行的区别](/basics/concurrent-coding/concurrent-vs-parallel.md)
            
        * 线程
H
hollis.zhl 已提交
410 411
        
            * 线程与进程的区别
412 413
            
            * 线程的实现
H
hollis.zhl 已提交
414
            
415
            * 线程的状态
H
hollis.zhl 已提交
416
            
417
            * 线程优先级
H
hollis.zhl 已提交
418
            
419
            * 线程调度
H
hollis.zhl 已提交
420 421 422
            
            * 多线程如何Debug
            
423
            * 守护线程
H
hollis.zhl 已提交
424 425 426 427 428 429 430 431 432 433
            
        * 创建线程的多种方式
            
            * 继承Thread类创建线程
            
            * 实现Runnable接口创建线程
            
            * 通过Callable和FutureTask创建线程
            
            * 通过线程池创建线程
434 435 436 437
            
        * 线程池
            
            * 自己设计线程池
H
hollis.zhl 已提交
438
            
439
            * submit() 和 execute()
H
hollis.zhl 已提交
440
            
441
            * 线程池原理
H
hollis.zhl 已提交
442
            
443 444 445
            * 为什么不允许使用Executors创建线程池
            
        * 线程安全
H
hollis.zhl 已提交
446 447 448 449 450 451 452 453
        
            * 什么是线程安全
            
            * 多级缓存和一致性问题
            
            * CPU时间片和原子性问题
            
            * 指令重排和有序性问题
454 455 456
            
            * 线程安全和内存模型的关系
            
H
hollis.zhl 已提交
457
            * happens-before
458
            
H
hollis.zhl 已提交
459 460 461 462 463 464 465 466
            * as-if-serial
            
        * 锁
        
            * 可重入锁
        
            * 阻塞锁
        
467
            * 乐观锁与悲观锁
H
hollis.zhl 已提交
468
        
469
            * 数据库相关锁机制
H
hollis.zhl 已提交
470
        
471
            * 分布式锁
H
hollis.zhl 已提交
472 473 474 475 476 477 478 479 480
            
        * 无锁
        
            * CAS
        
            * CAS的ABA问题
    
        * 锁优化
        
481
            * 偏向锁
H
hollis.zhl 已提交
482
        
483
            * 轻量级锁
H
hollis.zhl 已提交
484
        
485
            * 重量级锁
H
hollis.zhl 已提交
486
        
487
            * 锁消除
H
hollis.zhl 已提交
488
        
489
            * 锁粗化
H
hollis.zhl 已提交
490
        
491 492 493
            * 自旋锁
            
        * 死锁
H
hollis.zhl 已提交
494 495 496
        
            * [什么是死锁](/basics/concurrent-coding/deadlock-java-level.md)
        
497
            * 死锁的原因
H
hollis.zhl 已提交
498 499 500 501 502 503 504
        
            * 如何避免死锁
        
            * 写一个死锁的程序
        
            * 死锁问题如何排查
    
505 506 507 508 509
        * synchronized
            
            * [synchronized是如何实现的?](/basics/concurrent-coding/synchronized.md)
            
            * synchronized和lock之间关系
H
hollis.zhl 已提交
510
            
511 512
            * 不使用synchronized如何实现一个线程安全的单例
            
H
hollis.zhl 已提交
513
            * synchronized和原子性
514
            
H
hollis.zhl 已提交
515 516 517 518 519 520
            * synchronized和可见性
            
            * synchronized和有序性
            
        * volatile
        
521 522 523 524
            * 编译器指令重排和CPU指令重排
            
            * volatile的实现原理
            
H
hollis.zhl 已提交
525 526
            * 内存屏障
            
527 528
            * volatile和原子性
            
H
hollis.zhl 已提交
529 530 531
            * volatile和可见性
            
            * volatile和有序性
532
            
H
hollis.zhl 已提交
533
            * 有了symchronized为什么还需要volatile
534
            
H
hollis.zhl 已提交
535 536 537 538 539
        * 线程相关方法
        
            * start & run
        
            * sleep 和 wait
540
            
H
hollis.zhl 已提交
541
            * notify & notifyAll
542 543
            
        * ThreadLocal
H
hollis.zhl 已提交
544 545
        
            * ThreadLocal 原理
546
            
H
hollis.zhl 已提交
547
            * ThreadLocal 底层的数据结构
548 549 550
            
        * 写代码来解决生产者消费者问题
            
H
hollis.zhl 已提交
551
        * 并发包
552
            
H
hollis.zhl 已提交
553
            * 同步容器与并发容器
554 555
            
            * Thread
H
hollis.zhl 已提交
556
            
557
            * Runnable
H
hollis.zhl 已提交
558
            
559
            * Callable
H
hollis.zhl 已提交
560
            
561
            * ReentrantLock
H
hollis.zhl 已提交
562
            
563
            * ReentrantReadWriteLock
H
hollis.zhl 已提交
564
            
565
            * Atomic*
H
hollis.zhl 已提交
566
            
567
            * Semaphore
H
hollis.zhl 已提交
568
            
569
            * CountDownLatch
H
hollis.zhl 已提交
570
            
571
            * ConcurrentHashMap
H
hollis.zhl 已提交
572
            
573 574 575 576 577 578 579 580 581 582
            * Executors
            
* 底层篇
            
     * JVM
            
        * JVM内存结构
            
            * 运行时数据区
            
H
hollis.zhl 已提交
583
            * 运行时数据区哪些是线程独享
584
            
H
hollis.zhl 已提交
585
            * 堆和栈区别
586
            
H
hollis.zhl 已提交
587
            * 方法区在不同版本JDK中的位置
588
            
H
hollis.zhl 已提交
589 590 591 592 593
            * 堆外内存
              
            * TLAB
              
            * [Java中的对象一定在堆上分配吗?](/basement/jvm/stack-alloc.md)
594 595 596 597 598 599
            
        * 垃圾回收
            
            * GC算法:标记清除、引用计数、复制、标记压缩、分代回收、增量式回收
            
            * GC参数
H
hollis.zhl 已提交
600
            
601
            * 对象存活的判定
H
hollis.zhl 已提交
602
            
603 604 605
            * 垃圾收集器(CMS、G1、ZGC、Epsilon)
            
        * JVM参数及调优
H
hollis.zhl 已提交
606
                    
607
            * -Xmx
H
hollis.zhl 已提交
608
            
609
            * -Xmn
H
hollis.zhl 已提交
610
            
611
            * -Xms
H
hollis.zhl 已提交
612 613 614
            
            * -Xss
            
615 616 617
            * -XX:SurvivorRatio
            
            * -XX:PermSize
H
hollis.zhl 已提交
618
            
619 620
            * -XX:MaxPermSize
            
H
hollis.zhl 已提交
621 622
            * -XX:MaxTenuringThreshold
                    
623 624 625
        * Java对象模型
            
            * oop-klass
H
hollis.zhl 已提交
626
            
627 628 629 630 631
            * 对象头
            
        * HotSpot
            
            * 即时编译器
H
hollis.zhl 已提交
632
            
633 634
            * 编译优化
            
H
hollis.zhl 已提交
635
        * Java内存模型
636
            
H
hollis.zhl 已提交
637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659
            * 计算机内存模型
            
            * 缓存一致性
            
            * MESI协议
            
            * 可见性
            
            * 原子性
            
            * 顺序性
            
            * happens-before
            
            * as-if-serial
            
            * 内存屏障
            
            * synchronized
            
            * volatile
            
            * final
660
            
H
hollis.zhl 已提交
661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689
            *

    * 虚拟机性能监控与故障处理工具
            
        * jps
        
        * jstack
        
        * jmap
        
        * jstat
        
        * jconsole
        
        * jinfo
        
        * jhat
        
        * javap
        
        * btrace
        
        * TProfiler
        
        * jlink
        
        * Arthas
            
    * 类加载机制
690 691
            
        * classLoader
H
hollis.zhl 已提交
692 693 694
        
        * 类加载过程是线程安全的吗?
        
695
        * 类加载过程
H
hollis.zhl 已提交
696
        
697
        * 双亲委派(破坏双亲委派)
H
hollis.zhl 已提交
698
        
699
        * 模块化(jboss modules、osgi、jigsaw)
H
hollis.zhl 已提交
700 701 702 703 704 705 706 707
        
    * 打包工具
        
        * jar
        
        * jlink
        
        * jpackage
708
            
H
hollis.zhl 已提交
709
    * 编译与反编译
710
            
H
hollis.zhl 已提交
711 712
        * 什么是编译
        
713 714
        * 什么是反编译
        
H
hollis.zhl 已提交
715 716 717 718 719 720
        * 编译工具:javac
                
        * 反编译工具:javap 、jad 、CRF
        
    * JIT
    
721 722 723 724 725 726 727 728 729 730 731
        * JIT优化(逃逸分析、栈上分配、标量替换、锁优化)
        
        
            
* 进阶篇          
    * Java底层知识
            
        * 字节码
        
        * class文件格式
        
H
hollis.zhl 已提交
732
        * CAFEBABE
733
        
H
hollis.zhl 已提交
734
    * 位运算
735
        
H
hollis.zhl 已提交
736
        * 用位运算实现加、减、乘、除、取余
737 738 739 740 741 742
            
    * 设计模式
        
        * 设计模式的六大原则
            
            * 开闭原则(Open Close Principle)
H
hollis.zhl 已提交
743
            
744
            * 里氏代换原则(Liskov Substitution Principle)
H
hollis.zhl 已提交
745
            
746
            * 依赖倒转原则(Dependence Inversion Principle)
H
hollis.zhl 已提交
747
            
748
            * 接口隔离原则(Interface Segregation Principle)
H
hollis.zhl 已提交
749
            
750
            * 迪米特法则(最少知道原则)(Demeter Principle)
H
hollis.zhl 已提交
751
            
752 753
            * 合成复用原则(Composite Reuse Principle)
            
H
hollis.zhl 已提交
754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804
        * 创建型设计模式
        
            * 单例模式
            
            * 抽象工厂模式
            
            * 建造者模式
            
            * 工厂模式
            
            * 原型模式
            
        * 结构型设计模式
        
            * 适配器模式
            
            * 桥接模式
            
            * 装饰模式
            
            * 组合模式
            
            * 外观模式
            
            * 享元模式
            
            * 代理模式
            
        * 行为型设计模式
        
            * 模版方法模式
            
            * 命令模式
            
            * 迭代器模式
            
            * 观察者模式
            
            * 中介者模式
            
            * 备忘录模式
            
            * 解释器模式
            
            * 状态模式
            
            * 策略模式
            
            * 责任链模式
            
            * 访问者模式
805
    
H
hollis.zhl 已提交
806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827
        * 单例的七种写法
        
            * 懒汉——线程不安全
            
            * 懒汉——线程安全
            
            * 饿汉
            
            * 饿汉——变种
            
            * 静态内部类
            
            * 枚举
            
            * 双重校验锁
            
        * 为什么推荐使用枚举实现单例?
        
        * 三种工厂模式的区别及联系
        
            * 简单工厂、工厂方法、模板工厂
            
828 829 830
        * 会使用常用设计模式
        
            * 工厂模式
H
hollis.zhl 已提交
831
            
832
            * 适配器模式
H
hollis.zhl 已提交
833
            
834
            * 策略模式
H
hollis.zhl 已提交
835
            
836
            * 模板方法模式
H
hollis.zhl 已提交
837
            
838
            * 观察者模式
H
hollis.zhl 已提交
839
            
840
            * 外观模式
H
hollis.zhl 已提交
841
            
842 843 844 845 846
            * 代理模式
            
        * 不用synchronized和lock,实现线程安全的单例模式
            
        * nio和reactor设计模式
H
hollis.zhl 已提交
847 848
        
        * Spring中用到了哪些设计模式
849 850
            
    * 网络编程知识
H
hollis.zhl 已提交
851 852 853 854 855 856 857
    
        * 常用协议
        
            * tcp、udp、http、https
        
            * 用Java实现FTP、SMTP协议
        
858
        * OSI七层模型
H
hollis.zhl 已提交
859 860 861 862 863 864 865 866 867 868
        
            * 每一层的主要协议
        
        * TCP/UDP
        
            * 三次握手与四次关闭
        
            * 流量控制和拥塞控制
        
            * tcp粘包与拆包
869
            
H
hollis.zhl 已提交
870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 885 886 887
        * TCP/IP
        
            * IPV4
        
            * IPV6
        
        * HTTP
            * http/1.0 http/1.1 http/2之间的区别
        
            * http和https的区别
        
            * http中 get和post区别
        
            * 常见的web请求返回的状态码
        
            * 404、302、301、500分别代表什么
        
            * 用Java写一个简单的静态文件的HTTP服务器
888 889
            
        * http/2
H
hollis.zhl 已提交
890
        
891
        * Java RMI,Socket,HttpClient
H
hollis.zhl 已提交
892
                
893 894 895
        * cookie 与 session
            
            * cookie被禁用,如何实现session
H
hollis.zhl 已提交
896
        
897
        * 了解nginx和apache服务器的特性并搭建一个对应的服务器
H
hollis.zhl 已提交
898
       
899 900 901 902 903 904 905
        * 进程间通讯的方式
            
        * 什么是CDN?如果实现?
            
        * DNS?
            
            * 什么是DNS 
H
hollis.zhl 已提交
906
            
907 908 909
            * 记录类型:A记录、CNAME记录、AAAA记录等
            
            * 域名解析
H
hollis.zhl 已提交
910
            
911 912 913
            * 根域名服务器
            
            * DNS污染
H
hollis.zhl 已提交
914
            
915
            * DNS劫持
H
hollis.zhl 已提交
916
            
917 918 919 920 921
            * 公共DNS:114 DNS、Google DNS、OpenDNS
            
        * 反向代理
            
            * 正向代理
H
hollis.zhl 已提交
922
            
923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948
            * 反向代理
            
            * 反向代理服务器
            
    * 框架知识
            
        * Servlet
            
            * 生命周期
            
            * 线程安全问题
            
            * filter和listener
            
            * web.xml中常用配置及作用
            
        * Hibernate
            
            * 什么是OR Mapping
            
            * Hibernate的缓存机制
            
            * Hibernate的懒加载
            
            * Hibernate/Ibatis/MyBatis之间的区别
            
H
hollis.zhl 已提交
949 950 951 952 953 954 955 956 957 958 959 960
        * MyBatis
          
            * Mybatis缓存机制
              
            * `#{}``${}`的区别
              
            * mapper中传递多个参数
              
            * Mybatis动态sql
            
            * Mybatis的延迟加载
            
961 962 963 964 965 966 967 968 969 970 971 972 973 974 975 976 977 978 979
        * Spring 
            
            * Bean的初始化
            
            * AOP原理
            
            * 实现Spring的IOC
            
            * spring四种依赖注入方式
            
        * Spring MVC
            
            * 什么是MVC
            
            * Spring mvc与Struts mvc的区别
            
        * Spring Boot
            
            * Spring Boot 2.0
H
hollis.zhl 已提交
980
            
981
            * 起步依赖
H
hollis.zhl 已提交
982
            
983 984 985 986
            * 自动配置
            
            * Spring Boot的starter原理
            
H
hollis.zhl 已提交
987
            * 自己实现一个starter
988
            
H
hollis.zhl 已提交
989
            * 为什么Spring Boot可以通过main启动web项目
990
            
H
hollis.zhl 已提交
991
        * Spring Security
992
            
H
hollis.zhl 已提交
993 994 995 996 997 998 999 1000 1001 1002 1003 1004 1005
        * Spring Cloud
                
            * 服务发现与注册:Eureka、Zookeeper、Consul
                
            * 负载均衡:Feign、Spring Cloud Loadbalance
                
            * 服务配置:Spring Cloud Config
                
            * 服务限流与熔断:Hystrix
                
            * 服务链路追踪:Dapper
                
            * 服务网关、安全、消息
1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022
            
    * 应用服务器知识
            
        * JBoss
            
        * tomcat
            
        * jetty
            
        * Weblogic
            
    * 工具
            
        * git & svn
            
        * maven & gradle
            
H
hollis.zhl 已提交
1023 1024 1025 1026 1027 1028 1029
        * git技巧
       
            * 分支合并
       
            * 冲突解决
       
            * 提交回滚
1030
            
H
hollis.zhl 已提交
1031 1032 1033 1034 1035
        * maven技巧
        
            * 依赖树
        
            * 依赖仲裁
1036
                
H
hollis.zhl 已提交
1037 1038
        * Intellij IDEA
            * 常用插件:Maven Helper、FindBugs-IDEA、阿里巴巴代码规约检测、GsonFormat、Lombok plugin、.ignore、Mybatis plugin
1039 1040 1041 1042 1043 1044 1045 1046 1047 1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059 1060 1061 1062 1063 1064 1065 1066 1067 1068 1069 1070 1071 1072
            
* 高级篇
            
    * 新技术
            
        * Java 9
            
            * Jigsaw
            * Jshell
            * Reactive Streams
            
        * Java 10
            
            * 局部变量类型推断
            * G1的并行Full GC
            * ThreadLocal握手机制
            
        * Java 11
            
            * ZGC
            * Epsilon
            * 增强var
        * Java 12
            
            * Switch 表达式
            
        * Java 13
            
            * Text Blocks
            * Dynamic CDS Archives
             
        * Java 14
            
            * Java打包工具
H
hollis.zhl 已提交
1073
            
1074
            * 更有价值的NullPointerException
H
hollis.zhl 已提交
1075
            
1076 1077 1078 1079 1080 1081 1082 1083
            * record类型
            
        * Spring 5
            
            * 响应式编程
            
        * Spring Boot 2.0
            
H
hollis.zhl 已提交
1084 1085 1086
        * http/2
                
        * http/3
1087 1088 1089 1090
            
    * 性能优化
            
        * 使用单例
H
hollis.zhl 已提交
1091
        
1092
        * 使用Future模式
H
hollis.zhl 已提交
1093
        
1094
        * 使用线程池
H
hollis.zhl 已提交
1095
        
1096
        * 选择就绪
H
hollis.zhl 已提交
1097
        
1098
        * 减少上下文切换
H
hollis.zhl 已提交
1099
        
1100
        * 减少锁粒度
H
hollis.zhl 已提交
1101
        
1102
        * 数据压缩
H
hollis.zhl 已提交
1103
        
1104 1105
        * 结果缓存
        
H
hollis.zhl 已提交
1106 1107 1108 1109 1110 1111 1112 1113
        * Stream并行流
         
        * GC调优
         
        * JVM内存分配调优
         
        * SQL调优
        
1114 1115
    * 线上问题分析
            
H
hollis.zhl 已提交
1116
        * dump
1117 1118 1119
            
            * 线程Dump
            
H
hollis.zhl 已提交
1120
            * 内存Dump
1121
            
H
hollis.zhl 已提交
1122 1123 1124
            * gc情况
      
        * dump获取及分析工具
1125 1126
            
            * jstack
H
hollis.zhl 已提交
1127
            
1128
            * jstat
H
hollis.zhl 已提交
1129
            
1130
            * jmap
H
hollis.zhl 已提交
1131
            
1132
            * jhat
H
hollis.zhl 已提交
1133
            
1134 1135
            * Arthas
            
H
hollis.zhl 已提交
1136 1137 1138 1139
        * dump分析死锁
        
        * dump分析内存泄露
            
1140 1141 1142
        * 自己编写各种outofmemory,stackoverflow程序
            
            * HeapOutOfMemory
H
hollis.zhl 已提交
1143
            
1144
            * Young OutOfMemory
H
hollis.zhl 已提交
1145
            
1146
            * MethodArea OutOfMemory
H
hollis.zhl 已提交
1147
            
1148
            * ConstantPool OutOfMemory
H
hollis.zhl 已提交
1149
            
1150
            * DirectMemory OutOfMemory
H
hollis.zhl 已提交
1151
            
1152 1153 1154 1155 1156
            * Stack OutOfMemory Stack OverFlow
            
        * Arthas
            
            * jvm相关
H
hollis.zhl 已提交
1157
            
1158
            * class/classloader相关
H
hollis.zhl 已提交
1159
            
1160 1161 1162
            * monitor/watch/trace相关
            
            * options
H
hollis.zhl 已提交
1163
            
1164
            * 管道
H
hollis.zhl 已提交
1165
            
1166 1167 1168 1169 1170
            * 后台异步任务
            
        * 常见问题解决思路
            
            * 内存溢出
H
hollis.zhl 已提交
1171
            
1172
            * 线程死锁
H
hollis.zhl 已提交
1173
            
1174 1175
            * 类加载冲突
            
H
hollis.zhl 已提交
1176 1177 1178 1179 1180 1181
            * load飙高
            
            * CPU利用率飙高
            
            * 慢SQL
            
1182 1183 1184 1185 1186 1187 1188 1189 1190 1191 1192 1193 1194 1195 1196 1197 1198 1199 1200 1201 1202 1203 1204 1205 1206 1207 1208 1209 1210
        * 使用工具尝试解决以下问题,并写下总结
            
            * 当一个Java程序响应很慢时如何查找问题
            
            * 当一个Java程序频繁FullGC时如何解决问题
            
            * 如何查看垃圾回收日志
            
            * 当一个Java应用发生OutOfMemory时该如何解决
            
            * 如何判断是否出现死锁
            
            * 如何判断是否存在内存泄露
            
            * 使用Arthas快速排查Spring Boot应用404/401问题
            
            * 使用Arthas排查线上应用日志打满问题
            
            * 利用Arthas排查Spring Boot应用NoSuchMethodError
            
    * 编译原理知识
            
        * 编译与反编译
            
        * Java代码的编译与反编译
            
        * Java的反编译工具
            
            * javap 
H
hollis.zhl 已提交
1211
            
1212
            * jad 
H
hollis.zhl 已提交
1213
            
1214 1215 1216
            * CRF
            
        * 即时编译器
H
hollis.zhl 已提交
1217 1218
        
            * 编译器优化
1219 1220 1221 1222
            
    * 操作系统知识
            
        * Linux的常用命令
H
hollis.zhl 已提交
1223 1224
          
            * find、grep、ps、cp、move、tar、head、tail、netstat、lsof、tree、wget、curl、ping、ssh、echo、free、top
1225 1226
            
        * 进程间通信
H
hollis.zhl 已提交
1227 1228 1229 1230 1231 1232 1233 1234 1235 1236 1237 1238
        
        * 服务器性能指标
          
            * load
          
            * CPU利用率
          
            * 内存使用情况
          
            * qps
          
            * rt
1239 1240 1241 1242
            
        * 进程同步
            
            * 生产者消费者问题
H
hollis.zhl 已提交
1243
            
1244
            * 哲学家就餐问题
H
hollis.zhl 已提交
1245
            
1246 1247 1248 1249 1250 1251 1252 1253 1254 1255 1256 1257 1258 1259 1260 1261 1262 1263 1264
            * 读者写者问题
            
        * 缓冲区溢出
            
        * 分段和分页
            
        * 虚拟内存与主存
            
        * 虚拟内存管理
            
        * 换页算法
            
    * 数据库知识
            
        * MySql 执行引擎
            
        * MySQL 执行计划
            
            * 如何查看执行计划
H
hollis.zhl 已提交
1265
            
1266 1267 1268 1269
            * 如何根据执行计划进行SQL优化
            
        * 索引
            
H
hollis.zhl 已提交
1270 1271 1272 1273 1274
            * Hash索引&B树索引
              
            * 普通索引&唯一索引
              
            * 聚集索引&非聚集索引
1275 1276
            
            * 覆盖索引
H
hollis.zhl 已提交
1277
            
1278
            * 最左前缀原则
H
hollis.zhl 已提交
1279
            
1280 1281
            * 索引下推
            
H
hollis.zhl 已提交
1282 1283 1284 1285
            * 索引失效
            
        * 回表
            
1286 1287 1288 1289
        * SQL优化
            
        * 数据库事务和隔离级别
            
H
hollis.zhl 已提交
1290 1291 1292 1293
            * 事务的ACID
              
            * 事务的隔离级别与读现象
              
1294 1295
            * 事务能不能实现锁的功能
            
H
hollis.zhl 已提交
1296 1297 1298 1299 1300 1301 1302 1303 1304 1305 1306 1307 1308 1309
        * 编码方式
            
            * utf8
            
            * utf8mb4
            
            * 为什么不要在数据库中使用utf8编码
            
        * 行数统计
            
            * count(1)、count(*)、count(字段)的区别
            
            * 为什么建议使用count(*)

1310 1311
        * 数据库锁
            
H
hollis.zhl 已提交
1312 1313 1314 1315 1316 1317
            * 共享锁、排它锁
              
            * 行锁、表锁
              
            * 乐观锁、悲观锁
              
1318
            * 使用数据库锁实现乐观锁
H
hollis.zhl 已提交
1319 1320
              
            * Gap Lock、Next-Key Lock
1321 1322 1323 1324
            
        * 连接
            
            * 内连接
H
hollis.zhl 已提交
1325
            
1326
            * 左连接
H
hollis.zhl 已提交
1327
            
1328 1329 1330
            * 右连接
            
        * 数据库主备搭建
H
hollis.zhl 已提交
1331 1332 1333 1334 1335 1336
        
        * log
        
            * binlog
        
            * redolog
1337 1338 1339 1340 1341 1342 1343 1344 1345 1346 1347 1348
            
        * 内存数据库
            
            * h2
            
        * 分库分表
            
        * 读写分离
            
        * 常用的nosql数据库
            
            * redis
H
hollis.zhl 已提交
1349
            
1350 1351 1352 1353 1354 1355 1356 1357 1358 1359 1360 1361 1362 1363
            * memcached
            
        * 分别使用数据库锁、NoSql实现分布式锁
            
        * 性能调优
            
        * 数据库连接池
            
    * 数据结构与算法知识
            
        * 简单的数据结构
            
            * 栈
            * 队列
H
hollis.zhl 已提交
1364
            
1365
            * 链表
H
hollis.zhl 已提交
1366 1367 1368 1369
            
            * 数组
            
            * 哈希表
1370 1371 1372 1373 1374
            
            * 栈和队列的相同和不同之处
            
            * 栈通常采用的两种存储结构
            
H
hollis.zhl 已提交
1375 1376
            * 两个栈实现队列,和两个队列实现栈
            
1377 1378 1379
        * 树
            
            * 二叉树
H
hollis.zhl 已提交
1380
            
1381
            * 字典树
H
hollis.zhl 已提交
1382
            
1383
            * 平衡树
H
hollis.zhl 已提交
1384
            
1385
            * 排序树
H
hollis.zhl 已提交
1386
            
1387
            * B树
H
hollis.zhl 已提交
1388
            
1389
            * B+树
H
hollis.zhl 已提交
1390
            
1391
            * R树
H
hollis.zhl 已提交
1392
            
1393
            * 多路树
H
hollis.zhl 已提交
1394
            
1395 1396 1397 1398 1399
            * 红黑树
            
        * 堆
            
            * 大根堆
H
hollis.zhl 已提交
1400
            
1401 1402 1403 1404 1405
            * 小根堆
            
        * 图
            
            * 有向图
H
hollis.zhl 已提交
1406
            
1407
            * 无向图
H
hollis.zhl 已提交
1408
            
1409 1410
            * 拓扑
            
H
hollis.zhl 已提交
1411 1412 1413 1414 1415 1416 1417 1418 1419 1420 1421 1422 1423 1424 1425 1426 1427 1428 1429 1430 1431 1432 1433 1434 1435 1436 1437
        * 稳定的排序算法
            * 冒泡排序
            * 插入排序
            * 鸡尾酒排序
            * 桶排序
            * 计数排序
            * 归并排序
            * 原地归并排序
            * 二叉排序树排序
            * 鸽巢排序
            * 基数排序
            * 侏儒排序
            * 图书馆排序
            * 块排序
            
        * 不稳定的排序算法
            * 选择排序
            * 希尔排序
            * Clover排序算法
            * 梳排序
            * 堆排序
            * 平滑排序
            * 快速排序
            * 内省排序
            * 耐心排序
            
        * 各种排序算法和时间复杂度 
1438 1439 1440 1441
            
        * 深度优先和广度优先搜索 
            
        * 全排列
H
hollis.zhl 已提交
1442
        
1443
        * 贪心算法
H
hollis.zhl 已提交
1444
        
1445
        * KMP算法
H
hollis.zhl 已提交
1446
        
1447 1448 1449 1450 1451 1452 1453 1454 1455 1456 1457 1458 1459 1460 1461
        * hash算法
            
        * 海量数据处理
            
            * 分治
            * hash映射
            * 堆排序
            * 双层桶划分
            * Bloom Filter
            * bitmap
            * 数据库索引
            * mapreduce等。
            
    * 大数据知识
            
H
hollis.zhl 已提交
1462 1463 1464
        * 搜索 
        
            * Solr
1465
            
H
hollis.zhl 已提交
1466
            * Lucene
1467
            
H
hollis.zhl 已提交
1468 1469 1470
            * ElasticSearch
        
        * 流式计算
1471
            
H
hollis.zhl 已提交
1472
            * Storm
1473
            
H
hollis.zhl 已提交
1474
            * Spark
1475
            
H
hollis.zhl 已提交
1476
            * Flink
1477 1478 1479 1480
            
        * Hadoop,离线计算
            
            * HDFS
H
hollis.zhl 已提交
1481
            
1482 1483
            * MapReduce
            
H
hollis.zhl 已提交
1484 1485 1486 1487 1488 1489 1490
        * 分布式日志收集
        
            * flume
            
            * kafka
            
            * logstash
1491
            
H
hollis.zhl 已提交
1492 1493 1494
        * 数据挖掘
        
            * mahout
1495 1496 1497 1498 1499 1500 1501 1502 1503 1504 1505 1506 1507 1508 1509 1510 1511 1512 1513 1514 1515 1516 1517 1518
            
    * 网络安全知识
            
        * XSS
            
            * XSS的防御
            
        * CSRF
            
        * 注入攻击
            
            * SQL注入
            * XML注入
            * CRLF注入
            
        * 文件上传漏洞
            
        * 加密与解密
            
            * 对称加密
            * 非对称加密
            * 哈希算法
            * 加盐哈希算法
            
H
hollis.zhl 已提交
1519 1520
        * 加密算法
            
1521 1522
            * MD5,SHA1、DES、AES、RSA、DSA
            
H
hollis.zhl 已提交
1523
        * 彩虹表
1524 1525 1526 1527 1528 1529 1530
            
        * DDOS攻击
            
            * DOS攻击
            * DDOS攻击
            
            * memcached为什么可以导致DDos攻击
H
hollis.zhl 已提交
1531
            
1532 1533 1534 1535 1536 1537
            * 什么是反射型DDoS
            
            * 如何通过Hash碰撞进行DOS攻击
            
        * SSL、TLS,HTTPS
            
H
hollis.zhl 已提交
1538
        * 脱库、洗库、撞库
1539 1540
            
* 架构篇
H
hollis.zhl 已提交
1541 1542 1543 1544 1545 1546 1547 1548 1549 1550 1551 1552 1553

    * 架构设计原则
    
        * 单一职责原则
     
        * 开放封闭原则
     
        * 里氏替代原则
     
        * 依赖倒置原则
     
        * 接口分离原则
        
1554
    * 分布式
H
hollis.zhl 已提交
1555
        
1556
        * 分布式理论
H
hollis.zhl 已提交
1557
            
1558
            * 2PC
H
hollis.zhl 已提交
1559
            
1560
            * 3PC
H
hollis.zhl 已提交
1561
            
1562
            * CAP
H
hollis.zhl 已提交
1563
            
1564 1565
            * BASE
            
H
hollis.zhl 已提交
1566 1567 1568 1569 1570 1571 1572 1573 1574 1575
        * 分布式协调 Zookeeper
        
            * 基本概念
        
            * 常见用法
        
            * ZAB算法
        
            * 脑裂
        
1576
        * 分布式事务
H
hollis.zhl 已提交
1577 1578
            * 本地事务&分布式事务
            
1579
            * 可靠消息最终一致性
H
hollis.zhl 已提交
1580
            
1581 1582
            * 最大努力通知
            
H
hollis.zhl 已提交
1583 1584
            * TCC
                
1585 1586 1587 1588 1589
        * Dubbo
            
            * 服务注册
            * 服务发现
            * 服务治理
H
hollis.zhl 已提交
1590
                
1591 1592 1593
        * 分布式数据库
            
            * 怎样打造一个分布式数据库
H
hollis.zhl 已提交
1594
            
1595
            * 什么时候需要分布式数据库
H
hollis.zhl 已提交
1596
            
1597
            * mycat
H
hollis.zhl 已提交
1598
            
1599 1600
            * otter
            
H
hollis.zhl 已提交
1601 1602
            * HBase
                
1603 1604 1605 1606
        * 分布式文件系统
            
            * mfs
            * fastdfs
H
hollis.zhl 已提交
1607
                
1608 1609 1610 1611 1612
        * 分布式缓存
            
            * 缓存一致性
            * 缓存命中率
            * 缓存冗余
H
hollis.zhl 已提交
1613
        
1614
        * 限流降级
H
hollis.zhl 已提交
1615 1616
        
            * 熔断器模式
1617 1618
            
            * Hystrix
H
hollis.zhl 已提交
1619
            
1620 1621
            * Sentinal
            
H
hollis.zhl 已提交
1622 1623 1624
            * resilience4j
            
        * 分布式算法
1625 1626 1627 1628
            
            * 拜占庭问题与算法
            
            * 2PC
H
hollis.zhl 已提交
1629
            
1630 1631
            * 3PC
            
H
hollis.zhl 已提交
1632 1633 1634 1635 1636 1637 1638 1639 1640 1641 1642 1643 1644 1645 1646 1647 1648 1649 1650
            * 共识算法
            
            * Paxos 算法与 Raft 算法
            
            * ZAB算法
            
    * 领域驱动设计
    
        * 实体、值对象
        
        * 聚合、聚合根
        
        * 限界上下文
        
        * DDD如何分层
        
        * 充血模型和贫血模型
        
        * DDD和微服务有什么关系
1651 1652 1653
    * 微服务
            
       * SOA
H
hollis.zhl 已提交
1654
       
1655 1656 1657 1658 1659 1660 1661 1662 1663 1664 1665 1666 1667 1668 1669
       * 康威定律
            
       * ServiceMesh
            
          * sidecar
            
       * Docker & Kubernets
            
       * Spring Boot
            
       * Spring Cloud
            
    * 高并发
            
        * 分库分表
H
hollis.zhl 已提交
1670 1671
        
            * 横向拆分与水平拆分
1672
            
H
hollis.zhl 已提交
1673 1674
            * 分库分表后的分布式事务问题

1675 1676 1677 1678
        * CDN技术
            
        * 消息队列
            
H
hollis.zhl 已提交
1679 1680 1681
            * RabbitMQ、RocketMQ、ActiveMQ、Kafka  

            * 各个消息队列的对比
1682
            
H
hollis.zhl 已提交
1683 1684 1685 1686 1687 1688 1689 1690 1691 1692 1693 1694 1695 1696 1697 1698 1699 1700 1701 1702 1703 1704 1705 1706 1707 1708 1709 1710 1711 1712 1713 1714
    * 高可用
    
        *  双机架构
    
            * 主备复制
    
            * 主从复制
    
            * 主主复制
    
        * 异地多活
    
    * 高性能
    
        * 高性能数据库
    
            * 读写分离
    
            * 分库分表
    
        * 高性能缓存
    
            * 缓存穿透
    
            * 缓存雪崩
    
            * 缓存热点
    
        * 负载均衡
    
        * PPC、TPC

1715 1716 1717 1718 1719
    * 监控
            
        * 监控什么
            
            * CPU
H
hollis.zhl 已提交
1720
            
1721
            * 内存
H
hollis.zhl 已提交
1722
            
1723
            * 磁盘I/O
H
hollis.zhl 已提交
1724 1725
            
            * 网络I/O
1726 1727 1728 1729
            
        * 监控手段
            
            * 进程监控
H
hollis.zhl 已提交
1730
            
1731
            * 语义监控
H
hollis.zhl 已提交
1732
            
1733
            * 机器资源监控
H
hollis.zhl 已提交
1734
            
1735 1736 1737 1738 1739 1740 1741 1742 1743 1744
            * 数据波动
            
        * 监控数据采集
            
            * 日志
            * 埋点
            
        * Dapper
            
    * 负载均衡
H
hollis.zhl 已提交
1745 1746 1747 1748 1749 1750 1751 1752 1753 1754 1755 1756 1757 1758 1759 1760 1761 1762
    
        * 负载均衡分类
        
            * 二层负载均衡
        
            * 三层负载均衡
        
            * 四层负载均衡
        
            * 七层负载均衡
            
        * 负载均衡工具
        
            * LVS
        
            * Nginx
        
            * HAProxy
1763
            
H
hollis.zhl 已提交
1764 1765 1766
        * 负载均衡算法
        
            * 静态负载均衡算法:轮询,比率,优先权
1767
        
H
hollis.zhl 已提交
1768
            * 动态负载均衡算法: 最少连接数,最快响应速度,观察方法,预测法,动态性能分配,动态服务器补充,服务质量,服务类型,规则模式。
1769 1770 1771 1772
            
    * DNS
            
        * DNS原理
H
hollis.zhl 已提交
1773
        
1774 1775 1776 1777 1778 1779 1780 1781 1782 1783 1784
        * DNS的设计
            
    * CDN
            
        * 数据一致性
            
* 扩展篇
            
    * 云计算
            
        * IaaS
H
hollis.zhl 已提交
1785
        
1786
        * SaaS
H
hollis.zhl 已提交
1787
        
1788
        * PaaS
H
hollis.zhl 已提交
1789
        
1790
        * 虚拟化技术
H
hollis.zhl 已提交
1791
        
1792
        * openstack
H
hollis.zhl 已提交
1793
        
1794 1795 1796 1797 1798
        * Serverlsess
            
    * 搜索引擎
            
        * Solr
H
hollis.zhl 已提交
1799
        
1800
        * Lucene
H
hollis.zhl 已提交
1801
        
1802
        * Nutch
H
hollis.zhl 已提交
1803
        
1804 1805 1806 1807 1808 1809 1810 1811 1812 1813 1814 1815 1816 1817 1818 1819 1820 1821 1822 1823 1824 1825 1826 1827 1828 1829 1830 1831
        * Elasticsearch
            
    * 权限管理
            
        * Shiro
            
    * 区块链
            
        * 哈希算法
        * Merkle树
        * 公钥密码算法
        * 共识算法
        * Raft协议
        * Paxos 算法与 Raft 算法
        * 拜占庭问题与算法
        * 消息认证码与数字签名
            
        * 比特币
            
           * 挖矿
           * 共识机制
           * 闪电网络
           * 侧链
           * 热点问题
           * 分叉
            
        * 以太坊
            
H
hollis.zhl 已提交
1832
           * 超级账本
1833 1834 1835 1836 1837 1838 1839 1840 1841 1842 1843 1844 1845 1846 1847 1848 1849 1850 1851 1852 1853 1854 1855
            
    * 人工智能
            
        * 数学基础
        * 机器学习
        * 人工神经网络
        * 深度学习
        * 应用场景
            
        * 常用框架
            
            * TensorFlow
            * DeepLearning4J
            
    * IoT
            
    * 量子计算
            
    * AR & VR
            
    * 其他语言
            
        * Groovy
H
hollis.zhl 已提交
1856
        
1857
        * Kotlin
H
hollis.zhl 已提交
1858
        
1859
        * Python
H
hollis.zhl 已提交
1860
        
1861
        * Go
H
hollis.zhl 已提交
1862
        
1863
        * NodeJs
H
hollis.zhl 已提交
1864
        
1865
        * Swift
H
hollis.zhl 已提交
1866 1867
        
        * Rust