What does the exclamation point mean in a trait implementation?
Asked Answered
H

3

32

I found in the library reference for std::rc::Rc this trait implementation

impl<T> !Send for Rc<T> 
where
    T: ?Sized, 

What does the exclamation point in front of Send mean?

I consulted both The Rust Programming Language¹ book and The Rust Reference², but didn't find an explanation. Please give a reference in your answer.


¹ especially the [section 3.19 Traits
² and sections 5.1 Traits and 5.1 Implementations
Hewitt answered 17/5, 2015 at 19:28 Comment(0)
H
37

It's a negative trait implementation for the Send trait as described in RFC 19.

As a summary: The Send trait is an auto trait, which means it is automatically implemented for all types that only contain other Send types:

unsafe auto trait Send {}

(Send is also an unsafe trait, which means it is unsafe to implement, but that is not relevant to the question.)

An auto trait may not define any methods, which also makes it a marker trait. (The syntax for defining auto traits is currently only available in the standard library or on the nightly compiler, but their semantics are stable.)

To opt out of the automatic implementation of Send, you must write an explicit negative trait implementation:

impl !Send for MyType {}

This means that even though MyType only contains other types that are Send, MyType itself will not automatically implement Send.

See also the answer to another question: What is an auto trait in Rust?

Hewitt answered 17/5, 2015 at 19:28 Comment(4)
@mrnateriver I just reviewed your edit and decided to keep the old syntax, but add the new syntax, as it is still experimental. Take a look and let me know if anything is missing/ wrongStotts
@Stotts sure, no problem. AFAI understand, this syntax is experimental for users, but it's used in stdlib without any attributes. But anyway, I've started learning Rust just a week ago and I'm still struggling to wrap my head around all the RFCs, experimental features, what's stable and what's notFreund
The "new" syntax is still nightly-only, but the old syntax is obsolete, so I have updated the question (again) to avoid misleading new readers, as well as correcting the semantics of auto trait implementation.Koh
I made this answer community wiki, thank you for the collaboration.Hewitt
C
11

This is a negative trait impl, so you can read it as opting out of the Send trait.

Cuirassier answered 17/5, 2015 at 19:35 Comment(0)
S
0

From reference about auto traits:

Auto traits can also have negative implementations, shown as impl !AutoTrait for T in the standard library documentation, that override the automatic implementations. For example *mut T has a negative implementation of Send, and so *mut T is not Send, even if T is.

Shellacking answered 13/10, 2022 at 18:0 Comment(1)
This was an old question. Now they have added relevant information long ago.Hewitt

© 2022 - 2024 — McMap. All rights reserved.