《深入浅出Nodejs》—— 读后总结
这一个月过去了三分之二,加上之前看过这本书三分之一,这才算是看完。
虽然看完一遍,但是这本书内容很深,以后肯定是还要继续翻阅的.....
什么是Nodejs
Nodejs有几个特性:异步IO,事件驱动,单线程,跨平台
异步IO可以保证在CPU计算的同时,异步的加载IO,加快了应用的访问。不像传统的服务器是使用什么阻塞IO啊、轮训IO等等,它相当于在发送处理请求时,直接传一个回调函数,当异步的IO结束后,会自动的执行回调。
事件驱动,则是把粒度降低到事件级别。传统的服务器是一个请求分配一个线程进行处理,这样就会增加多线程通信的复杂性。而事件驱动,则简化了事件模型。
单线程其实主要是因为Nodejs是基于V8浏览器引擎,因此具有单线程的特点,而且内存很小。这样就引出了Node的劣势——无法利用多核CPU、如果应用出现问题整个系统也会崩溃、CPU繁忙将会影响IO。(因此Node中也提供了child_process模块创建子进程,以此来利用多核;引入了一些集群特性,增加健壮性)。
最后就是跨平台,Nodejs其实并非全部用javascript编写,只是表面的业务语言以及开放的模块才使用js。底层的大部分的模块还是使用C++构建,因此通过切换系统级别的组件,可以直接切换平台。
异步编程
使用Nodejs编写全栈应用,肯定会遇到异步编程的场景。由于有回调的特性,因此可能会出现回调嵌入回调的场景,如果嵌套很深,很影响代码的维护和阅读。
因此异步编程就出现了一些常见的模式:
发布/订阅
这种模式在Nodejs中很常见,像普通的http的on、error或者angular的$watch以及$emit、$broadcast等都是采用这种机制。
Promise/Deferred
最出名的的应该是Kris kawl's Q,后来很多的前端框架都推出了自己的promise模型,比如jquery,dojo,以及angular。这种方式书写出的代码很像传统的单线程顺序执行的代码,阅读起来很方便。
next尾触
这种模式比较有意思,是把一些列的操作放入一个队列。然后按顺序调用,当一个调用结束后,会执行next()方法,继续执行下一个调用。典型的场景就是Node里面的中间件。
内存机制
Nodejs的内存机制很像JVM,因为开发设计Node内存虚拟机的人,正式开发Hotspot的人——结果就是,Nodejs的回收机制跟JVM极其相似。
Nodejs的垃圾回收机制可以简单的描述为:
新生代:
生命周期短的对象,使用复制回收——即把内存分成两块,一块闲置,另一块工作;垃圾回收时,把工作中的存活对象复制到闲置空间中,再交换闲置和工作状态。典型的空间换时间。
老生代:
生命周期长的对象,使用标记清除、标记整理——即标记那些不再使用的对象,回收的时候回收掉这些标记中的对象;由于这种标记方法会出现内存碎片,因此搭配标记整理,可以整理内存。
代码规范
最后总结一下书中提及的代码规范:
1 缩进,由于tab在不同的编辑器中长度可能不同,因此推荐使用两个空格
2 变量声明,尽量每个对象都带上var,不然会变成全局变量污染全局
3 空格,在操作符或者括号两边加上空格
4 尽量优先使用单引号
5 大括号不推荐换行
6 逗号不要在行首出现
7 尽量每一句结尾都带上分号
8 变量命名:小驼峰,如userName;
方法命名:小驼峰,getName();
类命名:大驼峰,NameFilter;
常量命名:大写字母,USER_COUNT;
文件命名:下划线分割,user_test.js;
模块命名:简短单词,express、fs
9 比较操作使用 ===
10 使用{} [] 创建对象和数组
11 尽量避免使用with、eval
12 区分使用对象和数组