Node.js 学习笔记 fs、path、http模块;模块化;包;npm

Node.js学习

  • Node.js
    • 一、定义
      • 1.前端工程化
      • 2.Node.js 为何能执行 JS?
      • 3.安装nodejs、删除之前的nodejs
      • 4.使用 Node.js
    • 二、fs模块 \- 读写文件
    • 三、path 模块
    • 案例 - 压缩前端html
    • 四、HTTP相关
      • URL中的端口号
      • 常见的服务程序
      • http 模块-创建 Web 服务
        • 案例:浏览时钟
    • 五、模块化
      • 1.CommonJS 模块标准
      • 2.ECMAScript 模块标准
        • 2.1 默认导出和导入
        • 2.2 命名导出和导入
    • 六、包
      • 1.包
      • 2.npm
        • npm - 软件包管理器
        • npm - 安装所有依赖
        • npm - 全局软件包 nodemon
    • 七、Node.js总结
      • 1.Node.js 模块化:
      • 2.Node.js 包
      • 3.常用命令
    • 七、Node.js总结
      • 1.Node.js 模块化:
      • 2.Node.js 包
      • 3.常用命令

Node.js

教学视频 BV1MN411y7pw , P83-97的笔记

一、定义

Node.js是一个跨平台JavaScript运行环境,使开发者可以搭建服务器端的JavaScript应用程序。

作用:使用 Node.js 编写服务器端程序

✓ 编写数据接口,提供网页资源浏览功能等等

✓ 前端工程化:为后续学习 Vue 和 React 等框架做铺垫

1.前端工程化

前端工程化:开发项目直到上线,过程中集成的所有工具和技术

Node.js 是前端工程化的基础(因为 Node.js 可以主动读取前端代码内容)
在这里插入图片描述

2.Node.js 为何能执行 JS?

首先:浏览器能执行 JS 代码,依靠的是内核中的 V8 引擎(C++ 程序)

其次:Node.js 是基于 Chrome V8 引擎进行封装(运行环境)

区别:都支持 ECMAScript 标准语法,Node.js 有独立的 API

注意:Node.js 环境没有 DOM 和 BOM 等
在这里插入图片描述

3.安装nodejs、删除之前的nodejs

因为之前有安装过一次nodejs,但是忘记放在哪里了,

a later version of node.js is already installed.

https://www.cnblogs.com/fighxp/p/7410235.html

https://blog.51cto.com/teayear/9559527

备注一下,我这次装在了D:\nodejs
在这里插入图片描述

4.使用 Node.js

需求:新建 JS 文件,并编写代码后,在 node 环境下执行

命令:在 VSCode 集成终端中,输入node xxx.js,回车即可执行

在这里插入图片描述

总结:
1. Node.js 是什么?
➢ 基于 Chrome 的 V8 引擎封装,独立执行 JavaScript 代码的环境

2. Node.js 与浏览器环境的 JS 最大区别?
➢ Node.js 环境中没有 BOM 和 DOM

3. Node.js 有什么用?
➢ 编写后端程序:提供数据和网页资源等
➢ 前端工程化:集成各种开发中使用的工具和技术

4. Node.js 如何执行代码?
➢ 在 VSCode 终端中输入:node xxx.js 回车即可执行(注意路径)

二、fs模块 - 读写文件

模块:类似插件,封装了方法/属性

fs 模块:封装了与本机文件系统进行交互的,方法/属性

语法:

  1. 加载 fs 模块对象
  2. 写入文件内容
  3. 读取文件内容

在这里插入图片描述

 const f = require('fs')
 // 写
 f.writeFile('./02test.txt','hello,node.js',err => {
  if (err) {
    console.log(err);
  } else {
    console.log('写入成功');
  }
 })

// 读
f.readFile('./02test.txt',(err, data) => {
  if(err) console.log(err);
  else {
    console.log(data); // 68 65 6c 6c 6f 2c 6e 6f 64 65 2e 6a 73>
    // data是文件内容的 Buffer数据流 (是字符串在 计算机中保存的二进制数据 转换成的十六进制数据)
    console.log(data.toString()); // hello,node.js
  } 
})

三、path 模块

