rtic/1/api/lock_api/trait.RawRwLockFair.html

32 lines
8.2 KiB
HTML
Raw Normal View History

<!DOCTYPE html><html lang="en"><head><meta charset="utf-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta name="generator" content="rustdoc"><meta name="description" content="Additional methods for `RwLock`s which support fair unlocking."><title>RawRwLockFair in lock_api - Rust</title><script>if(window.location.protocol!=="file:")document.head.insertAdjacentHTML("beforeend","SourceSerif4-Regular-6b053e98.ttf.woff2,FiraSans-Regular-0fe48ade.woff2,FiraSans-Medium-e1aa3f0a.woff2,SourceCodePro-Regular-8badfe75.ttf.woff2,SourceCodePro-Semibold-aa29a496.ttf.woff2".split(",").map(f=>`<link rel="preload" as="font" type="font/woff2" crossorigin href="../static.files/${f}">`).join(""))</script><link rel="stylesheet" href="../static.files/normalize-9960930a.css"><link rel="stylesheet" href="../static.files/rustdoc-42caa33d.css"><meta name="rustdoc-vars" data-root-path="../" data-static-root-path="../static.files/" data-current-crate="lock_api" data-themes="" data-resource-suffix="" data-rustdoc-version="1.84.0 (9fc6b4312 2025-01-07)" data-channel="1.84.0" data-search-js="search-92e6798f.js" data-settings-js="settings-0f613d39.js" ><script src="../static.files/storage-59e33391.js"></script><script defer src="sidebar-items.js"></script><script defer src="../static.files/main-5f194d8c.js"></script><noscript><link rel="stylesheet" href="../static.files/noscript-893ab5e7.css"></noscript><link rel="alternate icon" type="image/png" href="../static.files/favicon-32x32-6580c154.png"><link rel="icon" type="image/svg+xml" href="../static.files/favicon-044be391.svg"></head><body class="rustdoc trait"><!--[if lte IE 11]><div class="warning">This old browser is unsupported and will most likely display funky things.</div><![endif]--><nav class="mobile-topbar"><button class="sidebar-menu-toggle" title="show sidebar"></button></nav><nav class="sidebar"><div class="sidebar-crate"><h2><a href="../lock_api/index.html">lock_<wbr>api</a><span class="version">0.4.12</span></h2></div><div class="sidebar-elems"><section id="rustdoc-toc"><h2 class="location"><a href="#">RawRw<wbr>Lock<wbr>Fair</a></h2><h3><a href="#required-methods">Required Methods</a></h3><ul class="block"><li><a href="#tymethod.unlock_exclusive_fair" title="unlock_exclusive_fair">unlock_exclusive_fair</a></li><li><a href="#tymethod.unlock_shared_fair" title="unlock_shared_fair">unlock_shared_fair</a></li></ul><h3><a href="#provided-methods">Provided Methods</a></h3><ul class="block"><li><a href="#method.bump_exclusive" title="bump_exclusive">bump_exclusive</a></li><li><a href="#method.bump_shared" title="bump_shared">bump_shared</a></li></ul><h3><a href="#dyn-compatibility">Dyn Compatibility</a></h3><h3><a href="#implementors">Implementors</a></h3></section><div id="rustdoc-modnav"><h2 class="in-crate"><a href="index.html">In crate lock_<wbr>api</a></h2></div></div></nav><div class="sidebar-resizer"></div><main><div class="width-limiter"><rustdoc-search></rustdoc-search><section id="main-content" class="content"><div class="main-heading"><span class="rustdoc-breadcrumbs"><a href="index.html">lock_api</a></span><h1>Trait <span class="trait">RawRwLockFair</span><button id="copy-path" title="Copy item path to clipboard">Copy item path</button></h1><rustdoc-toolbar></rustdoc-toolbar><span class="sub-heading"><a class="src" href="../src/lock_api/rwlock.rs.html#107-149">Source</a> </span></div><pre class="rust item-decl"><code>pub unsafe trait RawRwLockFair: <a class="trait" href="trait.RawRwLock.html" title="trait lock_api::RawRwLock">RawRwLock</a> {
// Required methods
unsafe fn <a href="#tymethod.unlock_shared_fair" class="fn">unlock_shared_fair</a>(&amp;self);
<span class="item-spacer"></span> unsafe fn <a href="#tymethod.unlock_exclusive_fair" class="fn">unlock_exclusive_fair</a>(&amp;self);
// Provided methods
unsafe fn <a href="#method.bump_shared" class="fn">bump_shared</a>(&amp;self) { ... }
<span class="item-spacer"></span> unsafe fn <a href="#method.bump_exclusive" class="fn">bump_exclusive</a>(&amp;self) { ... }
}</code></pre><details class="toggle top-doc" open><summary class="hideme"><span>Expand description</span></summary><div class="docblock"><p>Additional methods for <code>RwLock</code>s which support fair unlocking.</p>
<p>Fair unlocking means that a lock is handed directly over to the next waiting
thread if there is one, without giving other threads the opportunity to
“steal” the lock in the meantime. This is typically slower than unfair
unlocking, but may be necessary in certain circumstances.</p>
</div></details><h2 id="required-methods" class="section-header">Required Methods<a href="#required-methods" class="anchor">§</a></h2><div class="methods"><details class="toggle method-toggle" open><summary><section id="tymethod.unlock_shared_fair" class="method"><a class="src rightside" href="../src/lock_api/rwlock.rs.html#113">Source</a><h4 class="code-header">unsafe fn <a href="#tymethod.unlock_shared_fair" class="fn">unlock_shared_fair</a>(&amp;self)</h4></section></summary><div class="docblock"><p>Releases a shared lock using a fair unlock protocol.</p>
<h5 id="safety"><a class="doc-anchor" href="#safety">§</a>Safety</h5>
<p>This method may only be called if a shared lock is held in the current context.</p>
</div></details><details class="toggle method-toggle" open><summary><section id="tymethod.unlock_exclusive_fair" class="method"><a class="src rightside" href="../src/lock_api/rwlock.rs.html#120">Source</a><h4 class="code-header">unsafe fn <a href="#tymethod.unlock_exclusive_fair" class="fn">unlock_exclusive_fair</a>(&amp;self)</h4></section></summary><div class="docblock"><p>Releases an exclusive lock using a fair unlock protocol.</p>
<h5 id="safety-1"><a class="doc-anchor" href="#safety-1">§</a>Safety</h5>
<p>This method may only be called if an exclusive lock is held in the current context.</p>
</div></details></div><h2 id="provided-methods" class="section-header">Provided Methods<a href="#provided-methods" class="anchor">§</a></h2><div class="methods"><details class="toggle method-toggle" open><summary><section id="method.bump_shared" class="method"><a class="src rightside" href="../src/lock_api/rwlock.rs.html#131-134">Source</a><h4 class="code-header">unsafe fn <a href="#method.bump_shared" class="fn">bump_shared</a>(&amp;self)</h4></section></summary><div class="docblock"><p>Temporarily yields a shared lock to a waiting thread if there is one.</p>
<p>This method is functionally equivalent to calling <code>unlock_shared_fair</code> followed
by <code>lock_shared</code>, however it can be much more efficient in the case where there
are no waiting threads.</p>
<h5 id="safety-2"><a class="doc-anchor" href="#safety-2">§</a>Safety</h5>
<p>This method may only be called if a shared lock is held in the current context.</p>
</div></details><details class="toggle method-toggle" open><summary><section id="method.bump_exclusive" class="method"><a class="src rightside" href="../src/lock_api/rwlock.rs.html#145-148">Source</a><h4 class="code-header">unsafe fn <a href="#method.bump_exclusive" class="fn">bump_exclusive</a>(&amp;self)</h4></section></summary><div class="docblock"><p>Temporarily yields an exclusive lock to a waiting thread if there is one.</p>
<p>This method is functionally equivalent to calling <code>unlock_exclusive_fair</code> followed
by <code>lock_exclusive</code>, however it can be much more efficient in the case where there
are no waiting threads.</p>
<h5 id="safety-3"><a class="doc-anchor" href="#safety-3">§</a>Safety</h5>
<p>This method may only be called if an exclusive lock is held in the current context.</p>
</div></details></div><h2 id="dyn-compatibility" class="section-header">Dyn Compatibility<a href="#dyn-compatibility" class="anchor">§</a></h2><div class="dyn-compatibility-info"><p>This trait is <b>not</b> <a href="https://doc.rust-lang.org/1.84.0/reference/items/traits.html#object-safety">dyn compatible</a>.</p><p><i>In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.</i></p></div><h2 id="implementors" class="section-header">Implementors<a href="#implementors" class="anchor">§</a></h2><div id="implementors-list"></div><script src="../trait.impl/lock_api/rwlock/trait.RawRwLockFair.js" async></script></section></div></main></body></html>