Node 学习二、全局变量 process 和 核心模块 path

2024-08-23 01:18

本文主要是介绍Node 学习二、全局变量 process 和 核心模块 path,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

全局变量 process

获取进程信息

// 1 资源// 1.1 内存// 占用 arrayBuffers
// 声明一个大小为 1000 的 Buffer
// Buffer.alloc(1000)console.log(process.memoryUsage())
// {
//   rss: 24879104, // 常驻内存
//   heapTotal: 4509696, // 脚本执行之初申请的总的内存大小
//   heapUsed: 2415608, // 当前脚本在执行中实际使用的内存大小
//   external: 808874, // 底层 C/C++ 模块所占据的内存大小
//   arrayBuffers: 9386 // 缓冲区,代表一块独立的空间,不占据 V8 的内存,默认也会先申请一块空间
// }// 1.2 CPUconsole.log(process.cpuUsage())
// {
//   user: 31000, // 用户占用的 CPU 时间片段
//   system: 78000 // 操作系统占用的 CPU 时间片段
// }
// 2 运行环境// 2.1 运行目录
console.log(process.cwd())// 2.2 node 环境信息
console.log(process.version) // node 版本
console.log(process.versions) // 更多版本信息// 2.3 cpu 架构
console.log(process.arch) // x64// 2.4 用户环境(开发环境)
console.log(process.env.NODE_ENV)
console.log(process.env.PATH)// 2.5 系统平台
console.log(process.platform) // win32
// 3 运行状态// 3.1 启动参数(如 node <脚本文件> 1 -a 2 -b)
console.log(process.argv) // [<node 启动程序绝对路径>, <脚本文件绝对路径>, '1', '-a', '2', '-b']// 3.2 进程 PID
console.log(process.pid)// 3.3 运行时间
setTimeout(() => {console.log(process.uptime()) // 脚本从运行开始到结束总共消耗的时间
}, 3000)

执行进程操作

// 1 事件监听// 注册一个退出事件
// 退出事件在当前脚本文件执行完成之后触发
// code 是退出时的状态码
process.on('exit', code => {console.log('exit ' + code)setTimeout(() => {console.log('exit 事件不支持异步代码')}, 1000)
})process.on('beforeExit', code => {console.log('before exit ' + code)// beforeExit 事件中执行异步代码会让将要退出的脚本继续执行// 结果会导致 beforeExit 触发死循环
})console.log('脚本执行结束')// 主动退出不会触发 beforeExit
// process.exit()// 脚本执行结束
// exit 0
// before exit 0

下面简单了解一下管道、流:

// 2 标准输出console.log = data => {// stdout 标准输出// stdout 返回一个流对象process.stdout.write('---' + data + '\n')
}console.log(11)
console.log(22)const fs = require('fs')// 创建一个可读流 读取 test.txt 的内容
fs.createReadStream('test.txt')// 通过一个管道将数据流向(传递)下一个处理者// 传递给标准输出,就会打印到控制台.pipe(process.stdout)
// 3 标准输入// stdin 同样返回一个流
process.stdin// 允许在控制台输入内容// 将控制台输入的内容流向 stdout 输出// 类似复印的效果.pipe(process.stdout)
// 3 标准输入// 设置标准输入的字符编码集
process.stdin.setEncoding('utf-8')// 监听 readable 事件
// 当有可从流中读取的数据时,会触发 readable 事件
// 数据会被读入内部缓冲区
process.stdin.on('readable', () => {// 从内部缓冲区取出一些数据并返回let chunk = process.stdin.read()if (chunk) {process.stdout.write('data ' + chunk)}
})

内置模块之 path

Node 内置的模块需要通过 require 导入当前的脚本中使用。

path 模块的主要作用是用于处理文件或目录的路径。

常用 API

  • basename():获取路径中基础名称
  • dirname():获取路径中目录路径
  • extname():获取路径中扩展名称
  • isAbsolute():判断路径是否为绝对路径
  • join():拼接多个路径片段
  • resolve():返回绝对路径
  • parse():解析路径
  • format():序列化路径,与 parse() 相反
  • normalize():规范化路径
