位置: 编程技术 - 正文

深入理解Nodejs Global 模块(深入理解计算机系统)

编辑:rootadmin

推荐整理分享深入理解Nodejs Global 模块(深入理解计算机系统),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:深入理解中国式现代化,深入理解计算机系统 电子书,深入理解新发展理念,深入理解计算机系统 电子书,深入理解中国式现代化,深入理解新发展理念,推进供给侧结构性改革,深入理解新发展理念,深入理解计算机系统,内容如对您有帮助,希望把文章链接给更多的朋友!

浏览器上有自己的全局对象 window,同理, nodejs 下也有自己的全局对象 global,并且在各个模块下 都可以直接访问 global 对象。

在 nodejs 中,除了可以直接使用 V8 JavaScript 引擎中所支持的原生 JavaScript 的函数和对象外,它还追加了一些其他的函数和对象(比如:Buffer 对象、require 函数等)。

Buffer 对象: 用于处理二进制数据 module 对象: 用于访问当前模块的信息 process 对象: 用于访问进程信息 console 对象: 用于向控制端输出某些信息 6 个计时器相关函数

需要注意的是,可以在不引入模块的情况下直接使用 nodejs 追加的这些函数和对象。

下面将对上面的这些对象和函数的使用进行简单的解释。

Buffer 对象

在 ES6 之前,原生的 JavaScript 并没有专门用来处理二进制数据的机制,所以为了方便地处理二进制数据,nodejs 才引入了 Buffer 对象。

ES6 之后,原生的 JavaScript 引入了 TypedArray,用来处理二进制数据。注意 TypedArray 并不是以一个单一的对象的形式而存在,而是以一系列值的类型为 TypedArray 的对象而存在。在这一系列对象中,Uint8Array 对象和 Buffer 对象最为相似,但是 Buffer 对象更加适用于 nodejs。

Buffer 对象的实例很像一个各个元素都是整数的数组,但是与真正的数组的区别在于它的大小固定的(即在实例创建时决定大小),并且为它分配的内存是原生的,并且存在于 V8 的堆内存外。在 nodejs 6.0 版本之前,是使用 new Buffer() 语法来创建一个实例,但是因为一些安全问题,以这种形式创建实例的方法被废除了,取而代之的是一些 Buffer 对象的一些静态方法。

创建 Buffer 实例

Buffer.alloc(size[, fill[, encoding]]): 返回一个指定大小的 Buffer 实例,如果没有设置 fill,则默认填满 0 Buffer.allocUnsafe(size): 返回一个指定大小的 Buffer 实例,但是它不会被初始化,所以它可能包含敏感的数据 Buffer.allocUnsafeSlow(size) Buffer.from(array): 返回一个被 array 的值初始化的新的 Buffer 实例(传入的 array 的元素只能是数字,不然就会自动被 0 覆盖) Buffer.from(arrayBuffer[, byteOffset[, length]]): This creates a view of the ArrayBuffer without copying the underlying memory Buffer.from(buffer): 复制传入的 Buffer 实例的数据,并返回一个新的 Buffer 实例 Buffer.from(string[, encoding]): 返回一个被 string 的值初始化的新的 Buffer 实例

上面讲的不太清楚(以后再优化),因为我是初学,TypedArray 都没玩过呢!

但是放心,大腿在这呢 — Node源码解析 ? buffer

源码链接: buffer.js

Buffer.byteLength(string[, encoding]): 返回 string 的实际的字节长度(注意不是字符长度)

上面的汉字 小 的 UTF-8 码正好占用三个字节(xE5xB0x8F),所以才会有上面的结果。

Buffer.concat(list[, totalLength]): 连接多个 Buffer 实例或 Uint8Array 实例,并返回一个新的 Buffer 实例

Buffer.isBuffer(obj): 判断一个对象是不是 Buffer 实例

Buffer.isEncoding(encoding): 判断是否支持指定的编码方式

