_sidebar.md 45.1 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的继承与实现](/basics/object-oriented/extends-implement.md)
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)](/basics/java-basic/success-isSuccess-and-bollean-Bollean.md)
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
            * [时间戳](/basics/java-basic/timestamp.md)
H
hollis.zhl 已提交
317
            
318 319 320
            * Java中时间API
            
            * [格林威治时间](/basics/java-basic/GMT.md)
H
hollis.zhl 已提交
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 346
            * [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 已提交
347
            
348 349 350 351 352 353 354 355 356 357
            * [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 已提交
358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373
        * JMS
            
            * 什么是Java消息服务
            
            * JMS消息传送模型
            
        * JMX
            
            * java.lang.management.* 
            
            * javax.management.*
            
        * Java 8
            
            * lambda表达式
            
H
hollis.zhl 已提交
374
            * [Stream API](/basics/java-basic/stream.md)
H
hollis.zhl 已提交
375 376 377
            
            * 时间API
            
378 379 380
        * 阅读源代码
            
            * String
H
hollis.zhl 已提交
381
            
382
            * Integer
H
hollis.zhl 已提交
383
            
384
            * Long
H
hollis.zhl 已提交
385
            
386
            * Enum
H
hollis.zhl 已提交
387
            
388
            * BigDecimal
H
hollis.zhl 已提交
389
            
390
            * ThreadLocal
H
hollis.zhl 已提交
391
            
392
            * ClassLoader & URLClassLoader
H
hollis.zhl 已提交
393
            
394
            * ArrayList & LinkedList
H
hollis.zhl 已提交
395
            
396
            * HashMap & LinkedHashMap & TreeMap & CouncurrentHashMap
H
hollis.zhl 已提交
397
            
398 399 400 401 402 403 404 405 406 407 408 409 410
            * HashSet & LinkedHashSet & TreeSet
            
    * Java并发编程
            
        * 并发与并行
            
            * [什么是并发](/basics/concurrent-coding/concurrent.md)
            
            * [什么是并行](/basics/concurrent-coding/parallel.md)
            
            * [并发与并行的区别](/basics/concurrent-coding/concurrent-vs-parallel.md)
            
        * 线程
H
hollis.zhl 已提交
411 412
        
            * 线程与进程的区别
413 414
            
            * 线程的实现
H
hollis.zhl 已提交
415
            
416
            * 线程的状态
H
hollis.zhl 已提交
417
            
418
            * 线程优先级
H
hollis.zhl 已提交
419
            
420
            * 线程调度
H
hollis.zhl 已提交
421 422 423
            
            * 多线程如何Debug
            
424
            * 守护线程
H
hollis.zhl 已提交
425 426 427 428 429 430 431 432 433 434
            
        * 创建线程的多种方式
            
            * 继承Thread类创建线程
            
            * 实现Runnable接口创建线程
            
            * 通过Callable和FutureTask创建线程
            
            * 通过线程池创建线程
435 436 437 438
            
        * 线程池
            
            * 自己设计线程池
H
hollis.zhl 已提交
439
            
440
            * submit() 和 execute()
H
hollis.zhl 已提交
441
            
442
            * 线程池原理
H
hollis.zhl 已提交
443
            
444 445 446
            * 为什么不允许使用Executors创建线程池
            
        * 线程安全
H
hollis.zhl 已提交
447 448 449 450 451 452 453 454
        
            * 什么是线程安全
            
            * 多级缓存和一致性问题
            
            * CPU时间片和原子性问题
            
            * 指令重排和有序性问题
455 456 457
            
            * 线程安全和内存模型的关系
            
H
hollis.zhl 已提交
458
            * happens-before
459
            
H
hollis.zhl 已提交
460 461 462 463 464 465 466 467
            * as-if-serial
            
        * 锁
        
            * 可重入锁
        
            * 阻塞锁
        
468
            * 乐观锁与悲观锁
H
hollis.zhl 已提交
469
        
470
            * 数据库相关锁机制
H
hollis.zhl 已提交
471
        
472
            * 分布式锁
H
hollis.zhl 已提交
473 474 475 476 477 478 479 480 481
            
        * 无锁
        
            * CAS
        
            * CAS的ABA问题
    
        * 锁优化
        
482
            * 偏向锁
H
hollis.zhl 已提交
483
        
484
            * 轻量级锁
H
hollis.zhl 已提交
485
        
486
            * 重量级锁
H
hollis.zhl 已提交
487
        
488
            * 锁消除
H
hollis.zhl 已提交
489
        
490
            * 锁粗化
H
hollis.zhl 已提交
491
        
492 493 494
            * 自旋锁
            
        * 死锁
H
hollis.zhl 已提交
495 496 497
        
            * [什么是死锁](/basics/concurrent-coding/deadlock-java-level.md)
        
498
            * 死锁的原因
H
hollis.zhl 已提交
499 500 501 502 503 504 505
        
            * 如何避免死锁
        
            * 写一个死锁的程序
        
            * 死锁问题如何排查
    
506 507 508 509 510
        * synchronized
            
            * [synchronized是如何实现的?](/basics/concurrent-coding/synchronized.md)
            
            * synchronized和lock之间关系
H
hollis.zhl 已提交
511
            
512 513
            * 不使用synchronized如何实现一个线程安全的单例
            
H
hollis.zhl 已提交
514
            * synchronized和原子性
515
            
H
hollis.zhl 已提交
516 517 518 519 520 521
            * synchronized和可见性
            
            * synchronized和有序性
            
        * volatile
        
522 523 524 525
            * 编译器指令重排和CPU指令重排
            
            * volatile的实现原理
            
H
hollis.zhl 已提交
526 527
            * 内存屏障
            
528 529
            * volatile和原子性
            
H
hollis.zhl 已提交
530 531 532
            * volatile和可见性
            
            * volatile和有序性
533
            
H
hollis.zhl 已提交
534
            * 有了symchronized为什么还需要volatile
535
            
H
hollis.zhl 已提交
536 537 538 539 540
        * 线程相关方法
        
            * start & run
        
            * sleep 和 wait
541
            
H
hollis.zhl 已提交
542
            * notify & notifyAll
543 544
            
        * ThreadLocal
H
hollis.zhl 已提交
545 546
        
            * ThreadLocal 原理
547
            
H
hollis.zhl 已提交
548
            * ThreadLocal 底层的数据结构
549 550 551
            
        * 写代码来解决生产者消费者问题
            
H
hollis.zhl 已提交
552
        * 并发包
553
            
H
hollis.zhl 已提交
554
            * 同步容器与并发容器
555 556
            
            * Thread
H
hollis.zhl 已提交
557
            
558
            * Runnable
H
hollis.zhl 已提交
559
            
560
            * Callable
H
hollis.zhl 已提交
561
            
562
            * ReentrantLock
H
hollis.zhl 已提交
563
            
564
            * ReentrantReadWriteLock
H
hollis.zhl 已提交
565
            
566
            * Atomic*
H
hollis.zhl 已提交
567
            
568
            * Semaphore
H
hollis.zhl 已提交
569
            
570
            * CountDownLatch
H
hollis.zhl 已提交
571
            
572
            * ConcurrentHashMap
H
hollis.zhl 已提交
573
            
574 575 576 577 578 579 580 581 582 583
            * Executors
            
* 底层篇
            
     * JVM
            
        * JVM内存结构
            
            * 运行时数据区
            
H
hollis.zhl 已提交
584
            * 运行时数据区哪些是线程独享
585
            
H
hollis.zhl 已提交
586
            * 堆和栈区别
587
            
H
hollis.zhl 已提交
588
            * 方法区在不同版本JDK中的位置
589
            
H
hollis.zhl 已提交
590 591 592 593 594
            * 堆外内存
              
            * TLAB
              
            * [Java中的对象一定在堆上分配吗?](/basement/jvm/stack-alloc.md)
595 596 597 598 599 600
            
        * 垃圾回收
            
            * GC算法:标记清除、引用计数、复制、标记压缩、分代回收、增量式回收
            
            * GC参数
H
hollis.zhl 已提交
601
            
602
            * 对象存活的判定
H
hollis.zhl 已提交
603
            
604 605 606
            * 垃圾收集器(CMS、G1、ZGC、Epsilon)
            
        * JVM参数及调优
H
hollis.zhl 已提交
607
                    
608
            * -Xmx
H
hollis.zhl 已提交
609
            
610
            * -Xmn
H
hollis.zhl 已提交
611
            
612
            * -Xms
H
hollis.zhl 已提交
613 614 615
            
            * -Xss
            
616 617 618
            * -XX:SurvivorRatio
            
            * -XX:PermSize
H
hollis.zhl 已提交
619
            
620 621
            * -XX:MaxPermSize
            
H
hollis.zhl 已提交
622 623
            * -XX:MaxTenuringThreshold
                    
624 625 626
        * Java对象模型
            
            * oop-klass
H
hollis.zhl 已提交
627
            
628 629 630 631 632
            * 对象头
            
        * HotSpot
            
            * 即时编译器
H
hollis.zhl 已提交
633
            
634 635
            * 编译优化
            
H
hollis.zhl 已提交
636
        * Java内存模型
637
            
H
hollis.zhl 已提交
638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660
            * 计算机内存模型
            
            * 缓存一致性
            
            * MESI协议
            
            * 可见性
            
            * 原子性
            
            * 顺序性
            
            * happens-before
            
            * as-if-serial
            
            * 内存屏障
            
            * synchronized
            
            * volatile
            
            * final
661
            
H
hollis.zhl 已提交
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 690
            *

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

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

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

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

            * 各个消息队列的对比
1683
            
H
hollis.zhl 已提交
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 1715
    * 高可用
    
        *  双机架构
    
            * 主备复制
    
            * 主从复制
    
            * 主主复制
    
        * 异地多活
    
    * 高性能
    
        * 高性能数据库
    
            * 读写分离
    
            * 分库分表
    
        * 高性能缓存
    
            * 缓存穿透
    
            * 缓存雪崩
    
            * 缓存热点
    
        * 负载均衡
    
        * PPC、TPC

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