Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Non-macro biased Select? #1145

Closed
SimonSapin opened this issue Nov 7, 2024 · 1 comment · Fixed by #1150
Closed

Non-macro biased Select? #1145

SimonSapin opened this issue Nov 7, 2024 · 1 comment · Fixed by #1150

Comments

@SimonSapin
Copy link
Contributor

#1040 added a select_biased! macro. Some internal functions gained an is_biased: bool parameter to support it, but the non-macro public API around the Select type does not expose this functionality at all. Some of those internal functions are only ever called with false. Biased functionality could be useful to add to the Select type but I’m not sure what the API should look like exactly. ~Doubling the number of methods does not feel great.

For context: I’m building a priority queue on top of an array of crossbeam channels. My receiver should block until any of the inner receivers are ready, but then consume one item from the highest-priority channel rather than arbitrary one. (Starvation is mitigated by "ageing" some low-priority items into a one-level-higher priority channel.) As a work-around I call Select::ready() then an explicit loop with Receiver::try_recv(), but this looks like it does redundant work compared to an hypothetical Select::biased_select()

@taiki-e
Copy link
Member

taiki-e commented Dec 15, 2024

Added in crossbeam-channel 0.5.14 (#1150).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Development

Successfully merging a pull request may close this issue.

2 participants