node入门

OSI七层网络模型TCP/IP四层概念模型对应网络协议
应用层
表示层
会话层
传输层传输层
网络层网络层
数据链路层
物理层
node的底层语言是c++;
node是为了高效I/O而生。
node使用的引擎与js一样。
node也是单线程的。
1.node 为什么高效?
(1)异步I/O
	1、单线程阻塞执行  效率低,当读取文件过多导致效率低
	2、多线程同步执行  管理复杂 开销太大(占资源)

node所有的异步操作都是通过回调函数的方式。(容易造成回调地狱)

2.各种异步编程方式

3.利用async和promise封装node的异步操作

64位v8引擎分配1.4G内存 32位分配 0.7G内存

新生代内存:
64:64MB 32:

老生代内存:
64:1400MB 32:

node 的核心模块:
1.网络模块 (作为客户端,作为服务端)
2.文件操作
3.事件系统
为什么会有buffer?
node中要用到网络i/o,文件传输 (都是二进制的数据)。
buffer用于存储二进制数据。
buffer是网络传输的基础。
buffer是用的c++的内存,v8来管理。

process.memoryUsage()命令可以查看内存使用情况。

{ rss: 21884928,
heapTotal: 9682944,
heapUsed: 5390872,
external: 16903 }(C++分配的额外内存)。

strem
strem 其实就是一个buffer的高阶封装
strem 有Readable,Writable,Duplex,Transform
strem对象是eventemitter的实例,所以它也可以监听如data,end,error,finish

流是可恢复可缓存的,比如下载

drain事件 缓存区释放后出发 buffer先往内存里写入数据 然后再从内存将数据输出到文件中

pipe 管道 可以直接把读流读入到写流。可以链式调用。
rs.pipe(z.createGzip()).pipe(ws);
将读流通过转换流转换成压缩文件再写入文件。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值