const path = require('path')/** 1 获取路径中的基础名称* 01 返回的是接收路径当中的最后一部分,忽略前后的路径分隔符* 02 第二个可选参数表示扩展名,如果没有设置则返回完整带后缀的文件名称* 03 第二个参数也可以看作从后截取的字符串* 04 第二个参数会匹配当前路径的基础名称,如果匹配失败则忽略*/console.log(path.basename('D:/a/b/c/demo.js')) // demo.js
console.log(path.basename('D:/a/b/c/demo.js', '.js')) // demo
console.log(path.basename('D:/a/b/c/demo.js', '.css')) // demo.js
console.log(path.basename('/a/b/c')) // c
console.log(path.basename('/a/b/c/')) // c/** 2 获取路径中的目录路径* 01 返回路径中最后一个部分的上一层目录所在路径,忽略前后的路径分隔符**/
console.log(path.dirname('D:/a/b/c/demo.js')) // D:/a/b/c
console.log(path.dirname('/a/b/c')) // /a/b
console.log(path.dirname('/a/b/c/')) // /a/b/** 3 获取路径中的扩展名* 返回文件路径的文件的扩展名* 实际上匹配的是路径中最后一部分从最后一次出现`.`字符到结尾的部分,保留 `.`*/
console.log(path.extname('D:/a/b/c/demo.js')) // .js
console.log(path.extname('/a/b/c.d.e.css')) // .css
console.log(path.extname('/a/b/c.')) // .
console.log(path.extname('/a/b/c')) // 空/** 4 解析路径* 01 接收一个路径,返回一个包含路径信息的对象*/
console.log(path.parse('/a/b/c/demo.js'))
// {
//   root: '/', // 根路径
//   dir: '/a/b/c', // 同 dirname
//   base: 'demo.js', // 同 basename 完整名称
//   ext: '.js', // 同 extname
//   name: 'demo' // 最后一部分的文件名
// }
console.log(path.parse('/a/b/c'))
console.log(path.parse('/a/b/c/'))
console.log(path.parse('a/b/c'))/** 5 序列化路径* 与 parse() 相反*/
console.log(path.format(path.parse('a/b/c')))/* 6 判断路径是否为绝对路径 */
console.log(path.isAbsolute('foo')) // false
console.log(path.isAbsolute('/foo')) // true
console.log(path.isAbsolute('///foo')) // true/** 7 拼接路径* 01 使用当前平台的分隔符作为界定符拼接给定的路径片段* 02 空字符串会被作为 `.` 拼接*/
console.log(path.join('a/b', 'c', 'demo.js')) // a\b\c\demo.js
console.log(path.join('a/b', 'c', '../', 'demo.js')) // a\b\demo.js
console.log(path.join('a/b', 'c', '/demo.js')) // a\b\c\demo.js
console.log(path.join('a ', ' ', 'demo.js')) // a \ \demo.js/** 8 规范化路径* 01 将路径分隔符替换为当前平台的分隔符 `/` 或 `\`* 02 将连续的分隔符替换为1个* 03 保留尾随的分隔副* 04 空字符串路径会被转化成 `.`*/
console.log(path.normalize('')) // .
console.log(path.normalize('a///b/c../d')) // a\b\c..\d
console.log(path.normalize('a//\\/b/c\\/d/')) // a\b\c\d\/** 9 返回绝对路径* 将路径或路径片段的序列解析为绝对路径* 给定的路径序列从右往左处理,每个后续的路径都会被追加到前面,直到构建绝对路径* 如果处理完所有给定的路径还没有生成绝对路径,则使用当前工作目录`__dirname`*/
console.log(path.resolve()) // 同 __dirname
console.log(path.resolve('a', 'b')) // <__dirname>/a/b
console.log(path.resolve('a', '/b')) // <盘符>:/b
console.log(path.resolve('/a', '/b')) // <盘符>:/a
console.log(path.resolve('a', 'b', '../c')) // <__dirname>/a/c

这篇关于Node 学习二、全局变量 process 和 核心模块 path的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1097943

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

Andrej Karpathy最新采访:认知核心模型10亿参数就够了,AI会打破教育不公的僵局

夕小瑶科技说 原创  作者 | 海野 AI圈子的红人,AI大神Andrej Karpathy,曾是OpenAI联合创始人之一,特斯拉AI总监。上一次的动态是官宣创办一家名为 Eureka Labs 的人工智能+教育公司 ,宣布将长期致力于AI原生教育。 近日,Andrej Karpathy接受了No Priors(投资博客)的采访,与硅谷知名投资人 Sara Guo 和 Elad G

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学