有了它 ,我彻底告别了 try-finally 🔥🔥🔥

前言

前几天看到 Rspack 团队宣布即将支持 using 声明,

今天我们来看看 using 的神奇用法!

往期精彩推荐

正文

using 声明是 ECMAScript 提案中的一项新特性,旨在简化资源管理!

Node.js 从 v20 开始实验性支持此功能。

大家可以通过以下命令在 Node.js 中启用实验性支持:

bash 复制代码
node --harmony-explicit-resource-management app.js

其核心特点如下:

  • 声明式资源管理 :通过 using 关键字定义需自动清理的资源。
  • 自动释放 :作用域结束时调用资源的 [Symbol.dispose] 方法。
  • 异步支持usingawait using 分别支持同步和异步资源。

下面是基础使用示例,带大家感受它的简洁之处!

1. 同步资源管理:using 声明

传统资源读取会依赖 try-finally 块,代码冗长且易出错:

javascript 复制代码
import { open } from 'fs/promises';

async function readFile() {
  const file = await open('data.txt', 'r');
  try {
    const content = await file.readFile('utf8');
    console.log(content);
  } finally {
    await file.close();
  }
}

"using" 声明适用于需要手动管理生命周期的资源,如文件句柄或数据库连接。

javascript 复制代码
import { open } from 'fs/promises';

{
  using file = await open('data.txt', 'r');
  const content = await file.readFile('utf8');
  console.log(content);
}

file 自动关闭,无需显式调用 file.close()

这比传统的 try-finally 更简洁,减少了样板代码。

2. 异步资源管理:await using

对于异步资源(如数据库连接或网络请求),await using 结合了 awaitusing,确保异步资源在作用域结束时通过 [Symbol.asyncDispose] 清理。

javascript 复制代码
import { createConnection } from 'some-db-driver';

async function queryData() {
  await using db = await createConnection('mysql://localhost');
  const result = await db.query('SELECT * FROM users');
  return result;
} 

这里,db 在作用域结束时调用 [Symbol.asyncDispose],自动关闭数据库连接,避免资源泄漏。

3. 自定义资源管理

开发者可以为自定义对象实现 [Symbol.dispose][Symbol.asyncDispose],以支持 "using" 声明。

javascript 复制代码
class TempResource {
  constructor(name) {
    this.name = name;
  }
  [Symbol.dispose]() {
    console.log(`${this.name} disposed`);
  }
}

{
  using resource = new TempResource('temp');
  console.log('Using resource:', resource.name);
}

这种灵活性让 "using" 声明适用于各种场景,从内存管理到外部资源清理。

最后

使用 "using" 声明,代码更简洁,清理逻辑自动处理,减少出错风险~

今天的分享就这些了,感谢大家的阅读!如果文章中存在错误的地方欢迎指正!

往期精彩推荐

相关推荐
2601_949857431 分钟前
Flutter for OpenHarmony Web开发助手App实战:文本统计
前端·flutter
光影少年9 分钟前
智能体UI ux pro max
前端·ui·ux
酒鼎10 分钟前
学习笔记(7-01)函数闭包
javascript
半梅芒果干11 分钟前
vue3 实现无缝循环滚动
前端·javascript·vue.js
qq_4198540516 分钟前
锚点跳转及鼠标滚动与锚点高亮联动
前端
冰敷逆向24 分钟前
京东h5st纯算分析
java·前端·javascript·爬虫·安全·web
多多*1 小时前
2026年最新 测试开发工程师相关 Linux相关知识点
java·开发语言·javascript·算法·spring·java-ee·maven
Laurence1 小时前
从零到一构建 C++ 项目(IDE / 命令行双轨实现)
前端·c++·ide
会编程的土豆1 小时前
简易植物大战僵尸游戏 JavaScript版之html
javascript·游戏·html
雯0609~1 小时前
hiprint-官网vue完整版本+实现客户端配置+可实现直接打印(在html版本增加了条形码、二维码拖拽等)
前端·javascript·vue.js