|
| ▲ | steveklabnik 11 hours ago | parent | next [-] |
| Depending on exactly what you mean, this isn't correct. This syntax is the same as <T: BarTrait>, and you can store that T in any other generic struct that's parametrized by BarTrait, for example. |
| |
| ▲ | marcosdumay 7 hours ago | parent [-] | | > you can store that T in any other generic struct that's parametrized by BarTrait, for example Not really. You can store it on any struct that specializes to the same type of the value you received. If you get a pre-built struct from somewhere and try to store it there, your code won't compile. |
|
|
| ▲ | tcfhgj 11 hours ago | parent | prev [-] |
| sure about that? the struct in which it is stored, could be generic as well |
| |
| ▲ | Maxatar 10 hours ago | parent [-] | | I'm addressing the intent of the original question. No one would ask this question in the case where the struct is generic over a type parameter bounded by the trait, since such a design can only store a homogeneous collection of values of a single concrete type implementing the trait; the question doesn't even make sense in that situation. The question only arises for a struct that must store a heterogeneous collection of values with different concrete types implementing the trait, in which case a trait object (dyn Trait) is required. |
|