2018-03-24 10:08:46 +08:00
|
|
|
|
<!-- ![](https://img.shields.io/badge/update-today-blue.svg) ![](https://img.shields.io/badge/gitbook-making-lightgrey.svg)</br> -->
|
2018-03-28 10:01:26 +08:00
|
|
|
|
| Ⅰ | Ⅱ | Ⅲ | Ⅳ | Ⅴ | Ⅵ | Ⅶ | Ⅷ | Ⅸ | Ⅹ |
|
|
|
|
|
| :--------: | :---------: | :---------: | :---------: | :---------: | :---------:| :---------: | :-------: | :-------:| :------:|
|
2018-04-15 15:56:15 +08:00
|
|
|
|
| 算法[:pencil2:](#算法-pencil2) | 操作系统[:computer:](#操作系统-computer)|网络[:cloud:](#网络-cloud) | 面向对象[:couple:](#面向对象-couple) |数据库[:floppy_disk:](#数据库-floppy_disk)| Java [:coffee:](#java-coffee)| 分布式[:sweat_drops:](#分布式-sweat_drops)| 工具[:hammer:](#工具-hammer)| 编码实践[:speak_no_evil:](#编码实践-speak_no_evil)| 后记[:memo:](#后记-memo) |
|
2018-03-28 14:38:57 +08:00
|
|
|
|
|
2018-04-15 15:56:15 +08:00
|
|
|
|
## 算法 :pencil2:
|
2018-02-20 10:40:05 +08:00
|
|
|
|
|
2018-04-15 15:41:54 +08:00
|
|
|
|
> [剑指 Offer 题解](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/剑指%20offer%20题解.md)
|
2018-02-20 10:40:05 +08:00
|
|
|
|
|
2018-04-15 15:41:54 +08:00
|
|
|
|
《剑指 Offer 第二版》的最优解,在牛客网在线编程中出现的题目都已 AC。
|
|
|
|
|
|
|
|
|
|
> [Leetcode 题解](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/Leetcode%20题解.md)
|
|
|
|
|
|
|
|
|
|
对题目做了一个分类,并对每种题型的解题思路做了总结。
|
2018-02-20 10:40:05 +08:00
|
|
|
|
|
2018-04-15 15:56:15 +08:00
|
|
|
|
> [算法](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/算法.md)
|
|
|
|
|
|
2018-06-08 14:44:24 +08:00
|
|
|
|
整理自《算法 第四版》与《数据结构与算法分析》
|
2018-04-15 15:56:15 +08:00
|
|
|
|
|
2018-03-07 09:01:15 +08:00
|
|
|
|
## 操作系统 :computer:
|
2018-02-20 10:40:05 +08:00
|
|
|
|
|
|
|
|
|
> [计算机操作系统](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/计算机操作系统.md)
|
|
|
|
|
|
2018-02-28 09:57:26 +08:00
|
|
|
|
整理自《现代操作系统》和《计算机操作系统》
|
2018-02-20 10:40:05 +08:00
|
|
|
|
|
|
|
|
|
> [Linux](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/Linux.md)
|
|
|
|
|
|
|
|
|
|
整理自《鸟哥的 Linux 私房菜》
|
|
|
|
|
|
2018-04-15 15:41:54 +08:00
|
|
|
|
## 网络 :cloud:
|
2018-03-01 22:57:56 +08:00
|
|
|
|
|
2018-04-15 15:41:54 +08:00
|
|
|
|
> [计算机网络](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/计算机网络.md)
|
2018-03-01 22:57:56 +08:00
|
|
|
|
|
2018-06-08 14:44:24 +08:00
|
|
|
|
整理自《计算机网络 第七版》与《计算机网络 自顶向下方法》
|
2018-03-01 22:57:56 +08:00
|
|
|
|
|
2018-04-15 15:41:54 +08:00
|
|
|
|
> [HTTP](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/HTTP.md)
|
2018-03-01 22:57:56 +08:00
|
|
|
|
|
2018-04-15 15:41:54 +08:00
|
|
|
|
整理自《图解 HTTP》
|
2018-03-01 22:57:56 +08:00
|
|
|
|
|
2018-05-27 14:29:16 +08:00
|
|
|
|
> [Socket](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/Socket.md)
|
|
|
|
|
|
|
|
|
|
整理自《Unix 网络编程》
|
|
|
|
|
|
2018-03-07 09:01:15 +08:00
|
|
|
|
## 面向对象 :couple:
|
2018-02-20 10:40:05 +08:00
|
|
|
|
|
|
|
|
|
> [设计模式](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/设计模式.md)
|
|
|
|
|
|
2018-06-08 14:44:24 +08:00
|
|
|
|
整理自《Head First 设计模式》与《设计模式 可复用面向对象软件的基础》
|
2018-02-20 10:40:05 +08:00
|
|
|
|
|
|
|
|
|
> [面向对象思想](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/面向对象思想.md)
|
|
|
|
|
|
2018-06-08 14:44:24 +08:00
|
|
|
|
面向对象三个原则,类图,设计原则
|
2018-02-20 10:40:05 +08:00
|
|
|
|
|
2018-03-07 09:01:15 +08:00
|
|
|
|
## 数据库 :floppy_disk:
|
2018-02-20 10:40:05 +08:00
|
|
|
|
|
2018-03-08 15:26:36 +08:00
|
|
|
|
> [数据库系统原理](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/数据库系统原理.md)
|
|
|
|
|
|
2018-06-08 14:44:24 +08:00
|
|
|
|
整理自《数据库系统原理》
|
2018-03-08 15:26:36 +08:00
|
|
|
|
|
2018-03-14 17:17:27 +08:00
|
|
|
|
> [SQL](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/SQL.md)
|
2018-02-20 10:40:05 +08:00
|
|
|
|
|
2018-02-28 09:57:26 +08:00
|
|
|
|
整理自《SQL 必知必会》
|
2018-02-20 10:40:05 +08:00
|
|
|
|
|
2018-05-11 23:04:12 +08:00
|
|
|
|
> [Leetcode-Database 题解](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/Leetcode-Database%20题解.md)
|
2018-05-11 22:59:16 +08:00
|
|
|
|
|
2018-06-08 14:44:24 +08:00
|
|
|
|
Leetcode 上数据库题目的解题记录
|
2018-05-11 22:59:16 +08:00
|
|
|
|
|
2018-02-20 10:40:05 +08:00
|
|
|
|
> [MySQL](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/MySQL.md)
|
|
|
|
|
|
2018-03-19 10:49:02 +08:00
|
|
|
|
整理自《高性能 MySQL》
|
2018-02-20 10:40:05 +08:00
|
|
|
|
|
2018-03-14 16:55:01 +08:00
|
|
|
|
> [Redis](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/Redis.md)
|
|
|
|
|
|
2018-03-14 16:57:33 +08:00
|
|
|
|
整理自《Redis 设计与实现》和《Redis 实战》
|
|
|
|
|
|
2018-03-07 09:01:15 +08:00
|
|
|
|
## Java :coffee:
|
2018-02-20 10:40:05 +08:00
|
|
|
|
|
2018-05-20 20:42:51 +08:00
|
|
|
|
> [Java 基础](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/Java%20基础.md)
|
|
|
|
|
|
2018-06-08 14:44:24 +08:00
|
|
|
|
整理了一些常见知识点
|
2018-05-20 20:42:51 +08:00
|
|
|
|
|
2018-03-22 23:03:20 +08:00
|
|
|
|
> [Java 虚拟机](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/Java%20虚拟机.md)
|
2018-02-20 10:40:05 +08:00
|
|
|
|
|
2018-03-19 10:49:02 +08:00
|
|
|
|
整理自《深入理解 Java 虚拟机》
|
2018-03-05 14:48:04 +08:00
|
|
|
|
|
|
|
|
|
> [Java 并发](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/Java%20并发.md)
|
|
|
|
|
|
2018-05-27 14:29:16 +08:00
|
|
|
|
整理了一些并发的基本概念。
|
2018-02-20 10:40:05 +08:00
|
|
|
|
|
2018-02-21 23:28:33 +08:00
|
|
|
|
> [Java 容器](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/Java%20容器.md)
|
2018-02-21 21:04:17 +08:00
|
|
|
|
|
2018-02-21 21:16:38 +08:00
|
|
|
|
容器的一些总结,包含容器源码的分析。
|
2018-02-21 21:04:17 +08:00
|
|
|
|
|
2018-03-22 22:54:48 +08:00
|
|
|
|
> [Java I/O](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/Java%20IO.md)
|
2018-02-20 10:40:05 +08:00
|
|
|
|
|
2018-06-08 14:44:24 +08:00
|
|
|
|
重点是 NIO
|
2018-02-20 10:40:05 +08:00
|
|
|
|
|
2018-03-15 15:05:44 +08:00
|
|
|
|
## 分布式 :sweat_drops:
|
|
|
|
|
|
|
|
|
|
> [分布式基础](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/分布式基础.md)
|
|
|
|
|
|
|
|
|
|
整理自《大规模分布式存储系统》
|
|
|
|
|
|
2018-03-16 20:22:54 +08:00
|
|
|
|
> [分布式问题分析](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/分布式问题分析.md)
|
2018-03-16 20:21:56 +08:00
|
|
|
|
|
2018-04-02 20:42:18 +08:00
|
|
|
|
分布式事务、负载均衡算法与实现、分布式锁、分布式 Session、分库分表的分布式困境与应对之策。
|
2018-03-16 20:21:56 +08:00
|
|
|
|
|
2018-03-13 10:00:39 +08:00
|
|
|
|
## 工具 :hammer:
|
|
|
|
|
|
2018-03-13 10:01:56 +08:00
|
|
|
|
> [Git](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/Git.md)
|
2018-03-13 10:00:39 +08:00
|
|
|
|
|
2018-06-08 14:44:24 +08:00
|
|
|
|
整理一些 Git 的使用和概念
|
2018-03-13 10:00:39 +08:00
|
|
|
|
|
|
|
|
|
> [正则表达式](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/正则表达式.md)
|
|
|
|
|
|
|
|
|
|
整理自《正则表达式必知必会》
|
|
|
|
|
|
2018-03-13 10:04:37 +08:00
|
|
|
|
## 编码实践 :speak_no_evil:
|
2018-02-22 01:06:40 +08:00
|
|
|
|
|
|
|
|
|
> [重构](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/重构.md)
|
|
|
|
|
|
2018-02-22 01:18:15 +08:00
|
|
|
|
重构是对软件内部结构的一种调整,目的是在不改变软件可观察行为的前提下,提高其可理解性,降低其修改成本。
|
2018-02-22 01:06:40 +08:00
|
|
|
|
|
2018-02-27 21:13:55 +08:00
|
|
|
|
> [代码可读性](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/代码可读性.md)
|
2018-02-22 01:06:40 +08:00
|
|
|
|
|
2018-02-22 01:18:15 +08:00
|
|
|
|
编程有很大一部分时间是在阅读代码,可读性良好的代码能够大大提高编程效率。
|
2018-02-22 01:06:40 +08:00
|
|
|
|
|
2018-02-27 21:25:45 +08:00
|
|
|
|
> [代码风格规范](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/代码风格规范.md)
|
|
|
|
|
|
|
|
|
|
Google 开源项目的代码风格规范。
|
|
|
|
|
|
2018-03-07 09:01:15 +08:00
|
|
|
|
## 后记 :memo:
|
2018-02-20 10:40:05 +08:00
|
|
|
|
|
2018-03-25 16:32:29 +08:00
|
|
|
|
**关于仓库**
|
2018-03-25 09:57:11 +08:00
|
|
|
|
|
2018-06-11 08:19:08 +08:00
|
|
|
|
笔者在学习的过程中有做笔记的习惯,一方面是为了更深入的理解,另一方面是因为不习惯一些书籍文章的语言描述和排版风格。
|
|
|
|
|
|
|
|
|
|
[BOOKLIST](https://github.com/CyC2018/Interview-Notebook/blob/master/BOOKLIST.md),这个书单是笔者至今看的一些比较好的技术书籍,虽然没有全都翻完,但是每本书多多少少都看过一部分。
|
|
|
|
|
|
|
|
|
|
这个仓库算是笔者的一个学习笔记,主要记录一些比较重要的知识点,希望对大家有所帮助。
|
2018-03-25 09:57:11 +08:00
|
|
|
|
|
2018-06-12 14:46:22 +08:00
|
|
|
|
笔记并不是从网上到处复制粘贴拼凑而来,虽然少部分内容会直接引入书上原文或者官方技术文档的原文,但是没有直接摘抄其他人的博客文章,只做了一点参考,参考的文章会在最后给出链接。
|
2018-03-25 09:57:11 +08:00
|
|
|
|
|
2018-06-12 14:46:22 +08:00
|
|
|
|
**如何贡献**
|
2018-03-25 09:57:11 +08:00
|
|
|
|
|
2018-06-12 14:46:22 +08:00
|
|
|
|
笔记内容是笔者一个字一个字打上去的,难免会有一些笔误,如果发现笔误可直接在相应文档进行编辑修改。
|
2018-03-25 09:57:11 +08:00
|
|
|
|
|
2018-06-12 14:46:22 +08:00
|
|
|
|
**授权相关**
|
2018-03-25 09:57:11 +08:00
|
|
|
|
|
2018-06-12 14:46:22 +08:00
|
|
|
|
虽然没有加开源协议,但是默认允许非商业使用。网上已经有蛮多博客文章使用了本仓库的内容,但是都申明为原创文章,而且最后也没有给出参考链接。请注明出处,谢谢。
|
|
|
|
|
|
|
|
|
|
本仓库内容使用到的资料都会在最后面的参考资料中给出引用链接,希望您在使用本仓库的内容时也能给出相应的引用链接。
|
2018-03-25 09:57:11 +08:00
|
|
|
|
|
2018-03-25 16:32:29 +08:00
|
|
|
|
**关于上传**
|
2018-03-25 09:57:11 +08:00
|
|
|
|
|
|
|
|
|
笔者在本地使用为知笔记软件进行书写,为了方便将本地笔记内容上传到 Github 上,实现了一整套自动化上传方案,包括文本文件的导出、提取图片、Markdown 文档转换、Git 同步。
|
|
|
|
|
|
2018-03-25 16:36:32 +08:00
|
|
|
|
进行 Markdown 文档转换是因为 Github 使用的 GFM 不支持 MathJax 公式和 TOC 标记,所以需要替换 MathJax 公式为 CodeCogs 的云服务和重新生成 TOC 目录。这里提供了笔者实现的 GFM 文档转换工具的下载:[GFM-Converter](https://github.com/CyC2018/GFM-Converter)。
|
2018-03-25 09:57:11 +08:00
|
|
|
|
|
2018-03-25 16:32:29 +08:00
|
|
|
|
**关于排版**
|
2018-03-25 09:57:11 +08:00
|
|
|
|
|
2018-04-26 14:57:40 +08:00
|
|
|
|
笔记内容按照 [中文文案排版指北](http://mazhuang.org/wiki/chinese-copywriting-guidelines/) 进行排版,以保证内容的可读性。这里提供了笔者实现的中英混排文档在线排版工具:[Text-Typesetting](https://github.com/CyC2018/Markdown-Typesetting),目前实现了加空格的功能,之后打算实现对英文专有名词提示首字母大写的功能。
|
2018-03-09 12:52:38 +08:00
|
|
|
|
|
2018-03-25 16:36:32 +08:00
|
|
|
|
不使用 `![]()` 这种方式来引用图片是为了能够控制图片以合适的大小显示。而且 GFM 不支持 `<center> ![]() </center>` 让图片居中显示,只能使用 `<div align="center"> <img src=""/> </div>` ,所以只能使用 img 标签来引用图片。
|
2018-03-09 15:34:38 +08:00
|
|
|
|
|
2018-03-10 22:59:36 +08:00
|
|
|
|
|
2018-03-28 21:56:14 +08:00
|
|
|
|
|
2018-06-11 09:38:42 +08:00
|
|
|
|
**声明**
|
|
|
|
|
|
|
|
|
|
本仓库不参与商业行为,不向读者收取任何费用。(This repository is not engaging in business activities, and does not charge readers any fee.)
|
|
|
|
|
|
2018-03-28 21:56:14 +08:00
|
|
|
|
**鸣谢**
|
|
|
|
|
|
|
|
|
|
[TeeKee](https://github.com/linw7)
|
|
|
|
|
|
|
|
|
|
|