阳江[切换]
免费发布信息
您当前的位置: 阳江百修网> 阳江工控产品维修>阳江数控系统维修> >广数980系统机床锁怎么解除

广数980系统机床锁怎么解除

广数980系统机床锁怎么解除
服务区域
阳江市-阳东县
服务范围
数控机床
发布日期
2023-04-22 14:33:32
标签
广数980系统,机床解锁,密码

温馨提示:此页面服务由第三方为您提供,交易前请仔细核对商家真实资质,勿信夸张宣传和承诺,勿轻易相信预付定金、汇款等交易方式; 此页面所发布文字及图片均由网民自行发布,如有侵权请联系发布者删除。

产品介绍

广数980系统机床锁怎么解除通常情况下,Node.js被认为是单线程。由主线程去按照编码顺序一步步执行*代码,一旦遇到同步代码阻塞,主线程就会被占用,后续的*代码的执行都会被卡住。没错Node.js的单线程指的是主线程是"单线程"。

为了解决单线程带来的问题,本文的主角worker_threads出现了。worker_threads首次在Node.js v10.5.0作为实验性功能出现,需要命令行带上--experimental-worker才能使用。直到v12.11.0稳定版才能正式使用。

本文将会介绍worker_threads的使用方式,以及利用worker_threads执行斐波那契数列作为实践例子。

先决条件
阅读并食用本文,需要先具备:

安装了 Node.js v12.11.0 及以上版本
掌握 JavaScript 同步和异步编程的基础知识
掌握 Node.js 的工作原理
worker_threads 介绍
worker_threads 模块允许使用并行执行 JavaScript 的线程。

工作线程对于执行 CPU 密集型的 JavaScript 操作很有用。 它们对 I/O 密集型的工作帮助不大。 Node.js 内置的异步 I/O 操作比工作线程更高效。

与 child_process 或 cluster 不同,worker_threads 可以共享内存。 它们通过传输 ArrayBuffer 实例或共享 SharedArrayBuffer 实例来实现。

由于以下特性,worker_threads已被证明是充分利用CPU性能的*解决方案:

它们运行具有多个线程的单个进程。

每个线程执行一个事件循环。

每个线程运行单个 JS 引擎实例。

每个线程执行单个 Nodejs 实例。

worker_threads 如何工作
worker_threads通过执行主线程指定的脚本文件来工作。每个线程都在与其他线程隔离的情况下执行。但是,这些线程可以通过消息通道来回传递消息。

主线程使用worker.postMessage()函数使用消息通道,而工作线程使用parentPort.postMessage()函数。

通过*示例代码加强了解:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

const {

  Worker, isMainThread, parentPort, workerData

} = require('worker_threads');

 

if (isMainThread) {

  module.exports = function parseJSAsync(script) {

    return new Promise((resolve, reject) => {

      const worker = new Worker(__filename, {

        workerData: script

      });

      worker.on('message', resolve);

      worker.on('error', reject);

      worker.on('exit', (code) => {

        if (code !== 0)

          reject(new Error(`Worker stopped with exit code ${code}`));

      });

    });

  };

} else {

  const { parse } = require('some-js-parsing-library');

  const script = workerData;

  parentPort.postMessage(parse(script));

}

上述代码主线程与工作线程都使用同一份文件作为执行脚本(__filename为当前执行文件路径),通过isMainThread来区分主线程与工作线程运行时逻辑。当模块对外暴露方法parseJSAsync被调用时候,都将会衍生子工作线程去执行调用parse函数。

worker_threads 具体使用
在本节使用具体例子介绍worker_threads的使用

创建工作线程脚本文件workerExample.js:

1

2

const { workerData, parentPort } = require('worker_threads')

parentPort.postMessage({ welcome: workerData })

创建主线程脚本文件main.js:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

const { Worker } = require('worker_threads')

 

const runWorker = (workerData) => {

    return new Promise((resolve, reject) => {

        // 引入 workerExample.js `工作线程`脚本文件

        const worker = new Worker('./workerExample.js', { workerData });

        worker.on('message', resolve);

        worker.on('error', reject);

        worker.on('exit', (code) => {

            if (code !== 0)

                reject(new Error(`stopped with  ${code} exit code`));

        })

    })

}

 

const main = async () => {

    const result = await runWorker('hello worker threads')

    console.log(result);

}

 

main().catch(err => console.error(err))

控制台命令行执行:

1

node main.js

输出:

1

{ welcome: 'hello worker threads' }

worker_threads 运算斐波那契数列
在本节中,让我们看一下 CPU 密集型示例,生成斐波那契数列。

如果在没有工作线程的情况下完成此任务,则会随着nth期限的增加而阻塞主线程。

企业信息
入驻时间:
2022年
主营产品:
数控机床
公司地址:
广东省阳江市阳东县艺鹏装饰
客服热线

意见反馈邮箱:354481597@qq.com

关注我们
百修网公众号

百修网公众号

百修公众号

百修公众号

师傅接单小程序

师傅接单小程序

苏ICP备09042555号-2 | 增值电信业务经营许可证:苏B2-20150120 | 公安部备案号:32020202000170 | Copyright © 无锡市新视点网络科技有限公司 版权所有