by Curiositry on 5/3/25, 9:01 PM with 103 comments
by steveklabnik on 5/6/25, 5:43 AM
> Function Overloads
Strictly speaking, Rust doesn't support overloaded functions. Function overloading is when you define the same function but with different arguments, and the language selects the correct one based on the argument type. In this case, it's two different implementations of a trait for two different types. That said, it's close enough that this isn't really an issue, more of just a technical note, since this is a series trying to get into details.
> I can't find an explanation in the Rust documentation but I expect the reason is that someone could implement another trait that provides .into_iter() on whatever the x is in for y in x, thus resulting in a compiler error because there would be two candidate implementations.
Yep, I'm not sure that there is an official explanation anywhere else, but this is exactly what I would assume as well. This ensures that the correct implementation is called. This is also one of the reasons why adding a trait implementation isn't considered a breaking change, even if it could create a compiler error, because you can always expand it yourself to explicitly select the correct choice. Of course, these situations are usually treated more carefully then they have to be, because breakage isn't fun, even if it's technically allowed.
> But wait, you say, I'm doing exactly this in the first program, and indeed you are.
It's not the same, as the next paragraphs explain.
> We are able to examine the function and realize it's safe, but because the compiler wants to use local reasoning, it's not able to do so.
This is a super important point!
by Animats on 5/6/25, 5:31 AM
A useful way to think about this:
- All data in Rust has exactly one owner.
- If you need some kind of multiple ownership, you have to make the owner be a reference-counted cell, such as Rc or Arc.
- All data can be accessed by one reader/writer, or N readers, but not both at the same time.
- There is both compile time and run time machinery to strictly enforce this.
Once you get that, you can see what the borrow checker is trying to do for you.
by diath on 5/6/25, 8:53 AM
by teleforce on 5/7/25, 8:05 PM
Auto industry kind of solved this automation mechanism for example with the new high performance Toyota GR Corolla has a new automatic gear transmission that's proven as fast if not faster than the manual version [1]. The same goes to F1, the epitome of car racing performance.
[1] 2025 Toyota GR Corolla's New Automatic Gearbox Democratizes Fun:
https://www.caranddriver.com/reviews/a62672128/2025-toyota-g...
by rollcat on 5/6/25, 10:11 AM
It's a lot of assumptions, and if you trip, Rust will yell at you much more often than Zig; and it will likely be right to do so. But in all seriousness, I'm tired of the yelling, and find Zig much more pleasant.
by cornholio on 5/6/25, 6:24 AM
Essentially, you wouldn't and shouldn't make that tradeoff for anything other than system programming.
by Surac on 5/6/25, 5:31 AM
by dmitrygr on 5/6/25, 7:44 PM
Precisely the sort of question I do not want to waste time on.
by bsaul on 5/6/25, 8:23 AM
guess it's "instead of a &mut self"
by sidcool on 5/6/25, 4:00 AM
by gitroom on 5/6/25, 10:53 AM