Node.js 基础学习

文章目录

  • [1. Node.js](#1. Node.js)
    • [1.1 是什么?](#1.1 是什么?)
    • [1.2 作用](#1.2 作用)
  • [2. 命令行工具](#2. 命令行工具)
    • [2.1 命令的结构](#2.1 命令的结构)
    • [2.2 常用命令](#2.2 常用命令)
  • [3. Node.js 注意点](#3. Node.js 注意点)
    • [3.1 Node.js 中不能使用DOM 和BOM 的API](#3.1 Node.js 中不能使用DOM 和BOM 的API)
    • [3.2 Node.js 中顶级对象叫做global](#3.2 Node.js 中顶级对象叫做global)
  • [4. Buffer](#4. Buffer)
    • [4.1 Buffer 特点](#4.1 Buffer 特点)
    • [4.2 Buffer 创建方式](#4.2 Buffer 创建方式)
    • [4.3 Buffer 操作与注意点](#4.3 Buffer 操作与注意点)
  • [5. 计算机基础](#5. 计算机基础)
    • [5.1 计算机基本组成](#5.1 计算机基本组成)
    • [5.2 程序执行的基本流程](#5.2 程序执行的基本流程)
    • [5.3 进程和线程](#5.3 进程和线程)

1. Node.js

1.1 是什么?

Node.js是一个开源的,跨平台的JavaScript运行环境

通俗来讲,Node.js就是一款应用程序,是一款软件,它可以运行JavaScript

1.2 作用

  1. 开发服务器应用

  2. 开发工具类应用

  3. 开发桌面端应用

2. 命令行工具

2.1 命令的结构


// 这两行代码称为命令

// 前者为命令名称

// 后者url 成为命令参数

2.2 常用命令

  1. 切换盘符
    C:
    D:
  2. 切换工作目录
    cd
  3. 查看目录文件
    dir

怎么去执行node.js 文件 :

  1. 第一种方法是win + R 打开命令行窗口,通过命令执行文件;
  2. 第二种方法是在VSCode 中右击文件选择再集成终端打开,就可以执行文件;
  3. 还有就是可以使用Code Runner插件,点击右上角播放按钮直接就可以执行文件

3. Node.js 注意点

3.1 Node.js 中不能使用DOM 和BOM 的API

浏览器中的JavaScript :

Node.js 中的JavaScript :

javascript 复制代码
// BOM
console.log(window);
console.log(history);
console.log(navigator);
console.log(location);

// DOM
console.log(document);

// AJAX
let xhr = new XMLHttpRequest();
// 以上代码都是无法执行的 因为Node.js 中没有相应的API

3.2 Node.js 中顶级对象叫做global

浏览器的顶级对象为window ;而Node.js 中顶级对象叫做global。

另外,ES2020 中提出的globalThis 对象和Node.js 中的global 对象指向是一样的,也就是可以通过globalThis 访问顶级对象。

javascript 复制代码
console.log(globalThis ===global);
// true

4. Buffer

Buffer 中文译为缓冲区,是一个类似于Array 的对象,用于表示固定长度的字节序列;

Buffer 本质是一段内存空间,专门用来处理二进制数据。

4.1 Buffer 特点

  1. Buffer大小固定且无法调整
  2. Bufr性能较好,可以直接对计算机内存进行操作
  3. 每个元素的大小为1字节(byte)

4.2 Buffer 创建方式

  1. alloc
javascript 复制代码
let buf = Buffer.alloc(10);
console.log(buf);
// <Buffer 00 00 00 00 00 00 00 00 00 00>

这种方式创建的Buffer 位置都会归为0!

  1. allocUnsafe
javascript 复制代码
let buf_2 = Buffer.allocUnsafe(10);
console.log(buf_2);
// <Buffer 00 00 00 00 00 00 00 00 00 00>

与前者相比,后者创建的Buffer 可能会包含旧的内存数据,并且每次创建的Buffer 数据可能都不一样;

补充:

内存空间是可以进行复用的,比如说A 使用过一部分内存空间后,B复用该部分内存空间,所以allocUnsafe 创建Buffer 就可能出现就旧数据。

但是allocUnsafe 创建Buffer 速度要比alloc 更快,因为allocUnsafe 不需要进行数据归零的操作。

  1. from
javascript 复制代码
let buf_3 = Buffer.from('hello');
console.log(buf_3);
// <Buffer 68 65 6c 6c 6f>

补充 -- <Buffer 68 65 6c 6c 6f> 是怎么出现的?

字符中字母对应ASCII 码的十六进制数,比如h ASCII 码的十六进制数就为68

4.3 Buffer 操作与注意点

  1. Buffer 与字符串的转换
javascript 复制代码
let buf_4 = Buffer.from([105,108,111,118,101,121,111,117]);
console.log(buf_4.tostring()); // iloveyou
// toString() 是默认按照UTF-8的编码方式进行转换的

  1. 我们上面提到Buffer 是数组形式,那么就可以通过数组字面量进行查询数据,
javascript 复制代码
let buf = Buffer.from('hello');
console.log(buf[0]);
// 104
console.log(buf[0].toString(2));
// 01101000

也可以通过数组字面量对数组数据进行修改,

javascript 复制代码
buf[0] = 95;
console.log(buf.toString());
// _ello
  1. 溢出(了解即可)
    二进制中最大数据1111 1111 转换为十进制是255,也就是说如果存储的数据超过255就会出现溢出的情况,那么就会舍弃高位的数字
javascript 复制代码
let buf = Buffer.from('hello');
buf[0] = 361;
//舍弃高位的数字0001 0110 1001 => 0110 1001
  1. 中文
javascript 复制代码
let buf = Buffer.from('你好');
console.log(buf);

UTF-8 的中文一般是占三个字节,也就是'你' 占三个,'好' 占三个。

5. 计算机基础

5.1 计算机基本组成

内存:读写速度较快,断电丢失数据

硬盘:读写速度较慢,断电不丢失数据

显卡:

5.2 程序执行的基本流程

常见操作系统:

操作系统启动过程:

应用程序运行流程:

操作系统和应用程序的操作流程大体上来说是一致的,都是先将相关的程序从硬盘中获取加载在内存中,这样CPU就可以进行运行了,遇到视频信号时就交由显卡处理,最终在显示器上显示;遇到声音信号就交由声卡处理,最后呈现出来。

程序一般保存在硬盘中,软件安装的过程就是将程序写入硬盘的过程;

程序在运行时会加载进入内存,然后由CPU读取并执行程序。

5.3 进程和线程

进程 :进行中的程序,也可以说是程序的一次执行过程;

查看进程:

线程:是一个进程中执行的一个执行流,一个线程是属于某个进程的。

线程和进程的关系

进程就相当于整个营业中的蜜雪冰城商店,而线程就可以理解为员工进行工作。

相关推荐
霍格沃兹测试开发学社测试人社区28 分钟前
软件测试学习笔记丨Flask操作数据库-数据库和表的管理
软件测试·笔记·测试开发·学习·flask
今天我又学废了1 小时前
Scala学习记录,List
学习
王俊山IT1 小时前
C++学习笔记----10、模块、头文件及各种主题(一)---- 模块(5)
开发语言·c++·笔记·学习
Mephisto.java2 小时前
【大数据学习 | kafka高级部分】kafka中的选举机制
大数据·学习·kafka
南宫生2 小时前
贪心算法习题其三【力扣】【算法学习day.20】
java·数据结构·学习·算法·leetcode·贪心算法
武子康3 小时前
大数据-212 数据挖掘 机器学习理论 - 无监督学习算法 KMeans 基本原理 簇内误差平方和
大数据·人工智能·学习·算法·机器学习·数据挖掘
使者大牙4 小时前
【大语言模型学习笔记】第一篇:LLM大规模语言模型介绍
笔记·学习·语言模型
~甲壳虫4 小时前
说说webpack中常见的Plugin?解决了什么问题?
前端·webpack·node.js
As977_4 小时前
前端学习Day12 CSS盒子的定位(相对定位篇“附练习”)
前端·css·学习
ajsbxi4 小时前
苍穹外卖学习记录
java·笔记·后端·学习·nginx·spring·servlet