Rust-for-Arduboy/docs/doc/critical_section/struct.Mutex.html

101 lines
26 KiB
HTML
Raw Normal View History

2023-08-23 08:44:29 +02:00
<!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="A mutex based on critical sections."><title>Mutex in critical_section - Rust</title><link rel="preload" as="font" type="font/woff2" crossorigin href="../static.files/SourceSerif4-Regular-46f98efaafac5295.ttf.woff2"><link rel="preload" as="font" type="font/woff2" crossorigin href="../static.files/FiraSans-Regular-018c141bf0843ffd.woff2"><link rel="preload" as="font" type="font/woff2" crossorigin href="../static.files/FiraSans-Medium-8f9a781e4970d388.woff2"><link rel="preload" as="font" type="font/woff2" crossorigin href="../static.files/SourceCodePro-Regular-562dcc5011b6de7d.ttf.woff2"><link rel="preload" as="font" type="font/woff2" crossorigin href="../static.files/SourceSerif4-Bold-a2c9cd1067f8b328.ttf.woff2"><link rel="preload" as="font" type="font/woff2" crossorigin href="../static.files/SourceCodePro-Semibold-d899c5a5c4aeb14a.ttf.woff2"><link rel="stylesheet" href="../static.files/normalize-76eba96aa4d2e634.css"><link rel="stylesheet" href="../static.files/rustdoc-cb6f1f67f1bcd037.css" id="mainThemeStyle"><meta name="rustdoc-vars" data-root-path="../" data-static-root-path="../static.files/" data-current-crate="critical_section" data-themes="" data-resource-suffix="" data-rustdoc-version="1.73.0-nightly (8131b9774 2023-08-02)" data-channel="nightly" data-search-js="search-6dfdfced5eff6596.js" data-settings-js="settings-de11bff964e9d4e5.js" data-settings-css="settings-8c76f75bfb6bd192.css" data-theme-light-css="light-6d2c9675f3d09c26.css" data-theme-dark-css="dark-45ceb8f2e522f4d1.css" data-theme-ayu-css="ayu-fd19013d6ce078bf.css" ><script src="../static.files/storage-db41da1a38ea3cb8.js"></script><script defer src="sidebar-items.js"></script><script defer src="../static.files/main-0795b7d26be81095.js"></script><noscript><link rel="stylesheet" media="(prefers-color-scheme:light)" href="../static.files/light-6d2c9675f3d09c26.css"><link rel="stylesheet" media="(prefers-color-scheme:dark)" href="../static.files/dark-45ceb8f2e522f4d1.css"><link rel="stylesheet" href="../static.files/noscript-cffde32267a19fd6.css"></noscript><link rel="alternate icon" type="image/png" href="../static.files/favicon-16x16-8b506e7a72182f1c.png"><link rel="alternate icon" type="image/png" href="../static.files/favicon-32x32-422f7d1d52889060.png"><link rel="icon" type="image/svg+xml" href="../static.files/favicon-2c020d218678b618.svg"></head><body class="rustdoc struct"><!--[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">&#9776;</button><a class="logo-container" href="../critical_section/index.html"><img class="rust-logo" src="../static.files/rust-logo-151179464ae7ed46.svg" alt="logo"></a><h2></h2></nav><nav class="sidebar"><a class="logo-container" href="../critical_section/index.html"><img class="rust-logo" src="../static.files/rust-logo-151179464ae7ed46.svg" alt="logo"></a><h2 class="location"><a href="#">Mutex</a></h2><div class="sidebar-elems"><section><h3><a href="#implementations">Methods</a></h3><ul class="block"><li><a href="#method.borrow">borrow</a></li><li><a href="#method.borrow_ref">borrow_ref</a></li><li><a href="#method.borrow_ref_mut">borrow_ref_mut</a></li><li><a href="#method.get_mut">get_mut</a></li><li><a href="#method.into_inner">into_inner</a></li><li><a href="#method.new">new</a></li><li><a href="#method.replace">replace</a></li><li><a href="#method.replace_with">replace_with</a></li><li><a href="#method.take">take</a></li></ul><h3><a href="#trait-implementations">Trait Implementations</a></h3><ul class="block"><li><a href="#impl-Debug-for-Mutex%3CT%3E">Debug</a></li><li><a href="#impl-Sync-for-Mutex%3CT%3E">Sync</a></li></ul><h3><a href="#synthetic-implementations">Auto Trait Implementations</a></h3><ul class="block"><li><a href="#impl-RefUnwindSafe-for-Mutex%3CT%3E">!RefUnwindS
<h2 id="example"><a href="#example">Example</a></h2>
<div class="example-wrap"><pre class="rust rust-example-rendered"><code>
<span class="kw">static </span>FOO: Mutex&lt;Cell&lt;i32&gt;&gt; = Mutex::new(Cell::new(<span class="number">42</span>));
<span class="kw">fn </span>main() {
critical_section::with(|cs| {
FOO.borrow(cs).set(<span class="number">43</span>);
});
}
<span class="kw">fn </span>interrupt_handler() {
<span class="kw">let </span>_x = critical_section::with(|cs| FOO.borrow(cs).get());
}</code></pre></div>
<h2 id="design"><a href="#design">Design</a></h2>
<p><a href="https://doc.rust-lang.org/std/sync/struct.Mutex.html"><code>std::sync::Mutex</code></a> has two purposes. It converts types that are [<code>Send</code>]
but not [<code>Sync</code>] into types that are both; and it provides
<a href="https://doc.rust-lang.org/reference/interior-mutability.html">interior mutability</a>. <code>critical_section::Mutex</code>, on the other hand, only adds
<code>Sync</code>. It does <em>not</em> provide interior mutability.</p>
<p>This was a conscious design choice. It is possible to create multiple
<a href="struct.CriticalSection.html" title="struct critical_section::CriticalSection"><code>CriticalSection</code></a> tokens, either by nesting critical sections or <code>Copy</code>ing
an existing token. As a result, it would not be sound for <a href="struct.Mutex.html#method.borrow" title="method critical_section::Mutex::borrow"><code>Mutex::borrow</code></a>
to return <code>&amp;mut T</code>, because there would be nothing to prevent calling
<code>borrow</code> multiple times to create aliased <code>&amp;mut T</code> references.</p>
<p>The solution is to include a runtime check to ensure that each resource is
borrowed only once. This is what <code>std::sync::Mutex</code> does. However, this is
a runtime cost that may not be required in all circumstances. For instance,
<code>Mutex&lt;Cell&lt;T&gt;&gt;</code> never needs to create <code>&amp;mut T</code> or equivalent.</p>
<p>If <code>&amp;mut T</code> is needed, the simplest solution is to use <code>Mutex&lt;RefCell&lt;T&gt;&gt;</code>,
which is the closest analogy to <code>std::sync::Mutex</code>. [<code>RefCell</code>] inserts the
exact runtime check necessary to guarantee that the <code>&amp;mut T</code> reference is
unique.</p>
<p>To reduce verbosity when using <code>Mutex&lt;RefCell&lt;T&gt;&gt;</code>, we reimplement some of
<code>RefCell</code>s methods on it directly.</p>
<div class="example-wrap"><pre class="rust rust-example-rendered"><code>
<span class="kw">static </span>FOO: Mutex&lt;RefCell&lt;i32&gt;&gt; = Mutex::new(RefCell::new(<span class="number">42</span>));
<span class="kw">fn </span>main() {
critical_section::with(|cs| {
<span class="comment">// Instead of calling this
</span><span class="kw">let _ </span>= FOO.borrow(cs).take();
<span class="comment">// Call this
</span><span class="kw">let _ </span>= FOO.take(cs);
<span class="comment">// `RefCell::borrow` and `RefCell::borrow_mut` are renamed to
// `borrow_ref` and `borrow_ref_mut` to avoid name collisions
</span><span class="kw">let _</span>: <span class="kw-2">&amp;mut </span>i32 = <span class="kw-2">&amp;mut *</span>FOO.borrow_ref_mut(cs);
})
}</code></pre></div>
</div></details><h2 id="implementations" class="small-section-header">Implementations<a href="#implementations" class="anchor">§</a></h2><div id="implementations-list"><details class="toggle implementors-toggle" open><summary><section id="impl-Mutex%3CT%3E" class="impl"><a class="src rightside" href="../src/critical_section/mutex.rs.html#78-109">source</a><a href="#impl-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; <a class="struct" href="struct.Mutex.html" title="struct critical_section::Mutex">Mutex</a>&lt;T&gt;</h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.new" class="method"><a class="src rightside" href="../src/critical_section/mutex.rs.html#81-85">source</a><h4 class="code-header">pub const fn <a href="#method.new" class="fn">new</a>(value: T) -&gt; Self</h4></section></summary><div class="docblock"><p>Creates a new mutex.</p>
</div></details><details class="toggle method-toggle" open><summary><section id="method.get_mut" class="method"><a class="src rightside" href="../src/critical_section/mutex.rs.html#94-96">source</a><h4 class="code-header">pub fn <a href="#method.get_mut" class="fn">get_mut</a>(&amp;mut self) -&gt; &amp;mut T</h4></section></summary><div class="docblock"><p>Gets a mutable reference to the contained value when the mutex is already uniquely borrowed.</p>
<p>This does not require locking or a critical section since it takes <code>&amp;mut self</code>, which
guarantees unique ownership already. Care must be taken when using this method to
<strong>unsafely</strong> access <code>static mut</code> variables, appropriate fences must be used to prevent
unwanted optimizations.</p>
</div></details><details class="toggle method-toggle" open><summary><section id="method.into_inner" class="method"><a class="src rightside" href="../src/critical_section/mutex.rs.html#100-102">source</a><h4 class="code-header">pub fn <a href="#method.into_inner" class="fn">into_inner</a>(self) -&gt; T</h4></section></summary><div class="docblock"><p>Unwraps the contained value, consuming the mutex.</p>
</div></details><details class="toggle method-toggle" open><summary><section id="method.borrow" class="method"><a class="src rightside" href="../src/critical_section/mutex.rs.html#106-108">source</a><h4 class="code-header">pub fn <a href="#method.borrow" class="fn">borrow</a>&lt;'cs&gt;(&amp;'cs self, _cs: <a class="struct" href="struct.CriticalSection.html" title="struct critical_section::CriticalSection">CriticalSection</a>&lt;'cs&gt;) -&gt; &amp;'cs T</h4></section></summary><div class="docblock"><p>Borrows the data for the duration of the critical section.</p>
</div></details></div></details><details class="toggle implementors-toggle" open><summary><section id="impl-Mutex%3CRefCell%3CT%3E%3E" class="impl"><a class="src rightside" href="../src/critical_section/mutex.rs.html#111-170">source</a><a href="#impl-Mutex%3CRefCell%3CT%3E%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; <a class="struct" href="struct.Mutex.html" title="struct critical_section::Mutex">Mutex</a>&lt;RefCell&lt;T&gt;&gt;</h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.replace" class="method"><a class="src rightside" href="../src/critical_section/mutex.rs.html#122-124">source</a><h4 class="code-header">pub fn <a href="#method.replace" class="fn">replace</a>&lt;'cs&gt;(&amp;'cs self, cs: <a class="struct" href="struct.CriticalSection.html" title="struct critical_section::CriticalSection">CriticalSection</a>&lt;'cs&gt;, t: T) -&gt; T</h4></section></summary><div class="docblock"><p>Borrow the data and call [<code>RefCell::replace</code>]</p>
<p>This is equivalent to <code>self.borrow(cs).replace(t)</code></p>
<h5 id="panics"><a href="#panics">Panics</a></h5>
<p>This call could panic. See the documentation for [<code>RefCell::replace</code>]
for more details.</p>
</div></details><details class="toggle method-toggle" open><summary><section id="method.replace_with" class="method"><a class="src rightside" href="../src/critical_section/mutex.rs.html#136-141">source</a><h4 class="code-header">pub fn <a href="#method.replace_with" class="fn">replace_with</a>&lt;'cs, F&gt;(&amp;'cs self, cs: <a class="struct" href="struct.CriticalSection.html" title="struct critical_section::CriticalSection">CriticalSection</a>&lt;'cs&gt;, f: F) -&gt; T<span class="where fmt-newline">where
F: FnOnce(&amp;mut T) -&gt; T,</span></h4></section></summary><div class="docblock"><p>Borrow the data and call [<code>RefCell::replace_with</code>]</p>
<p>This is equivalent to <code>self.borrow(cs).replace_with(f)</code></p>
<h5 id="panics-1"><a href="#panics-1">Panics</a></h5>
<p>This call could panic. See the documentation for
[<code>RefCell::replace_with</code>] for more details.</p>
</div></details><details class="toggle method-toggle" open><summary><section id="method.borrow_ref" class="method"><a class="src rightside" href="../src/critical_section/mutex.rs.html#153-155">source</a><h4 class="code-header">pub fn <a href="#method.borrow_ref" class="fn">borrow_ref</a>&lt;'cs&gt;(&amp;'cs self, cs: <a class="struct" href="struct.CriticalSection.html" title="struct critical_section::CriticalSection">CriticalSection</a>&lt;'cs&gt;) -&gt; Ref&lt;'cs, T&gt;</h4></section></summary><div class="docblock"><p>Borrow the data and call [<code>RefCell::borrow</code>]</p>
<p>This is equivalent to <code>self.borrow(cs).borrow()</code></p>
<h5 id="panics-2"><a href="#panics-2">Panics</a></h5>
<p>This call could panic. See the documentation for [<code>RefCell::borrow</code>]
for more details.</p>
</div></details><details class="toggle method-toggle" open><summary><section id="method.borrow_ref_mut" class="method"><a class="src rightside" href="../src/critical_section/mutex.rs.html#167-169">source</a><h4 class="code-header">pub fn <a href="#method.borrow_ref_mut" class="fn">borrow_ref_mut</a>&lt;'cs&gt;(
&amp;'cs self,
cs: <a class="struct" href="struct.CriticalSection.html" title="struct critical_section::CriticalSection">CriticalSection</a>&lt;'cs&gt;
) -&gt; RefMut&lt;'cs, T&gt;</h4></section></summary><div class="docblock"><p>Borrow the data and call [<code>RefCell::borrow_mut</code>]</p>
<p>This is equivalent to <code>self.borrow(cs).borrow_mut()</code></p>
<h5 id="panics-3"><a href="#panics-3">Panics</a></h5>
<p>This call could panic. See the documentation for [<code>RefCell::borrow_mut</code>]
for more details.</p>
</div></details></div></details><details class="toggle implementors-toggle" open><summary><section id="impl-Mutex%3CRefCell%3CT%3E%3E-1" class="impl"><a class="src rightside" href="../src/critical_section/mutex.rs.html#172-186">source</a><a href="#impl-Mutex%3CRefCell%3CT%3E%3E-1" class="anchor">§</a><h3 class="code-header">impl&lt;T: Default&gt; <a class="struct" href="struct.Mutex.html" title="struct critical_section::Mutex">Mutex</a>&lt;RefCell&lt;T&gt;&gt;</h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.take" class="method"><a class="src rightside" href="../src/critical_section/mutex.rs.html#183-185">source</a><h4 class="code-header">pub fn <a href="#method.take" class="fn">take</a>&lt;'cs&gt;(&amp;'cs self, cs: <a class="struct" href="struct.CriticalSection.html" title="struct critical_section::CriticalSection">CriticalSection</a>&lt;'cs&gt;) -&gt; T</h4></section></summary><div class="docblock"><p>Borrow the data and call [<code>RefCell::take</code>]</p>
<p>This is equivalent to <code>self.borrow(cs).take()</code></p>
<h5 id="panics-4"><a href="#panics-4">Panics</a></h5>
<p>This call could panic. See the documentation for [<code>RefCell::take</code>]
for more details.</p>
</div></details></div></details></div><h2 id="trait-implementations" class="small-section-header">Trait Implementations<a href="#trait-implementations" class="anchor">§</a></h2><div id="trait-implementations-list"><details class="toggle implementors-toggle" open><summary><section id="impl-Debug-for-Mutex%3CT%3E" class="impl"><a class="src rightside" href="../src/critical_section/mutex.rs.html#73">source</a><a href="#impl-Debug-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T: Debug&gt; Debug for <a class="struct" href="struct.Mutex.html" title="struct critical_section::Mutex">Mutex</a>&lt;T&gt;</h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.fmt" class="method trait-impl"><a class="src rightside" href="../src/critical_section/mutex.rs.html#73">source</a><a href="#method.fmt" class="anchor">§</a><h4 class="code-header">fn <a class="fn">fmt</a>(&amp;self, f: &amp;mut Formatter&lt;'_&gt;) -&gt; Result</h4></section></summary><div class='docblock'>Formats the value using the given formatter. <a>Read more</a></div></details></div></details><section id="impl-Sync-for-Mutex%3CT%3E" class="impl"><a class="src rightside" href="../src/critical_section/mutex.rs.html#191">source</a><a href="#impl-Sync-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; Sync for <a class="struct" href="struct.Mutex.html" title="struct critical_section::Mutex">Mutex</a>&lt;T&gt;<span class="where fmt-newline">where
T: Send,</span></h3></section></div><h2 id="synthetic-implementations" class="small-section-header">Auto Trait Implementations<a href="#synthetic-implementations" class="anchor">§</a></h2><div id="synthetic-implementations-list"><section id="impl-RefUnwindSafe-for-Mutex%3CT%3E" class="impl"><a href="#impl-RefUnwindSafe-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; !RefUnwindSafe for <a class="struct" href="struct.Mutex.html" title="struct critical_section::Mutex">Mutex</a>&lt;T&gt;</h3></section><section id="impl-Send-for-Mutex%3CT%3E" class="impl"><a href="#impl-Send-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; Send for <a class="struct" href="struct.Mutex.html" title="struct critical_section::Mutex">Mutex</a>&lt;T&gt;<span class="where fmt-newline">where
T: Send,</span></h3></section><section id="impl-Unpin-for-Mutex%3CT%3E" class="impl"><a href="#impl-Unpin-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; Unpin for <a class="struct" href="struct.Mutex.html" title="struct critical_section::Mutex">Mutex</a>&lt;T&gt;<span class="where fmt-newline">where
T: Unpin,</span></h3></section><section id="impl-UnwindSafe-for-Mutex%3CT%3E" class="impl"><a href="#impl-UnwindSafe-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; UnwindSafe for <a class="struct" href="struct.Mutex.html" title="struct critical_section::Mutex">Mutex</a>&lt;T&gt;<span class="where fmt-newline">where
T: UnwindSafe,</span></h3></section></div><h2 id="blanket-implementations" class="small-section-header">Blanket Implementations<a href="#blanket-implementations" class="anchor">§</a></h2><div id="blanket-implementations-list"><details class="toggle implementors-toggle"><summary><section id="impl-Any-for-Mutex%3CT%3E" class="impl"><a href="#impl-Any-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; Any for T<span class="where fmt-newline">where
T: 'static + ?Sized,</span></h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.type_id" class="method trait-impl"><a href="#method.type_id" class="anchor">§</a><h4 class="code-header">fn <a class="fn">type_id</a>(&amp;self) -&gt; TypeId</h4></section></summary><div class='docblock'>Gets the <code>TypeId</code> of <code>self</code>. <a>Read more</a></div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-Borrow%3CT%3E-for-Mutex%3CT%3E" class="impl"><a href="#impl-Borrow%3CT%3E-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; Borrow&lt;T&gt; for T<span class="where fmt-newline">where
T: ?Sized,</span></h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.borrow-1" class="method trait-impl"><a href="#method.borrow-1" class="anchor">§</a><h4 class="code-header">fn <a class="fn">borrow</a>(&amp;self) -&gt; &amp;T</h4></section></summary><div class='docblock'>Immutably borrows from an owned value. <a>Read more</a></div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-BorrowMut%3CT%3E-for-Mutex%3CT%3E" class="impl"><a href="#impl-BorrowMut%3CT%3E-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; BorrowMut&lt;T&gt; for T<span class="where fmt-newline">where
T: ?Sized,</span></h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.borrow_mut" class="method trait-impl"><a href="#method.borrow_mut" class="anchor">§</a><h4 class="code-header">fn <a class="fn">borrow_mut</a>(&amp;mut self) -&gt; &amp;mut T</h4></section></summary><div class='docblock'>Mutably borrows from an owned value. <a>Read more</a></div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-From%3CT%3E-for-Mutex%3CT%3E" class="impl"><a href="#impl-From%3CT%3E-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T&gt; From&lt;T&gt; for T</h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.from" class="method trait-impl"><a href="#method.from" class="anchor">§</a><h4 class="code-header">fn <a class="fn">from</a>(t: T) -&gt; T</h4></section></summary><div class="docblock"><p>Returns the argument unchanged.</p>
</div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-Into%3CU%3E-for-Mutex%3CT%3E" class="impl"><a href="#impl-Into%3CU%3E-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T, U&gt; Into&lt;U&gt; for T<span class="where fmt-newline">where
U: From&lt;T&gt;,</span></h3></section></summary><div class="impl-items"><details class="toggle method-toggle" open><summary><section id="method.into" class="method trait-impl"><a href="#method.into" class="anchor">§</a><h4 class="code-header">fn <a class="fn">into</a>(self) -&gt; U</h4></section></summary><div class="docblock"><p>Calls <code>U::from(self)</code>.</p>
<p>That is, this conversion is whatever the implementation of
<code>[From]&lt;T&gt; for U</code> chooses to do.</p>
</div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-TryFrom%3CU%3E-for-Mutex%3CT%3E" class="impl"><a href="#impl-TryFrom%3CU%3E-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T, U&gt; TryFrom&lt;U&gt; for T<span class="where fmt-newline">where
2023-08-23 08:44:29 +02:00
U: Into&lt;T&gt;,</span></h3></section></summary><div class="impl-items"><details class="toggle" open><summary><section id="associatedtype.Error-1" class="associatedtype trait-impl"><a href="#associatedtype.Error-1" class="anchor">§</a><h4 class="code-header">type <a class="associatedtype">Error</a> = Infallible</h4></section></summary><div class='docblock'>The type returned in the event of a conversion error.</div></details><details class="toggle method-toggle" open><summary><section id="method.try_from" class="method trait-impl"><a href="#method.try_from" class="anchor">§</a><h4 class="code-header">fn <a class="fn">try_from</a>(value: U) -&gt; Result&lt;T, &lt;T as TryFrom&lt;U&gt;&gt;::Error&gt;</h4></section></summary><div class='docblock'>Performs the conversion.</div></details></div></details><details class="toggle implementors-toggle"><summary><section id="impl-TryInto%3CU%3E-for-Mutex%3CT%3E" class="impl"><a href="#impl-TryInto%3CU%3E-for-Mutex%3CT%3E" class="anchor">§</a><h3 class="code-header">impl&lt;T, U&gt; TryInto&lt;U&gt; for T<span class="where fmt-newline">where
U: TryFrom&lt;T&gt;,</span></h3></section></summary><div class="impl-items"><details class="toggle" open><summary><section id="associatedtype.Error" class="associatedtype trait-impl"><a href="#associatedtype.Error" class="anchor">§</a><h4 class="code-header">type <a class="associatedtype">Error</a> = &lt;U as TryFrom&lt;T&gt;&gt;::Error</h4></section></summary><div class='docblock'>The type returned in the event of a conversion error.</div></details><details class="toggle method-toggle" open><summary><section id="method.try_into" class="method trait-impl"><a href="#method.try_into" class="anchor">§</a><h4 class="code-header">fn <a class="fn">try_into</a>(self) -&gt; Result&lt;U, &lt;U as TryFrom&lt;T&gt;&gt;::Error&gt;</h4></section></summary><div class='docblock'>Performs the conversion.</div></details></div></details></div></section></div></main></body></html>