三、node的异步I/O
四、异步编程
1、函数式编程
高阶函数
函数可以作为参数或者返回值。
偏函数用法
偏函数用法是指创建一个调用另外一个部分——参数或变量已经预置的函数——的函数的用法。
举个例子:在JavaScrip中进行类型判断时,我们通常会进行类似上述代码的方法定义。如下代码存在的问题是需要重复去定义一些相似的函数,如果有 更多的isXXX(),就会出现更多的冗余代码。
var toString = Object.prototype.toString;
var isString = function (obj){
return toString.call(obj) =='[object String]';
}
var isFunction = function (obj){
return toString.call(obj) == '[object Function]';
}
改造以后
var isType = function (type) {
return function (obj) {
return toString.call(obj) == '[object ' + type + ']';
}
}
var isString = isType('String')
var isFunction = isType('Function')
console.log(isString)
console.log(isFunction)
2、异步编程的优势与难点
Node利用JavaScript及其内部异步库,将异步直接提升到业务层面,这是一种创新。
优势
Node带来的最大特性莫过于基于事件驱动的非阻塞I/O模型,这是它的灵魂所在。非阻塞I/0可以使CPU与I/O并不相互依赖等待,让资源得到更好的利用。对于网络应用而言,并行带来的想象空间更大,延展而开的是分布式和云。并行使得各个单点之间能够更有效地组织起来,这也是Node在云计算厂商中广受青睐的原因,图4-1为异步IO调用的示意图。
难点
- 异常处理
- 函数嵌套过深
- 阻塞代码
- 多线程编程
- 异步转同步
3、异步编程的解决方案
1. 事件发布/订阅模式
2.Promise / Deferred
3.流程控制库
4、异步并发控制
五、内存控制
V8的内存限制:
在一般的 后端开发语言中,在基本的内存使用上没有什么限制。然而在Node中通过JS使用内存时就会发现只能使用部分内存(64位系统下约为1.4GB,32位系统下 约为0.7GB)。在这样的限制下,将会导致Node无法直接操作大内存 对象。
高效使用内存
这一节中定义的闭包概念是:实现外部作用域访问内部作用域中变量的方法叫做闭包(closure)。
小结:
在正常的JavaScript执行中,无法立即回收的内存有闭包和全局变量引用这两种情况。由于V8的内存限制,要十分小心此类变量是否无限制地增加,因为它会导致老生代中的对象增多。
六、理解 Buffer
Buffer是一个像Array的对象,但它主要用于操作字节。下面我们从模块结构和对象结构的层面上来认识它。
1、Buffer结构
模块结构:
Buffer 是一个典型的JavaScript与C++结合的模块,它将性能相关部分用C++实现,将非性能相关的部分用JavaScript实现。
Buffer所占用的内存不是通过V8分配的,属于堆外内存。由于V8垃圾回收性能的影响,将常用的操作对象用更高效和专有的内存分配回收策略来管理是个不错的思路。文章来源:https://www.toymoban.com/news/detail-620265.html
由于 Buffer 太过常见,Node 在进程启动时就已经加载了它,并将其放在全局对象(global)上。所以在使用Buffer时,无需通过 require() 即可直接使用。文章来源地址https://www.toymoban.com/news/detail-620265.html
2、Buffer的转换
3、Buffer的拼接
4、Buffer与性能
到了这里,关于Node.js学习笔记-02的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!