问题:Node.js 代码中,相对路径是根据终端所在路径来查找的,可能无法找到你想要的文件。

建议:在 Node.js 代码中,使用绝对路径

补充知识点:__dirname 内置变量(获取当前模块目录的绝对路径)

  • 例子:

✓ windows: D:\备课代码\3-B站课程\03_Node.js与Webpack\03-code\03

✓ mac: /Users/xxx/Desktop/备课代码/3-B站课程/03_Node.js与Webpack/03-code/03

mac 和 windows 的区别在于 分隔符 一个是\ 一个是/

注意:path.join() 会使用特定于平台的分隔符,作为定界符,将所有给定的路径片段连接在一起。

path.join('03', 'dist/js', 'index.js')
// windows: '03\dist\js\index.js'
// mac:      '03/dist/js/index.js'

语法
在这里插入图片描述

path用于解决,代码中的相对路径和调试终端的所在文件夹 不同的问题。

调用path.join()配合__dirname组成的目标文件的绝对路径。

  • 案例:

在这里插入图片描述

修改后:

const path = require('path')
console.log(__dirname);

const f = require('fs')
f.writeFile(path.join(__dirname,'./03test.txt'),'444444',err => {
 if (err) {
   console.log(err);
 } else {
   console.log('写入成功');
 }
})

案例 - 压缩前端html

需求:把 回车符(\r)和换行符(\n)去掉后,写入到新 html 文件中

步骤:

  1. 读取源 html 文件内容
  2. 正则替换字符串
  3. 写入到新的 html 文件中

V:\Web\mycode\nodejs\04 compress_html\public\index.html

/**
 * 目标1:压缩 html 代码
 * 需求:把回车符 \r,换行符 \n 去掉,写入到新 html 文件中
 *  1.1 读取源 html 文件内容
 *  1.2 正则替换字符串
 *  1.3 写入到新的 html 文件中
 */
// 1.1 读取源 html 文件内容
const fs = require('fs')
const path = require('path')
fs.readFile(path.join(__dirname, 'public/index.html'), (err, data) => {
  if (err) console.log(err)
  else {
    const htmlStr = data.toString()
    // 1.2 正则替换字符串
    const resultStr = htmlStr.replace(/[\r\n]/g, '')
    console.log(resultStr)
    // 1.3 写入到新的 html 文件中
    fs.writeFile(path.join(__dirname, 'dist/index.html'), resultStr, err => {
      if (err) console.log(err)
      else console.log('写入成功')
    })
  }
})

四、HTTP相关

URL中的端口号

URL:统一资源定位符,简称网址,用于访问服务器里的资源

端口号:标记服务器里不同功能的服务程序

端口号范围:0-65535 之间的任意整数
在这里插入图片描述

注意:http 协议,默认访问 80 端口。所以可以省略。

常见的服务程序

服务器中常见的服务程序-Web 服务程序:用于提供网上信息浏览功能

注意:0-1023 和一些特定端口号被占用,我们自己编写服务程序请避开使用

1. 端口号的作用?
➢ 标记区分服务器里不同的服务程序
2. 什么是 Web 服务程序?
➢ 提供网上信息浏览的程序代码

http 模块-创建 Web 服务

使用nodejs提供的http模块,创建 Web 服务

需求:创建 Web 服务并响应内容给浏览器