Buffer.poolSize: 指定预分配的字节数的大小,默认为 (即 8 KB)

Buffer.prototype.buffer: 一个指向 ArrayBuffer 的引用

Buffer.prototype.equals(otherBuffer): 比较两个 Buffer 实例是否拥有完全相同的 bytes

用于迭代的方法

Buffer.prototype.entries() Buffer.prototype.keys() Buffer.prototype.values()

Buffer.prototype.fill(value[, offset[, end]][, encoding]): 用指定的值填充满 Buffer 实例

Buffer.prototype.includes(value[, byteOffset][, encoding])

深入理解Nodejs Global 模块(深入理解计算机系统)

Buffer.prototype.indexOf(value[, byteOffset][, encoding])

Buffer.prototype.toJSON(): 返回一个 JSON 对象

当 JSON.stringify(buf) 的参数为一个 Buffer 实例时,会隐式地调用上面的方法

Buffer.prototype.toString([encoding[, start[, end]]]): 以指定的 encoding 解码 Buffer 实例,返回解码后的字符串

字符串不能被修改,但是 Buffer 实例却可以被修改。

Buffer.prototype.write(string[, offset[, length]][, encoding]): 将指定字符串写入到 Buffer 中

好了,还有一堆方法就不一一列出来了,Buffer 就到这里了。

module 对象

在使用 require 函数加载模块文件时,将运行该模块文件中的每一行代码

模块在首次加载后将缓存在内存缓存区中,所以对于相同模块的多次引用得到的都是同一个模块对象,即对于相同模块的多次引用不会引起该模块内代码的多次执行。

在编译的过程中,Node 会对获取的 JavaScript 文件内容进行头尾包装!

__filename & __dirname

__filename: 返回当前模块文件的绝对路径(带文件名) __dirname: 返回当前模块文件所在目录的绝对路径

Process 对象

process 对象是 nodejs 的一个全局对象,提供当前 nodejs 进程的信息。

属性

process.arch: 返回当前处理器的架构 process.env: 返回一个包含用户环境变量的对象 process.argv: 返回一个数组,数组的第一个元素总是 node 程序的绝对路径,第二个元素是当前执行脚本的绝对路径 process.execPath: 返回 node 程序的绝对路径 process.argv0: 返回 node 程序的绝对路径 process.pid: 返回当前进程的进程号 process.platform: 返回当前的系统平台标识符(比如:'darwin', ‘freebsd', ‘linux', ‘sunos' or ‘win') process.version: 返回当前 node 的版本号 process.versions: 返回一个对象,列出了 nodejs 和其相关依赖的版本号

三个重要的属性

process.stdin: 返回一个指向标准输入流的可读流(Readable Stream) process.stdout: 返回一个指向标准输出流的可写流(Writable Stream) process.stderr: 返回一个指向标准错误流的可写流(Writable Stream)

方法

process.cwd(): 返回进程当前的工作目录 process.chdir(path): 改变进程当前的工作目录 process.cpuUsage(): 返回当前 CPU 的使用情况 process.memoryUsage(): 返回当前内存的使用情况 process.uptime(): 返回 Node 程序已运行的秒数 process.nextTick(callback[, …args]): 指定回调函数在当前执行栈的尾部、下一次Event Loop之前执行 process.emitWarning(warning[, options]): 触发一个 warning 事件,可以自定义一些警告信息 process.exit([code]): 立即结束当前进程,但是会触发 process 的 exit 事件 process.abort(): 立即结束当前进程,不会触发 exit 事件

process 对象还有一些方法没列出来,因为我现在看不懂怎么用,以后补 >_<

Console 对象

这个对象就是用来在控制台下面打印一些信息而已,挑几个有用但没记牢的方法来玩玩。

console.dir(value): 打印一个对象的详细信息

console.time(label) & console.timeEnd(label): 用来统计代码执行时间

