hashbrown VS cpython

Compare hashbrown vs cpython and see what are their differences.

hashbrown

Rust port of Google's SwissTable hash map (by rust-lang)
Our great sponsors
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • WorkOS - The modern identity platform for B2B SaaS
  • SaaSHub - Software Alternatives and Reviews
hashbrown cpython
22 5
2,261 3
2.0% -
8.2 0.0
14 days ago almost 2 years ago
Rust Python
Apache License 2.0 GNU General Public License v3.0 or later
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

hashbrown

Posts with mentions or reviews of hashbrown. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-01-13.
  • OpenD, a D language fork that is open to your contributions
    9 projects | news.ycombinator.com | 13 Jan 2024
    That's because you're looking at a wrapper around the actual implementation (which lives in an external package). Notice "use hashbrown::hash_map as base;" at the top.

    There's far more unsafe there: https://github.com/rust-lang/hashbrown/blob/f2e62124cd947b5e...

  • I just published my first crate: `identified_vec` - I would love some input! PR's are most welcome.
    4 projects | /r/learnrust | 9 Dec 2023
    You might want to check out how popular ecosystem crates do some of these things. Particularly relevant to you are probably crates providing collections, such as smallvec, hashbrown, or indexmap.
  • GDlog: A GPU-Accelerated Deductive Engine
    16 projects | news.ycombinator.com | 3 Dec 2023
    https://github.com/topics/swisstable

    rust-lang/hashbrown: https://github.com/rust-lang/hashbrown

    CuPy has array but not yet hashmaps, or (GPU) SIMD FWICS?

    NumPy does SIMD:

  • When Zig Outshines Rust – Memory Efficient Enum Arrays
    7 projects | news.ycombinator.com | 18 Sep 2023
    Thanks, great point indeed. I am looking into this https://github.com/rust-lang/hashbrown

    The way I think about it -- rather naively, I suppose -- is that I care more about the references cells make to each other than the actual grid of cells displayed on a table. The latter feels more like a "view" of the data than an actual data structure?

    This also seems to align with the relative priority of (sorted from highest to lowest): figuring out the order of evaluation, calculating those evaluations, and finally displaying the results of the evaluation

  • This Week in Rust # 500!!
    1 project | /r/rust | 22 Jun 2023
    updated std's hashbrown dependency to 0.14 which contains some optimizations
  • Crust of Rust: std::collections [video]
    1 project | /r/rust | 7 May 2023
    The std hashmap is actually very fast and uses state of the art hashmap design, namely because it's implemented by hashbrown
  • Deduplicating a Slice in Go
    3 projects | news.ycombinator.com | 12 Apr 2023
    I believe Rust uses hashbrown as the underlying implementation now. This just calculates the number of buckets based on the number of items requested:

    https://github.com/rust-lang/hashbrown/blob/009969a860290849...

    Is it really the case that rehashing can guarantee that the number of buckets allocated will be sufficient for any given set of keys? In principle you could fail to rehash in a way that reduces collisions after k attempted rehashings.

  • Blog Post: Rust Is a Scalable Language
    2 projects | /r/rust | 28 Mar 2023
    For example, since the hashbrown crate is marked with #![no_std], it can be used as a dependency for the standard library.
  • Hey Rustaceans! Got a question? Ask here (6/2023)!
    6 projects | /r/rust | 8 Feb 2023
    To implement something that cannot be expressed in safe Rust, or at least cannot be expressed succinctly in safe Rust, like fundamental datastructures. The hashbrown crate contains a lot of unsafe code, but it's such high quality that it's now the backing implementation for std::collections::HashMap.
  • Data-driven performance optimization with Rust and Miri
    9 projects | news.ycombinator.com | 9 Dec 2022

cpython

Posts with mentions or reviews of cpython. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2021-03-30.

What are some alternatives?

When comparing hashbrown and cpython you can also consider the following projects:

dashmap - Blazing fast concurrent HashMap for Rust.

xxHash - Extremely fast non-cryptographic hash algorithm

meow_hash - Official version of the Meow hash, an extremely fast level 1 hash

flamegraph - Easy flamegraphs for Rust projects and everything else, without Perl or pipes <3

CPython - The Python programming language

bumpalo - A fast bump allocation arena for Rust

moonfire-nvr - Moonfire NVR, a security camera network video recorder

aoc - 🎄 My solutions and walkthroughs for Advent of Code and more related stuff.

aoc-2020 - Advent of Code 2020

cargo-flamegraph - Easy flamegraphs for Rust projects and everything else, without Perl or pipes <3

rust - Empowering everyone to build reliable and efficient software.