Perhaps I'm spoiled by ever so slightly higher-level languages, but it seems your entire point is that if a program is ever so slightly incorrect, the programmer (and/or the end user) should suffer all of the consequences.
From where I stand, compilers are tools to aid the programmer. We invented them, because we found out that it was more productive than writing machine code by hand[1]. If an off-by-one error or a null pointer dereference[2] in a trivial program can invoke time travel several frames up the call stack[3], it isn't just missing the entire point of having a compiler - it can drive people insane.
[1]: https://en.wikipedia.org/wiki/Grace_Hopper#UNIVAC
[2]: https://en.wikipedia.org/wiki/Tony_Hoare#Research_and_career
[3]: https://devblogs.microsoft.com/oldnewthing/20140627-00/?p=63...
As far as I can tell, no popular language created in the past 30 years (including those with official specs and multiple implementations) makes heavy use of UB.
> no popular language created in the past 30 years makes heavy use of UB
Yeah, I'm happy that Rust's list is relatively short, with approximately 10 items on it: https://doc.rust-lang.org/reference/behavior-considered-unde...
Also relevant reading: https://doc.rust-lang.org/nomicon/what-unsafe-does.html
That list for Rust is not necessarily comprehensive. What matters more than the number is the segregation; you can’t cause UB from safe rust, only unsafe rust.