CS-Notes/README.md

176 lines
7.7 KiB
Markdown
Raw Normal View History

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 19:41:32 +08:00
2018-04-24 12:23:03 +08:00
本仓库不参与商业行为,不向读者收取任何费用。(This repository is not engaging in business activities, and does not charge readers any fee.)
2018-04-22 16:26:16 +08:00
</br>
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-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-03-01 22:57:56 +08:00
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-04-15 15:41:54 +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-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-02-28 09:57:26 +08:00
整理自《Head First 设计模式》
2018-02-20 10:40:05 +08:00
> [面向对象思想](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/面向对象思想.md)
2018-03-19 10:49:02 +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-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
> [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-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-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-03-10 15:15:30 +08:00
File, InputStream OutputStream, Reader Writer, Serializable, Socket, NIO
2018-02-20 10:40:05 +08:00
2018-02-28 21:29:27 +08:00
> [Java 基础](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/Java%20基础.md)
2018-02-28 22:12:22 +08:00
整理了一些常见考点。
2018-02-28 21:29:27 +08:00
2018-03-18 21:52:08 +08:00
> [JDK 中的设计模式](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/JDK%20中的设计模式.md)
对每种设计模式做了一个总结,并给出在 JDK 中的使用实例。
2018-03-15 15:05:44 +08:00
## 分布式 :sweat_drops:
> [分布式基础](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/分布式基础.md)
整理自《大规模分布式存储系统》
2018-03-15 21:34:28 +08:00
> [一致性协议](https://github.com/CyC2018/InnterviewNotes/blob/master/notes/一致性协议.md)
2018-03-15 21:35:11 +08:00
两阶段提交、Paxos、Raft、拜占庭将军问题。
2018-03-15 21:34:28 +08:00
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
分布式事务、负载均衡算法与实现、分布式锁、分布式 Session、分库分表的分布式困境与应对之策。
2018-03-16 20:21:56 +08:00
2018-04-02 21:07:28 +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
整理一些 Git 的使用和概念。
> [正则表达式](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 年春招实习过程中的学习总结,内容以计算机书籍的学习笔记为主,在整理重点知识的同时会尽量保证知识的系统性。
2018-03-25 16:32:29 +08:00
**关于贡献**
2018-03-25 09:57:11 +08:00
2018-04-26 14:56:45 +08:00
因为大部分内容是笔者一个字一个字打上去的,所以难免会有一些笔误。如果发现,可以直接在相应的文档上编辑修改。
2018-03-25 09:57:11 +08:00
2018-04-26 14:56:45 +08:00
笔者能力有限,很多内容还不够完善。如果您希望和笔者一起完善这个仓库,可以发表一个 Issue表明您想要添加的内容笔者会及时查看。
2018-03-25 09:57:11 +08:00
2018-03-25 16:36:32 +08:00
因为不打算将这个仓库做成一个大而全的面试宝典,只希望添加一些比较通用的基础知识,或者是与 Java 和分布式相关的内容,但是不添加 Java Web 相关的内容。
2018-03-25 09:57:11 +08:00
2018-03-25 16:36:32 +08:00
您也可以在 Issues 中发表关于改进本仓库的建议。
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-25 16:32:29 +08:00
**关于转载**
2018-03-10 22:59:36 +08:00
2018-03-25 09:57:11 +08:00
本仓库内容使用到的资料都会在最后面的参考资料中给出引用链接,希望您在使用本仓库的内容时也能给出相应的引用链接。
2018-03-28 21:56:14 +08:00
**鸣谢**
[TeeKee](https://github.com/linw7)