6 个计时器函数

在浏览器上,就有相应的 4 个计时器函数(setInterval、clearInterval、setTimeout、clearTimeout),只不过它们是 window 全局对象的属性。

在 nodejs 中,除过上面的 4 个计时器,还增加了两个(setImmediate,clearImmediate)。

这六个计时器函数被定义在了全局对象 global 下,即可以直接在代码中进行使用。

标签: 深入理解计算机系统

本文链接地址:https://www.jiuchutong.com/biancheng/380829.html 转载请保留说明!

上一篇:深入理解Node中的buffer模块(node的理解)

下一篇:详解nodeJS之二进制buffer对象(nodejs init)

  • 待处理财产损益借方
  • 一般纳税人登记证明
  • 待处理财产损益年底怎么处理
  • 大凭证小凭证
  • 购买生产原料分录
  • 转让无形资产增值税
  • 企业报税盘入账应该记入哪个科目
  • 建筑业预交税金怎么计算
  • 前三季度盈利第四季度亏损 所得税记账
  • 公司购买的冰箱供员工使用
  • 房地产企业增值税预缴
  • 应交税费不核算
  • 会计档案保管最新规定
  • 财务费用属于什么会计科目类别
  • 其他业务收入怎么填纳税申报表
  • 资产总额从业人数
  • 申报个税是按哪个月的工资表
  • edge浏览器设置主页网址
  • 贷款逾期了利息和罚息可以不还吗
  • 哪些金融资产的股票会涨
  • linux网络管理实训总结
  • win10ie浏览器打开就崩溃
  • 减免的税款还用做分录吗
  • 债券利息计算表
  • 栀子花的养殖方法和注意事项茉莉花
  • 其他货币资金属于资产类科目
  • 电脑硬盘数据恢复一般需要收费多少钱
  • 材料成本差异如何做账
  • 个体户何去何从
  • php缓存文件并自动清理
  • 一天看小说十几个小时的人
  • php的file函数
  • thinkphp5框架介绍
  • javascript对象有哪些
  • 后端中spef文件和spf文件
  • bzip2命令压缩后无法保存原文件
  • 一般纳税人第一次申请发票
  • 帝国cms批量excel导入文章
  • 实行核定征收印花税
  • 小规模纳税人减按1%征收率征收增值税
  • 生成100个[30-99]之内的随机数
  • sql条件查询语句怎么写
  • 购置环保设备一次性扣除
  • 预收工程款的会计分录
  • 土地租金计入什么会计科目
  • 商场联营方案
  • 销售商品的运费的税费计入进项税额
  • 增值税运费发票清单怎么开
  • 付给其他公司的服务费怎么记账
  • 企业预缴增值税税率
  • 公对公房产过户
  • 现金流动负债比率越大越好吗
  • 递延所得税资产是什么意思
  • 股票交易费用计算器小程序
  • 现金流量为负的原因
  • 农业合作社成本有哪些
  • 商贸企业固定资产折旧可以一次性扣除吗?
  • 分公司人数要求
  • 创建小企业
  • sqlserver数据库维护
  • Windows Server 2008下的网络排错
  • macbookzen
  • mac m1读取ntfs
  • linux恢复rm删除目录
  • linux启动u盘制作
  • win10系统的设备管理器在哪里
  • windos8怎么样
  • 怎么放大linux字体
  • linux 11
  • [置顶]电影名字《收件人不详》
  • Cocos2dx3.2 Crazy Tetris 绘制不规则方块 遮罩(ClippingNode的使用)
  • jqueryvalidate验证
  • python迭代器的作用
  • angular.min.js
  • 深入理解中国式现代化
  • jQuery bt气泡实现悬停显示及移开隐藏功能的方法
  • JavaScript ParseFloat()方法
  • 电子税务局内蒙古自治区
  • 深圳税务局工作时间表
  • 上海买新房办贷款流程
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设