38 releases (23 stable)

Uses old Rust 2015

1.16.0 Jun 29, 2023
1.15.0 Dec 20, 2022
1.14.0 Nov 3, 2022
1.13.1 Dec 20, 2021
0.1.0 Mar 16, 2015

#1 in Hardware support

Download history 1690002/week @ 2024-07-27 1646569/week @ 2024-08-03 1677550/week @ 2024-08-10 1607104/week @ 2024-08-17 1622480/week @ 2024-08-24 1514161/week @ 2024-08-31 1647129/week @ 2024-09-07 1502114/week @ 2024-09-14 1808202/week @ 2024-09-21 1818243/week @ 2024-09-28 2342514/week @ 2024-10-05 2154001/week @ 2024-10-12 2239252/week @ 2024-10-19 1704949/week @ 2024-10-26 1704632/week @ 2024-11-02 1403156/week @ 2024-11-09

7,354,115 downloads per month
Used in 12,627 crates (1,546 directly)

MIT/Apache

34KB
792 lines

num_cpus

crates.io CI Status

Count the number of CPUs on the current machine.

Usage

Add to Cargo.toml:

[dependencies]
num_cpus = "1.0"

In your main.rs or lib.rs:

extern crate num_cpus;

// count logical cores this process could try to use
let num = num_cpus::get();

lib.rs:

A crate with utilities to determine 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.

Examples

Fetch the number of logical CPUs.

let cpus = num_cpus::get();

See rayon::Threadpool for an example of where the number of CPUs could be used when setting up parallel jobs (Where the threadpool example uses a fixed number 8, it could use the number of CPUs).

Dependencies

~53KB