Skip to content
This repository has been archived by the owner on Mar 19, 2022. It is now read-only.

justjavac/deno_plugin_num_cpus

Repository files navigation

deno_plugin_num_cpus

Build Status tag Crates.io Docs.rs license

Rust num_cpus binding for Deno.

Get the number of CPUs available on the current system.

Sometimes the CPU will exaggerate the number of CPUs it contains, because it can use processor tricks to deliver increased performance when there are more threads. This crate provides methods to get both the logical and physical numbers of cores.

This information can be used as a guide to how many tasks can be run in parallel. There are many properties of the system architecture that will affect parallelism, for example memory access speeds (for all the caches and RAM) and the physical architecture of the processor, so the number of CPUs should be used as a rough guide only.

Ops

op_num_cpus

Get the number of CPUs available on the current system.

Use in Deno:

const { op_num_cpus } = Deno.core.ops();
const response: Uint8Array = Deno.core.dispatch(op_num_cpus)!;

Returned Binary Layout:

+----------------+----------------+----------------+----------------+
|   NUM_CPUS (8) |                |                |                |
+----------------+----------------+----------------+----------------+

The number of cpu on each machine will not be greater than 256(2^8), so we use 1 byte to pass the return value.

License

deno_plugin_num_cpus is released under the MIT License. See the bundled LICENSE file for details.