2016-03-08 08:30:09 +00:00
|
|
|
|
# 进程
|
|
|
|
|
|
2016-12-30 09:15:28 +00:00
|
|
|
|
> process 对象扩展。
|
2016-03-08 08:30:09 +00:00
|
|
|
|
|
2016-12-30 02:45:39 +00:00
|
|
|
|
Process: [Main](../glossary.md#main-process), [Renderer](../glossary.md#renderer-process)
|
|
|
|
|
|
|
|
|
|
Electron 的 `process` 对象是
|
2016-12-30 09:15:28 +00:00
|
|
|
|
[Node.js `process` 对象](https://nodejs.org/api/process.html) 的扩展。
|
|
|
|
|
它添加了以下事件、属性和方法:
|
2016-03-08 08:30:09 +00:00
|
|
|
|
|
|
|
|
|
## 事件
|
|
|
|
|
|
|
|
|
|
### 事件: 'loaded'
|
|
|
|
|
|
2016-12-30 09:15:28 +00:00
|
|
|
|
在Electron已经加载了其内部预置脚本和它准备加载网页或者主进程的时候触发。
|
2016-03-08 08:30:09 +00:00
|
|
|
|
|
2016-12-30 09:15:28 +00:00
|
|
|
|
当node被完全关闭的时候,它可以被预加载脚本使用来添加(原文: removed)与node无关的全局符号来回退到全局范围:
|
2016-03-08 08:30:09 +00:00
|
|
|
|
|
2016-10-03 22:48:04 +00:00
|
|
|
|
```javascript
|
2016-03-08 08:30:09 +00:00
|
|
|
|
// preload.js
|
2016-12-30 02:45:39 +00:00
|
|
|
|
const _setImmediate = setImmediate
|
|
|
|
|
const _clearImmediate = clearImmediate
|
|
|
|
|
process.once('loaded', () => {
|
2016-10-03 03:47:16 +00:00
|
|
|
|
global.setImmediate = _setImmediate
|
|
|
|
|
global.clearImmediate = _clearImmediate
|
|
|
|
|
})
|
2016-03-08 08:30:09 +00:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
## 属性
|
|
|
|
|
|
|
|
|
|
### `process.noAsar`
|
|
|
|
|
|
2016-12-30 09:15:28 +00:00
|
|
|
|
设置它为 `true` 可以使 `asar` 文件在node的内置模块中失效。
|
2016-03-08 08:30:09 +00:00
|
|
|
|
|
2016-12-30 02:45:39 +00:00
|
|
|
|
### `process.type`
|
|
|
|
|
|
2016-12-30 09:15:28 +00:00
|
|
|
|
当前 `process` 的类型,值为`"browser"` (即主进程) 或 `"renderer"`。
|
2016-12-30 02:45:39 +00:00
|
|
|
|
|
|
|
|
|
### `process.versions.electron`
|
|
|
|
|
|
2016-12-30 09:15:28 +00:00
|
|
|
|
Electron的版本号。
|
2016-12-30 02:45:39 +00:00
|
|
|
|
|
|
|
|
|
### `process.versions.chrome`
|
|
|
|
|
|
2016-12-30 09:15:28 +00:00
|
|
|
|
Chrome的版本号。
|
2016-12-30 02:45:39 +00:00
|
|
|
|
|
|
|
|
|
### `process.resourcesPath`
|
|
|
|
|
|
2016-12-30 09:15:28 +00:00
|
|
|
|
资源文件夹的路径。
|
2016-12-30 02:45:39 +00:00
|
|
|
|
|
|
|
|
|
### `process.mas`
|
|
|
|
|
|
2016-12-30 09:15:28 +00:00
|
|
|
|
在 Mac App Store 的构建中,该属性为 `true`, 其他平台的构建均为 `undefined`。
|
2016-12-30 02:45:39 +00:00
|
|
|
|
|
|
|
|
|
### `process.windowsStore`
|
|
|
|
|
|
2016-12-30 09:15:28 +00:00
|
|
|
|
如果 app 是运行在 Windows Store app (appx) 中,该属性为 `true`, 其他情况均为 `undefined`。
|
2016-12-30 02:45:39 +00:00
|
|
|
|
|
|
|
|
|
### `process.defaultApp`
|
|
|
|
|
|
2016-12-30 09:15:28 +00:00
|
|
|
|
当 app 在启动时,被作为参数传递给默认应用程序,在主进程中该属性为 `true`, 其他情况均为 `undefined`。
|
2016-12-30 02:45:39 +00:00
|
|
|
|
|
2016-03-08 08:30:09 +00:00
|
|
|
|
## 方法
|
|
|
|
|
|
2016-12-30 09:15:28 +00:00
|
|
|
|
`process` 对象有如下方法:
|
2016-03-08 08:30:09 +00:00
|
|
|
|
|
2016-12-30 02:45:39 +00:00
|
|
|
|
### `process.crash()`
|
|
|
|
|
|
2016-12-30 09:15:28 +00:00
|
|
|
|
使当前进程的主线程崩溃。
|
2016-12-30 02:45:39 +00:00
|
|
|
|
|
2016-03-08 08:30:09 +00:00
|
|
|
|
### `process.hang()`
|
|
|
|
|
|
2016-12-30 09:15:28 +00:00
|
|
|
|
使当前进程的主线程挂起。
|
2016-03-08 08:30:09 +00:00
|
|
|
|
|
2016-06-18 13:26:26 +00:00
|
|
|
|
### `process.setFdLimit(maxDescriptors)` _macOS_ _Linux_
|
2016-03-08 08:30:09 +00:00
|
|
|
|
|
|
|
|
|
* `maxDescriptors` Integer
|
|
|
|
|
|
2016-12-30 02:45:39 +00:00
|
|
|
|
设置文件描述符软限制于 `maxDescriptors` 或硬限制于OS, 无论它是否低于当前进程.
|
|
|
|
|
|
|
|
|
|
### `process.getProcessMemoryInfo()`
|
|
|
|
|
|
2016-12-30 09:15:28 +00:00
|
|
|
|
返回 `Object`:
|
2016-12-30 02:45:39 +00:00
|
|
|
|
|
2016-12-30 09:15:28 +00:00
|
|
|
|
* `workingSetSize` Integer - 当前固定到实际物理内存的内存量。
|
|
|
|
|
* `peakWorkingSetSize` Integer - 被固定在实际物理内存上的最大内存量。
|
2016-12-30 02:45:39 +00:00
|
|
|
|
* `privateBytes` Integer - 不被其他进程共享的内存量,如JS堆或HTML内容。
|
2016-12-30 09:15:28 +00:00
|
|
|
|
* `sharedBytes` Integer - 进程之间共享的内存量,通常是 Electron 代码本身所消耗的内存。
|
2016-12-30 02:45:39 +00:00
|
|
|
|
|
2016-12-30 09:15:28 +00:00
|
|
|
|
返回当前进程的内存使用统计信息的对象. 请注意,所有数据的单位都是KB。
|
2016-12-30 02:45:39 +00:00
|
|
|
|
|
|
|
|
|
### `process.getSystemMemoryInfo()`
|
|
|
|
|
|
2016-12-30 09:15:28 +00:00
|
|
|
|
返回 `Object`:
|
2016-12-30 02:45:39 +00:00
|
|
|
|
|
2016-12-30 09:15:28 +00:00
|
|
|
|
* `total` Integer - 系统的物理内存总量。
|
|
|
|
|
* `free` Integer - 未被应用程序或磁盘缓存使用的物理内存总量。
|
|
|
|
|
* `swapTotal` Integer - 系统 swap 分区(虚拟内存)总量。 _Windows_ _Linux_
|
|
|
|
|
* `swapFree` Integer - 系统剩余可用的 swap 分区(虚拟内存)量。 _Windows_ _Linux_
|
2016-12-30 02:45:39 +00:00
|
|
|
|
|
2016-12-30 09:15:28 +00:00
|
|
|
|
返回系统的内存使用统计信息的对象. 请注意,所有数据的单位都是KB。
|