步骤:

  1. 加载 http 模块,创建 Web 服务对象

  2. 监听 request 请求事件,设置响应头和响应体

    server.on(‘request’, (req, res) =>{ // 略})

    • req,request 意为请求. 是对请求报文的封装对象, 通过 request 对象可以获得请求报文的数据
    • res,response 意为响应. 是对响应报文的封装对象, 通过 response 对象可以设置响应报文
  3. 配置端口号并启动 Web 服务(一个web服务程序对应一个端口号)

  4. 浏览器请求 http://localhost:3000 测试

(localhost:固定代表本机的域名)

// 1. 加载 http 模块,创建 Web 服务对象
const h = require('http')
const server = h.createServer()

// 2. 监听 request 请求事件,设置响应头和响应体
server.on('request', (req, res) => {
  // 设置响应头: 内容类型 普通文本以及中文编码格式
  res.setHeader('Content-Type', 'text/plain; charset=utf-8')
  // 设置响应体内容,结束本次请求与响应
  res.end('欢迎使用node.js和http模块创建的web服务')
})

// 3. 配置端口号并启动 Web 服务(一个web服务程序对应一个端口号)
server.listen(3000, () => {
  console.log('web服务启动成功');
})

// 4. 浏览器请求 http://localhost:3000 测试

在浏览器网址栏输入 http://localhost:3000后:
在这里插入图片描述

案例:浏览时钟

需求:基于 Web 服务,开发提供网页资源的功能

在这里插入图片描述

const fs = require('fs')
const path = require('path')

// 基于http模块
const http = require('http');
// 创建服务器
const server = http.createServer()


// 服务器监听有没有请求
// req,request 意为请求. 是对请求报文的封装对象, 通过 request 对象可以获得请求报文的数据
// res,response 意为响应. 是对响应报文的封装对象, 通过 response 对象可以设置响应报文
server.on('request', (req, res) => {
  if(req.url === '/index.html') {
    // 返回该网址
    fs.readFile(path.join(__dirname, 'dist/index.html'), (err,data) =>{
      if(err) console.log(err);
      else {
        res.setHeader('Content-Type', 'text/html; charset=utf-8')
        res.end(data.toString())
      }
    })
  } else {
    res.setHeader('Content-Type', 'text/html;charset=utf-8')
    res.end('not found')
  }
})

// 配置端口号并启动 Web 服务
server.listen(8080, () => {
  console.log('web 服务器启动');
})

五、模块化

在Node.js 中,每个文件都被视为一个单独的模块。

概念:项目是由很多个模块文件组成的。 一个文件就是一个模块。

好处:提高代码复用性,按需加载,独立作用域

使用:需要标准语法 导出和导入进行使用。标准语法有 CommonJS 、ECMAScript

1.CommonJS 模块标准

CommonJS 模块是为Nodejs打包 JavaScript 代码的原始方式。Node.js 还支持浏览器和其他JavaScript运行使用的ECMAScript模块标准

使用:

1、导出:module.exports = {}

2、导入:require(‘模块名或路径’)

模块名或路径:

​ ✓ 内置模块:直接写名字(例如:fs,path,http)

​ ✓ 自定义模块:写模块文件路径(例如:./utils.js)

  • 示例

需求:定义 utils.js 模块,封装基地址和求数组总和的函数
在这里插入图片描述

V:\Web\mycode\nodejs\07 modularity_CommonJS\index.js

在这里插入图片描述

utils.js:

const baseURL = 'http://hmajax.itheima.net'
const getArraySum = arr => arr.reduce((sum, item) => sum += item, 0)

// const getArraySum2 =  function (arr) {
//   return arr.reduce((sum,item) => sum + item ,0)
// }

// 导出
module.exports = {
  url: baseURL,
  arraySum: getArraySum
}

index.js:

const obj = require('./utils.js')
console.log(obj.url);
console.log(obj.arraySum([1,2,4]));
总结:
1. Node.js 中什么是模块化?
➢ 每个文件都是独立的模块
2. 模块之间如何联系呢?
➢ 使用特定语法,导出和导入使用
3. CommonJS 标准规定如何导出和导入模块呢?
➢ 导出:module.exports = {}
➢ 导入:require('模块名或路径')
4. 模块名/路径如何选择?
➢ 内置模块,直接写名字。例如:fs,path,http等
➢ 自定义模块,写模块文件路径。例如:./utils.js

2.ECMAScript 模块标准

2.1 默认导出和导入

默认标准使用:

1、导出:export default {}

2、导入:import 变量名 from ‘模块名或路径’

注意:Node.js 默认支持 CommonJS 标准语法。如需使用 ECMAScript 标准语法,在运行模块所在文件夹新建 package.json 文件,并设置 { “type” : “module” }

  • 示例
    在这里插入图片描述

V:\Web\mycode\nodejs\08 modularity_ECMAScript_default export\index.js

index.js是运行模块,要在index.js所在的文件夹中 创建一个 package.json

在这里插入图片描述

utils.js

const baseURL = 'http://hmajax.itheima.net'
const getArraySum = arr => arr.reduce((sum, item) => sum += item, 0)


// 导出
export default {
  url: baseURL,
  arraySum: getArraySum
}

index.js

import obj from './utils'
console.log(obj);

package.json

{
  "type" : "module"
}

在这里插入图片描述

总结
1. ECMAScript 标准规定如何默认导出和导入模块呢?
➢ 导出:export default {}
➢ 导入:import 变量名 from '模块名或路径'
2. 如何让 Node.js 切换模块标准为 ECMAScript?
➢ 运行模块所在文件夹,新建 package.json 并设置
➢ { "type" : "module" }
2.2 命名导出和导入

命名标准使用:

1、导出:export 修饰定义语句

2、导入:import { 同名变量 } from '模块名或路径‘

如何选择是默认导入导出还是命名导入导出?

​ 按需加载,使用命名导出和导入

​ 全部加载,使用默认导出和导入

​ 二者可以同时用
在这里插入图片描述

  • 示例

utils.js

// 导出
export const baseURL = 'http://hmajax.itheima.net'
export const getArraySum = arr => arr.reduce((sum, item) => sum += item, 0)

index.js

// 默认导入导出
import {baseURL, getArraySum} from './utils.js'
console.log(baseURL);
console.log(getArraySum([1,2,5]));

package.json

{ "type" : "module" }

本节总结

1. Node.js 支持哪 2 种模块化标准?
➢ CommonJS 标准语法(默认)
➢ ECMAScript 标准语法
2. ECMAScript 标准,命名导出和导入的语法?
➢ 导出:export 修饰定义的语句
➢ 导入:import { 同名变量 } from '模块名或路径‘
3. ECMAScript 标准,默认导出和导入的语法?
➢ 导出:export default {}
➢ 导入:import 变量名 from '模块名或路径'

六、包

1.包

包:将模块,代码,其他资料聚合成一个文件夹

包分类:

✓ 项目包:主要用于编写项目和业务逻辑

✓ 软件包:封装工具和方法进行使用

要求:根目录中,必须有 package.json 文件(记录包的清单信息)

  • 示例:package.json

在这里插入图片描述

注意:导入软件包时,默认引入该包中的 index.js 模块文件 。如果没有找到,就引入package.json文件中 main 属性指定的模块文件。

  • 案例

需求:封装数组求和函数的模块,判断用户名和密码长度函数的模块,形成成一个软件包

V:\Web\mycode\nodejs\10 package\server.js

在这里插入图片描述

总结

1. 什么是包?
➢ 将模块,代码,其他资料聚合成的文件夹
2. 包分为哪 2 类呢?
➢ 项目包:编写项目代码的文件夹
➢ 软件包:封装工具和方法供开发者使用
3. package.json 文件的作用?
➢ 记录软件包的名字,作者,入口文件等信息
4. 导入一个包文件夹的时候,导入的是哪个文件?
➢ 默认 index.js 文件,package.json文件中 main 属性指定的文件

文件 —— 模块
文件夹 —— 包

2.npm

npm - 软件包管理器

npm是Node.js标准的软件包管理器。

它起初是作为下载和管理Node.js包依赖的方式(下载和管理Node.js中需要的软件包),但其现在也已成为前端JavaScript中使用的工具。

使用:

  1. 初始化清单文件 :npm init -y(得到 package.json 文件,用于记录当前项目下载过哪些软件包,有则略过此命令)

  2. 下载软件包 :npm i 软件包名称

  3. 使用软件包

  • 示例: 需求:使用 dayjs 软件包,来格式化日期时间

① 创建一个项目文件夹

② 初始化清单文件 :npm init -y ,得到 package.json 文件,用于记录当前项目下载过哪些软件包

③ npm i dayjs 命令, 从npm资源库中下载该软件包到当前项目文件夹中的node_modules文件夹中。(1) 同时npm会记录dayjs包的名字、版本号 到 package.json 文件中(具体是dependencies选项里)(2)还会生成一个package-lock.json文件,主要作用是固化下载的软件包对应的版本号。(固化原因:开发项目的过程中如果修改这个软件包,使用过的方法会有问题,为了保证当前项目可以正常运行)

④自己的项目文件中导入dayjs包 并引用方法

流程图:
在这里插入图片描述

  • 案例

V:\Web\mycode\nodejs\11 npm_use\server.js

总结

1. npm 软件包管理器作用?
➢ 下载软件包以及管理版本
2. 初始化项目清单文件 package.json 命令?
➢ npm init -y
3. 下载软件包的命令?
➢ npm i 软件包名字
4. 下载的包会存放在哪里?
➢ 当前项目下的 node_modules 中,并记录在 package.json 中
npm - 安装所有依赖

从网上找到的代码 少了 node_modules文件夹

在这里插入图片描述

项目中不包含 node_modules,不能正常运行。因为缺少依赖的本地软件包。

为什么别人不把node_modules传递给我们呢?因为,自己用 npm 下载依赖比磁盘传递拷贝要快得多。

解决:项目终端输入命令:【npm i】 (注意下载路径要对)

下载 package.json 中记录的所有软件包

BV1MN411y7 , P95

总结
1. 当项目中只有 package.json 没有 node_modules 怎么办?
➢ 当前项目下,执行 npm i 安装所有依赖软件包
2. 为什么 node_modules 不进行传递?
➢ 因为用 npm 下载比磁盘传递要快
npm - 全局软件包 nodemon

BV1MN411y7pw, P96

软件包区别:

➢ 本地软件包:当前项目内使用,封装属性和方法,存在于 node_modules

➢ 全局软件包:本机所有项目使用,封装命令和工具,存在于系统设置的位置

nodemon 作用:替代 node 命令,检测我们编写的代码是否发生更改,然后自动重启程序

使用nodemon:

  1. 安装:npm i nodemon -g(-g 代表安装到全局环境中,因此下载的时候终端路径是什么都可以)
  2. 运行:nodemon 待执行的目标 js 文件
总结
1. 本地软件包和全局软件包区别?
➢ 本地软件包,作用在当前项目,封装属性和方法
➢ 全局软件包,本机所有项目使用,封装命令和工具
2. nodemon 作用?
➢ 替代 node 命令,检测代码更改,自动重启程序
3. nodemon 怎么用?
➢ 先确保安装 npm i nodemon -g
➢ 使用 nodemon 执行目标 js 文件

七、Node.js总结

1.Node.js 模块化:

概念:每个文件当做一个模块,独立作用域,按需加载

使用:采用特定的标准语法导出和导入进行使用
在这里插入图片描述

CommonJS 标准:一般应用在 Node.js 项目环境中

ECMAScript 标准:一般应用在前端工程化项目中

2.Node.js 包

Node.js 包:

  • 概念:把模块文件,代码文件,其他资料聚合成一个文件夹

  • 包的分类

​ 项目包:编写项目需求和业务逻辑的文件夹

​ 软件包:封装工具和方法进行使用的文件夹(一般使用 npm 管理)

​ 软件包分类:

​ ✓ 本地软件包:作用在当前项目,一般封装的属性/方法,供项目调用编写业务需求

​ ✓ 全局软件包:作用在所有项目,一般封装的命令/工具,支撑项目运行

在这里插入图片描述

3.常用命令

,然后自动重启程序

使用nodemon:

  1. 安装:npm i nodemon -g(-g 代表安装到全局环境中,因此下载的时候终端路径是什么都可以)
  2. 运行:nodemon 待执行的目标 js 文件
总结
1. 本地软件包和全局软件包区别?
➢ 本地软件包,作用在当前项目,封装属性和方法
➢ 全局软件包,本机所有项目使用,封装命令和工具
2. nodemon 作用?
➢ 替代 node 命令,检测代码更改,自动重启程序
3. nodemon 怎么用?
➢ 先确保安装 npm i nodemon -g
➢ 使用 nodemon 执行目标 js 文件

七、Node.js总结

1.Node.js 模块化:

概念:每个文件当做一个模块,独立作用域,按需加载

使用:采用特定的标准语法导出和导入进行使用

[外链图片转存中…(img-utaMSZxB-1710427561669)]

CommonJS 标准:一般应用在 Node.js 项目环境中

ECMAScript 标准:一般应用在前端工程化项目中

2.Node.js 包

Node.js 包:

  • 概念:把模块文件,代码文件,其他资料聚合成一个文件夹

  • 包的分类

​ 项目包:编写项目需求和业务逻辑的文件夹

​ 软件包:封装工具和方法进行使用的文件夹(一般使用 npm 管理)

​ 软件包分类:

​ ✓ 本地软件包:作用在当前项目,一般封装的属性/方法,供项目调用编写业务需求

​ ✓ 全局软件包:作用在所有项目,一般封装的命令/工具,支撑项目运行

[外链图片转存中…(img-4aLpJCdz-1710427561671)]

3.常用命令

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/456960.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Docker 搭建 PaddleOCR

转自PaddleOCR docker模式 - 简书 目的: 公司要放弃第三方的ocr工具(日语),需要自己搭建训练一套,这篇是搭建 图片要标出文字的选取框 因为是日文所以ocr有专门的工具,只需要文字坐标就好如图 日文的账票需要加密一下 我得环境是 Ubuntu 22.04.1 LTS 1,下载代码 cd /hom…

第 7 场 小白入门赛

第5题 &#xff1a;兽之泪【算法赛】 AC_Code:C #include <iostream> #include <cstring> #include <algorithm> #include <vector> #include <queue> #include<stack> #include<cmath> #include <unordered_set> #include &…

介绍Oracle的SQL调化健康检查脚本(SQLHC)

概述 Oracle提供了一个SQL调优健康检查脚本&#xff08;SQLHC&#xff09;&#xff0c;用于检查需要优化的SQL的运行环境&#xff0c;生成报告以便帮助DBA找到SQL性能不佳的原因。SQLHC是SQLT的一个子集&#xff08;我后续的文章会介绍SQLT&#xff09;&#xff0c;但SQLHC与S…

【string一些函数用法的补充】

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言 string类对象的修改操作 我们来看 c_str 返回c格式的字符串的操作&#xff1a; 我们来看 rfind 和 substr 的操作&#xff1a; string类非成员函数 我们来看 r…

安全访问服务边缘解决方案

随着云计算、大数据和物联网技术的快速发展&#xff0c;企业对于业务数据的访问需求日益增多&#xff0c;而安全访问服务边缘&#xff08;Secure Access Service Edge&#xff0c;SASE&#xff09;作为一种新兴的网络架构&#xff0c;正逐渐成为企业保障数据安全、优化网络性能…

Python引入其他文件作为包

1.首先当我们写的代码&#xff0c;可能要被其他文件引用&#xff0c;那么在建文件夹的时候&#xff0c;记得选包 不是文件夹&#xff01;&#xff08;选第4个&#xff0c;不是第3个&#xff09; 因为文件夹默认没有init 方法&#xff0c;不能导包... 如果已经是文件夹了&#…

Claude3、Gemini、Sora与GPT-4:谁将成为AI领域的明日之星?

【最新增加Claude3、Gemini、Sora、GPTs讲解及AI领域中的集中大模型的最新技术】 2023年随着OpenAI开发者大会的召开&#xff0c;最重磅更新当属GPTs&#xff0c;多模态API&#xff0c;未来自定义专属的GPT。微软创始人比尔盖茨称ChatGPT的出现有着重大历史意义&#xff0c;不亚…

ECCV2022 | BEVFormer原文翻译

BEVFormer: Learning Bird’s-Eye-View Representation from Multi-Camera Images via Spatiotemporal Transformers BEVFormer: 通过时空变换器从多摄像头图像中学习鸟瞰图表征 Figure 1: We propose BEVFormer, a paradigm for autonomous driving that applies both Trans…

【Java探索之旅】运算符解析 算术运算符,关系运算符

&#x1f3a5; 屿小夏 &#xff1a; 个人主页 &#x1f525;个人专栏 &#xff1a; Java编程秘籍 &#x1f304; 莫道桑榆晚&#xff0c;为霞尚满天&#xff01; 文章目录 &#x1f4d1;前言一、什么是运算符二、算术运算符2.1 基本四则运算&#xff08;-*/%&#xff09;2.2 增…

2049.不容易系列之(4)——考新郎

2048的升级 当nm时则全排错&#xff0c;与上题一样 当n>m时&#xff0c;则有n-m个是排对的&#xff0c;剩下m个全错 import java.util.*;public class Main {public static void main(String[] args) {Scanner scannernew Scanner(System.in);int num scanner.nextInt()…

LeetCode2.07链表相交

2.07链表相交 给你两个单链表的头节点 headA 和 headB &#xff0c;请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点&#xff0c;返回 null 。 图示两个链表在节点 c1 开始相交&#xff1a; 题目数据 保证 整个链式结构中不存在环。 注意&#xff0c;函数返回结…

洛谷 P5018 对称二叉树

题目背景 NOIP2018 普及组 T4 题目描述 一棵有点权的有根树如果满足以下条件&#xff0c;则被轩轩称为对称二叉树&#xff1a; 二叉树&#xff1b;将这棵树所有节点的左右子树交换&#xff0c;新树和原树对应位置的结构相同且点权相等。 下图中节点内的数字为权值&#xf…

Compose UI 之 BottomAppBar 底部应用栏

BottomAppBar 底部应用栏 BottomAppBar 是一个在 Jetpack Compose 中用于创建底部应用栏的组件。它提供了一个高度可定制且功能丰富的底部导航解决方案。 它的使用方式与 TopAppBar 类似。下面的图是 BottomAppBar 的基本样式图。 常见使用场景 BottomAppBar 在应用中常用于…

【JavaScript】使用debugger语句快速开启浏览器调试代码工具

简言 有的时候我们想开启浏览器代码调试功能&#xff0c;这个时候应该使用debugger语句。 debugger debugger 语句调用任何可用的调试功能&#xff0c;例如设置断点。如果没有调试功能可用&#xff0c;则此语句不起作用。 debugger;可以多次使用 debugger语句&#xff0c;使…

蓝桥杯练习系统(算法训练)ALGO-976 P0804字符串压缩

资源限制 内存限制&#xff1a;256.0MB C/C时间限制&#xff1a;1.0s Java时间限制&#xff1a;3.0s Python时间限制&#xff1a;5.0s 编写一个函数void strcompress(char *s)&#xff0c;输入一个字符串&#xff08;只包含小写字母和空格&#xff0c;且长度小于1000&am…

基于springboot社团管理系统的设计与实现

互联网发展至今&#xff0c;无论是其理论还是技术都已经成熟&#xff0c;而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播&#xff0c;搭配信息管理工具可以很好地为人们提供服务。针对信息管理混乱&#xff0c;出错率高&#xff0c;信息安全性差&#xff0c;劳…

leetcode代码记录(有效的括号

目录 1. 题目&#xff1a;2. 我的代码&#xff1a;小结&#xff1a; 1. 题目&#xff1a; 给定一个只包括 ‘(’&#xff0c;‘)’&#xff0c;‘{’&#xff0c;‘}’&#xff0c;‘[’&#xff0c;‘]’ 的字符串 s &#xff0c;判断字符串是否有效。 有效字符串需满足&…

香港理工大学主办!2024年第八届电力能源系统与应用国际会议(ICoPESA 2024)即将召开!

2024年第八届电力能源系统与应用国际会议&#xff08;ICoPESA 2024&#xff09; 2024年6月24日-26日 中国香港 ICoPESA 2024-Hong Kong (icpesa.org)https://icpesa.org/index.html 会议组织单位 会议出版及检索&#xff1a; 会议录用并注册的论文将由IEEE出版&#xff0c;…

Let’s Move Sui , 一起来学习吧

Let’s Move Sui是一个全新的交互式学习平台&#xff0c;通过SuiFrens的帮助教您如何在Sui上构建。设计供新手和经验丰富的开发者使用&#xff0c;Let’s Move Sui提供了一次非凡的Sui开发之旅&#xff0c;利用了Move在Sui上的独特之处&#xff0c;从基于对象的数据模型的基础知…

3、鸿蒙学习-在AGC创建HarmonyOS 项目或应用

项目和应用介绍 关于项目 项目是资源、应用的组织实体。资源包括服务器、数据库、存储&#xff0c;以及您的应用、终端用户的数据等。在您使用部分服务时&#xff0c;您是数据的控制者&#xff0c;数据将按照您设置的数据处理位置来存储在指定区域。 通常&#xff0c;您不需…
最新文章