数据库1、为什么数据库很重要?
后端就是操作和存储数据,所以作为后端开发,数据库是最主要的学习模块。数据库,也是计算机专业的必修课。我们学校的话,是大三会学这门课,课本教材是这个《数据库系统概论》。
如果连基本的SQL都不会写的话,就不能算后台开发工程师。当然,学习数据库技能,会写SQL语句只是基本素养。想成为一名高级后台开发工程师,还需要学会SQL调优、分库分表等等。
2、数据库相关书籍推荐
《sql必知必会》
本书是深受世界各地读者欢迎的SQL经典畅销书,内容丰富,文字简洁明快,针对Oracle、SQL Server、MySQL、DB2、PostgreSQL、SQLite等各种主流数据库提供了大量简明的实例。
《高性能Mysql》
《高性能mysql(第3版)》不但适合数据库管理员(dba)阅读,也适合开发人员参考学习。不管是数据库新手还是专家,相信都能从这本书有所收获。
《MySQL技术内幕:innodb存储引擎》
《MySQL技术内幕:InnoDB存储引擎(第2版)》从源代码的角度深度解析了InnoDB的体系结构、实现原理、工作机制,并给出了大量最佳实践,能帮助你系统而深入地掌握InnoDB,更重要的是,它能为你设计管理高性能、高可用的数据库系统提供绝佳的指导。
3、课程推荐
极客时间的《MySQL 45讲》
MySQL的45讲,真的挺好,课程讲解深入浅出,生动有趣,不仅仅适合开发看,也适合运维看。
4、视频推荐
推荐一个适合初级以及中级工程师看的SQl视频,讲师一个老外,内容很不错的。
视频地址:
操作系统1、为什么要学习操作系统?
引用一个知乎的回答:
比如你要开发一个网络代理软件,不过是从socket上收一个包,然后转发给另一个socket,看起来,跟操作系统没半毛线关系。
实现过程中,如果你只用一个线程处理网络IO,只要CPU顶得住,延迟一般会在几个毫秒内。但是如果你用了多线程分别处理收/发,网络压力稍大,引入的延迟就会增加,额外延迟就可能突破几十个毫秒。
想搞明白这是为什么,就需要对操作系统调度原理、时间片等概念没有足够深刻的理解。
应用层开发的确只需要接触冰山在海面上的可见部分;但这只够你开发一些蹩脚的软件;冰山藏在海面下的9/10,和冰山的可见部分毕竟是一体的:浮于表面的软件同样会影响冰山的不可见部分、并被冰山的不可见部分影响。如果没有基本了解,当冰山的不可见部分透过可见部分坑到你时,你绝没能力为这些蹩脚软件debug。
2、操作系统书籍推荐
《现代操作系统》
本书是操作系统领域的经典之作.书中集中讨论了操作系统的基本原理,包括进程、线程、存储管理、文件系统、输入/输出、死锁等,同时还包含了有关计算机安全、多媒体操作系统、掌上计算机操作系统、微内核、多核处理机上的虚拟机以及操作系统设计等方面的内容。
《程序是怎么跑起来的》
本书从计算机的内部结构开始讲起,以图配文的形式详细讲解了二进制、内存、数据压缩、源文件和可执行文件、操作系统和应用程序的关系、汇编语言、硬件控制方法等内容,目的是让读者了解从用户双击程序图标到程序开始运行之间到底发生了什么。同时专设了“如果是你,你会怎样介绍?”专栏,以小学生、老师为对象讲解程序的运行原理,颇为有趣。本书图文并茂,通俗易懂,非常适合计算机爱好者及相关从业人员阅读。
3、操作系统视频推荐
清华大学公开课:操作系统,讲得很好,推荐一波
视频地址:
此外,我也给大家分享我收集的资源,从最零基础开始的教程到C语言C++项目案例,帮助大家在学习C语言的道路上披荆斩棘!
暂无评论内容