Can C++ be 10x Simpler & Safer? - Herb Sutter - CppCon 2022

  Рет қаралды 264,667

CppCon

CppCon

Күн бұрын

Пікірлер: 599
@luctielen
@luctielen 2 жыл бұрын
Matt Godbolt is such a legend, adding support for cpp2 to compiler explorer during the talk.
@shasderias
@shasderias 2 жыл бұрын
1:43:38
@meneldal
@meneldal 2 жыл бұрын
Having such simple compiling instructions definitely helped, imagine if it had a bunch of dependencies, that wouldn't have been possible.
@josephlagrange9531
@josephlagrange9531 Жыл бұрын
Dijkstra and Wirth spoke negatively about C++. Stroustrup lobbied C++ at that time. At fact I agree with some dudes claiming Stroustroup is far from good designer.
@AngelLoredo53
@AngelLoredo53 Жыл бұрын
@@josephlagrange9531 i have been thinking about dijkstra’s comments regarding complex languages. I use cpp because it makes things easier like generic programming and abstracting away lots of complexity to clearly express your ideas without loosing performance, but he obviously was onto something when he was in for simpler languages, and I think everyone would prefer a magical simple language like scheme but expressive as hell. Maybe we are too far away from that, hopefully not by hundreds of years.
@ryleitdept
@ryleitdept Жыл бұрын
​@@josephlagrange9531so you're a good designer huh
@ChristopherSamuelson5
@ChristopherSamuelson5 2 жыл бұрын
I have literally dreamed of this exact idea. I'm so amped at the prospect of this becoming real. 🤞 Herb Sutter, as always, proves that he deserves our respect.
@llothar68
@llothar68 2 жыл бұрын
If you know the C++ Comittee you know it will not become real before it's too late. It's 2022 and we still have no UTF-8 charset conversion handling.
@totheknee
@totheknee 2 жыл бұрын
Funny how he does everything the C. Muratori/J. Blow crowd is advocating, even to the point where he didn't add classes in his transpiler yet. But watch how they still sh!t all over cpp2 no matter what...
@jennifierburnett2901
@jennifierburnett2901 Жыл бұрын
@@llothar68 unless I'm misunderstanding what you're saying, we have? Since c++11 we've had std::codecvt specialisations that convert to and from UTF-8 explicitly, and we also have the null terminated multibyte stings library which while not explicitly UTF-8 is effectively always going to be because that's just the most common multibyte encoding in use
@josephlagrange9531
@josephlagrange9531 Жыл бұрын
@@llothar68 Dijkstra and Wirth spoke negatively about C++. Stroustrup lobbied C++ at that time. At fact I agree with some dudes claiming Stroustroup is far from good designer.
@Adowrath
@Adowrath Жыл бұрын
@@josephlagrange9531 Why copy-paste your comment all over?
@kodirovsshik
@kodirovsshik 2 жыл бұрын
Ever since I saw that one talk by Herb on an actual good way of passing arguments, that talk never left me as I thought about it again and again, and now I can't describe how happy I am to see Herb still keep actively pushing C++ towards this direction of simplifying it. I even shed a tear at some point watching the talk and I believe it means a lot to the whole C++ community as it does to me, so I just wanna say thank you a million to Herb for doing this fascinating job of actively and sincerely trying to make our world better
@loarto
@loarto 2 жыл бұрын
Link to talk?
@domenicocipriani604
@domenicocipriani604 2 жыл бұрын
Which is the talk about a good way of passing arguments?
@herbsutter4340
@herbsutter4340 2 жыл бұрын
@kodirovsshik Thank you for the kind words, I'm glad you find it a promising direction! @@domenicocipriani604 @loarto You can find the parameter passing (arguments) in the second half of my CppCon 2020 talk... the links are here: github.com/hsutter/cppfront#2020-parameter-passing
@kodirovsshik
@kodirovsshik Жыл бұрын
@@loarto kzbin.info/www/bejne/bJ3Yo4J5mcadZrs
@magikworx3748
@magikworx3748 2 жыл бұрын
This is the first "alternative" I've wanted to learn. Thank you for the dream of a better, way less complicated future.
@CppCon
@CppCon 2 жыл бұрын
Glad you like it!
@SqueakyNeb
@SqueakyNeb 2 жыл бұрын
Finally, after YEARS of warmup, Herb Sutter finally says it: if C++ is so good, why isn't there a C++ 2?
@josephlagrange9531
@josephlagrange9531 Жыл бұрын
Dijkstra and Wirth spoke negatively about C++. Stroustrup lobbied C++ at that time. At fact I agree with some dudes claiming Stroustroup is far from good designer.
@ryleitdept
@ryleitdept Жыл бұрын
​@@josephlagrange9531so you're a good designer huh
@SianaGearz
@SianaGearz 11 ай бұрын
@@josephlagrange9531 It's a language that is designed by starting with a practical but very limiting in design terms premise - take C and make it more expressive and more useful while keeping it seamless. But it's also exactly what allowed it become so successful. You can't blame the designer for doing what had to be done. For competition there was ObjC but the performance was not great, turns out gluing Smalltalk to C you get the drawbacks of both. C++ manages to be more than the sum of parts, which is not so trivial, and the better designed languages heavily lean on hindsight experience of C++. Wirth designed languages, where are they now? They've never been flawless either. The language grew unwieldy at the stage when it was already being designed by committee, so blaming it on one guy is a little silly. Something as important as C++ emerges, you simply don't get to keep dictatorship over it.
@angelcaru
@angelcaru 7 ай бұрын
@@ryleitdept i would be inclined to believe that a random stranger on the internet could design a better language than c++
@KulaGGin
@KulaGGin 3 ай бұрын
@@ryleitdept No, he doesn't have to be. You don't have to be a good film creator to be able to tell if a movie is good or bad.
@gideonmuller7435
@gideonmuller7435 2 жыл бұрын
This is soooo much more promising than Carbon IMO!
@frydac
@frydac 2 жыл бұрын
It's more opinionated (by one person) and farther along, and it does speaks to me. But carbon could become good too, we just don't know yet afaik. These initiatives do illustrate that ppl want something breaking from C++ if 2 such similar (popular) initiatives exist (and probably others like Circle).
@TheSulross
@TheSulross 2 жыл бұрын
Carbon did the important task of breaking from the crowd and saying, yes, it is time for a new language to supplant C++ and it needs to come out of the C++ community itself so that the concerns that the community cares about in a language are addressed
@Elite7555
@Elite7555 2 жыл бұрын
I think Carbon borrows some good concepts from Go, while throwing away the garbage.
@Mempler
@Mempler 2 жыл бұрын
@@frydac dont forget, its made by google. They might kill it at any time if it does not seem profitable.
@JohnDlugosz
@JohnDlugosz 2 жыл бұрын
@@frydac Well, Carbon makes it easier to highlight (or just find by eye) symbol declarations. Herb promises that he can write a context-free grammar, but it's fragile and any future change has to be careful not to make the parsing more complex. With keyword-first principle, we guarantee the grammar will be (and stay) simple in this respect.
@michaelliuzzi
@michaelliuzzi Жыл бұрын
In addition to his technical skills, Herb is an excellent presenter and leader.
@zactron1997
@zactron1997 2 жыл бұрын
This is exactly what we need in the world. I started learning Rust because of the amount of work I'd need to do to go from "my code compiles" through to "and now it's not a pending lawsuit". Rust is not for everyone, so I'm really happy to see C++ moving towards a world where it catches up to (and hopefully exceeds!) Rust's ergonomics and safety.
@srghma
@srghma Жыл бұрын
Why programming on c++ gives you a lawsuit?
@robrick9361
@robrick9361 Жыл бұрын
Rust is a moronic language. If you're thing is safety, WHY THE HELL WOULD ALLOW SOMETHING LIKE THE UNSAFE COMMAND? All the problems (and benefits) of C++ is how many features there are and how there's always a way around their restrictions. Why move from a language that allows anything to a language that allows anything.................with far less libraries. Rust hasn't solved anything. Also ergonomics is super relative.
@TheRedHavoc
@TheRedHavoc Жыл бұрын
​​​​​@@robrick9361The whole point of unsafe is to isolate essential but uncheckable low level operations to compartmentalized blocks that can be more easily reasoned about and verified by hand (functions, modules). Good C++ design already follows the same principle (References/Smart pointers vs pointers, Range for vs raw for, collections vs raw new/delete). The only difference is that Rust has stronger compile time checking to enforce this compartmentalization. As for ergonomics, while it is true that it is partially determined by preference/experience, there are objectively more ergonomic ways of programming, otherwise we would all still be using assembly. Rust does have features that make it easier to express your intent than C++, such as sum types with pattern matching. And as for solving no issues, you should go ask Google, who have observed a staggering reduction in memory safety violations in the parts of Android that have been written in Rust, or Microsoft, who are investing heavily in Rust support for Windows, or Mozilla, who's multi-threaded CSS renderer project failed multiple times before they successfully reimplemented it in Rust, that "Rust solves nothing". I'm sure they will find it very amusing.
@mr.johnson8974
@mr.johnson8974 Жыл бұрын
@@robrick9361 Because rust got it's start on LLVM which needs interop with C. Even then, you have to explictly go out of your way to make "unsafe" Rust code. You're so hyperfocused on a "GOTCHA" that you missed the fact Rust has a way better toolchain than cpp. Better package manager, better syntax, Composition over inheritance, the list goes on.
@raffimolero64
@raffimolero64 Жыл бұрын
@@robrick9361 better a 10-line unsafe code block than a 10,000-line unsafe codebase
@ryanwooley4111
@ryanwooley4111 2 жыл бұрын
Very nicely done, Herb! This approach not only bypasses the backwards-compatible limitations baked into C++ while still allowing mixing code, but keeps the language feeling like a refreshed C++ instead of something completely new. I think this compromise will be a appealing to many C++ developers. I think Rust is an excellent alternative to C++ (and is available today) but comes at the cost of learning a different way of thinking about memory safety and interoperability headaches with C++. Carbon is another experimental language trying to overcome these issues with a new language that prioritizes compatibility but is not familiar to those coming from C++. I suspect cppfront will be an easier sell to those currently heavily-invested in C++ but want more simplicity and safety guarantees.
@VoidOfTheMachine
@VoidOfTheMachine 2 жыл бұрын
I love this. It definately took a rust-like approach to compiler warnings / errors, which is great. Not only are the messages clear and they tell you how you can fix your mistake, but it also helps keep safety within c++ programs. I also enjoy some of the "syntactic sugar" resembilng some of the newer programming languages. I also never knew about the whole NSA ordeal with type unsafety and them advising against c & c++. Thousand Thanks to Herb Sutter And cppcon
@austinmorton
@austinmorton 2 жыл бұрын
Wow, I didn't realize there would be cameras on the mic stands! Super glad I was able to twist Matt's arm into hacking support into Compiler Explorer before the talk was over - your reaction was priceless 😄. Thanks for a great closing keynote as always.
@mattbettcher
@mattbettcher 2 жыл бұрын
This really is quite good! I've been waiting years for someone to reduce complexity in C++!
@lolilollolilol7773
@lolilollolilol7773 2 жыл бұрын
Even a luminary like Scott Meyers had lost hope years ago. In his last few public talks back in 2017 (that are available on his website), it's very clear that he had enough. In one of his talks (at Dconf), he said that he was still taking engagement talks as long as it wasn't about C++, and that the C++ design committee didn't really care about the creeping complexity. I think that one is a bit harsh but it speaks volume as what he thought about the evolution of the language. Herb's experiment is a stroke of genius, as it is both the disruption that is needed and the continuity and back compatibility that is a requirement.
@dat_21
@dat_21 2 жыл бұрын
With committee that is so focused on backward compatibility, there won't be any progress in C++. It needs a serious redesign. Like a dozen or so new keywords and removal of non-intuitive bits like initializer lists. Templates need a serious redesign to be more readable. And so on. It needs a massive purge to be a better language.
@Bolpat
@Bolpat 2 жыл бұрын
1:04:00 If it works on anything with a subscript that has an integral value supplied and has a size(), it fails on std::map.
@ar1i_k
@ar1i_k 3 ай бұрын
I cannot describe how much I loved every single part of it, only then to be crushed how literal perfection is gonna be stained by (1:24:55) the confusion that is gonna be caused by an empty return in the function that is supposed to return certain values (though, to be fair, it’s gonna be so freaking convenient at avoiding the little annoyance of repeating the structure shape, that I’m gonna use it anyway. Just like I use the ternary operator where it completely screws the code readability)
@r31527
@r31527 8 ай бұрын
This is super exciting. I'm a Rust engineer & I love Rust, but I would also love to see C++ become modern & safe so that we can all build better software with less headaches.
@Razzileful
@Razzileful 2 жыл бұрын
This is not just a fascinating idea/experiment, but may even fall into the "essential for continued language evolution" category! I really hope it succeeds
@atlantic_love
@atlantic_love 2 жыл бұрын
I think C++ is on life support. Hardware is at the point where you can create GUI apps (yes, I know C++ is a systems programming language) much more rapidly in other languages and still have acceptable performance, than you ever could with C++. That it's still difficult for beginners to the language to install and link to GUI frameworks/libraries in C++, is a real hindrance.
@mx2000
@mx2000 2 жыл бұрын
@@atlantic_loveyou realize that game development is still C++ most of the time? Rich client apps are on the way out, games are here to stay.
@xl000
@xl000 2 жыл бұрын
@@mx2000 Rich client apps are not on the way out. Only the ones which require no computational power. That's a good chunk of them, but certainly not all. What I like about that is that you can install Linux on someone's computer and he won't be able to tell the difference if he's a office / web user.
@josephlagrange9531
@josephlagrange9531 Жыл бұрын
@@atlantic_love C++ is a mess, programming language without any idea expressed with good design, see the list of wishes from Stroustrop books where Stroustroup listed some items for himself about what the language needs to be like.
@llothar68
@llothar68 Жыл бұрын
@@atlantic_love Yes but when you have large data sets you have a good C++ optimization and memory control. Performance is still king and never fast enough.
@Heater-v1.0.0
@Heater-v1.0.0 9 ай бұрын
I find the idea of the gargantuan and ugly monster that is C++ continuing to evolve for another thirty years terrifying.
@totheknee
@totheknee 2 жыл бұрын
It's great that Herb is doing this. I am designing a way to do this in C, but once it's done, no one will know or care about it except for me. When Herb is done, it has a good chance of actually going somewhere. Even if not in the standard, there's no way it doesn't get a community behind it after this talk...
@Bob-tx7hv
@Bob-tx7hv 2 ай бұрын
I'd be interested, how far have you got? Do you have a github repo?
@ElementaryWatson-123
@ElementaryWatson-123 Жыл бұрын
I'm amazed that Herb Sutter after so many years is still going strong, still is thinking cogently, and even looking much younger than his years. Kudos.
@_Ani_
@_Ani_ 2 жыл бұрын
This could be a gamechanger in terms of reducing complexity. Hyped to see this come forward!
@kirilvidev454
@kirilvidev454 2 жыл бұрын
Amazing work Herb. I now again have hope for C++'s future. Also, very good point in the end about naming the syntax cpp2 explicitly. Human nature is one of the reasons there is still so much confusion about the language.
@justdoityourself7134
@justdoityourself7134 2 жыл бұрын
I've always believed this style of syntax versioning to be the correct way forward. Count me in!
@IAmMoF
@IAmMoF 2 жыл бұрын
Really amazing what he was able to accomplish with basic principles. I really look forward to a CPP future like the one he displayed in this talk.
@giannimariani9744
@giannimariani9744 2 жыл бұрын
I have been wanting cpp2 for a long time. It is much better than I imagined. Would love to see it succeed.
@slipcurve1410
@slipcurve1410 2 жыл бұрын
so modest. i've got a feeling this is going to be a historical talk.
@chalimsupa6603
@chalimsupa6603 9 ай бұрын
learnt alot of c++ by just watching this video... kudos Herb for the effort and all the best with this very worthy experiment
@KulaGGin
@KulaGGin Жыл бұрын
18:55 I was thinking the same, Herb. The *void f(int i) {* syntax is usable, I don't like the *auto f(int i) -> string {* syntax, because it's more text and you have return type written in 2 places. The *f: (i: int) -> string = {* is alright. What I'd also add is the ability to declare a variable of that type to return it: *f: (i: int) -> ComputedText: string{""} = { return Text; };* Why? Because it makes the code clearer: the code explains what it does. Right now you only see the type, like a string, but you don't actually see what exactly the string returns. Like, for example, sometimes it returns an int. Now I have to go and look up the documentation or read the source: does it return an error code, number of bytes processed, or something else?
@herbsutter4340
@herbsutter4340 9 ай бұрын
Thanks! Belated answer: Yes, Cpp2 also has multiple/named return values. You can write your example like this: f: (i: int) -> (computed_text: std::string = "") = { computed_text = Text; } or better still, avoid the extra step of initializing the return value to "" only to overwrite it, like the following where the string is constructed directly from Text: f: (i: int) -> (computed_text: std::string) = { computed_text = Text; /*now a constructor call*/ } Finally, note that there is an implicit "return;" at the end of the function body, and if you want an early return you write just "return;". It's not "return computed_text;" because we already know what the return values' names are, and they were already set, so all you need is "okay function, now 'return;;".
@KulaGGin
@KulaGGin 9 ай бұрын
@@herbsutter4340 Thank you for the answer. I'm thinking of trying it out for one of my personal CMake projects: it's a DLL mod for a game in C++ on Windows.
@mustafaaltay4920
@mustafaaltay4920 2 жыл бұрын
Promising evolution, this transformation became inevitable, good luck Dear Herb ✌
@oskarkirmis4437
@oskarkirmis4437 2 жыл бұрын
It's been a long time I've done c++, but that got my attention back. I could imagine something like this being the default and you can enter "unsafe mode" like in other languages for the "old" c++ style.
@nobodyimportant9073
@nobodyimportant9073 2 жыл бұрын
re: around 1:04:00, if the bounds checking assert_in_bounds is applied to on any stl container with integral subscripts and a .size function, how does it behave with something like map? If I have a map mymap with 3 ints 5, 7, 143 as keys, then mymap[143] is fine, but way beyond the size of the map. (Also, I really like the cpp2 idea. This could be just what we need to clean up the language)
@DotcomL
@DotcomL 2 жыл бұрын
It is very surprising how much can be improved while being tethered to syntax1 code generation. Fantastic work.
@yuryg.
@yuryg. 2 жыл бұрын
That's just a fantastic idea! As Herb said, he wants to teach people more about how to program instead of the details of C++. So and I want to program more instead of learning about quirks of particular syntax/semantics of C++. Herb, you have full support of the random dude from the internet!
@jishanshaikh4
@jishanshaikh4 2 жыл бұрын
The safety idea of showing errors and giving exact solutions for standard recommendations is really good.
@vladimirkraus1438
@vladimirkraus1438 2 жыл бұрын
I love it. I can't wait to start using it.
@PaulMetalhero
@PaulMetalhero 2 жыл бұрын
Even if it doesn´t succeed, you have created an awesome new language!
@cppmsg
@cppmsg 2 жыл бұрын
Fantastic, I don't need backwards compatibly for my green fields programs. And I may not need to learn TS, if this can run in the browser with decent screen IO. :) Thanks to Herb for his long term efforts.
@osrodd2154
@osrodd2154 2 жыл бұрын
I'm amazed. Really hope this project works out.
@Swampdragon102
@Swampdragon102 2 жыл бұрын
I've been avoiding C++ in projects because of all the complexity and the chances to fail miserably. But this looks pretty good! I have one important question though: Why not `const` as the default for everything everywhere? I am a firm believer in "the laziest solution should be the best", so adding sth like an explicit `mut` instead of `const` would fit that paradigm.
@Xeverous
@Xeverous 2 жыл бұрын
I guess Herb simply didn't implement it yet.
@Firestar-rm8df
@Firestar-rm8df 2 жыл бұрын
I agree, many people have the sentiment that mutable by default was a mis step, but to correct it now would break the world. However with cpp2 that isn't a concern anymore. It could even be a flag if there was any strong pushback against it.
@Adowrath
@Adowrath 2 жыл бұрын
@@Firestar-rm8df A flag would mean you can't look at the code in isolation and figure out the meaning. Flags shouldn't be able to change semantics like that, I'd say.
@Firestar-rm8df
@Firestar-rm8df 2 жыл бұрын
@@Adowrath There are already plenty of compiler flags that can change behavior. and preprocessor macros. That's why flags and build scripts are often checked into your repo with the source code as it is a part of your code, just at a higher level of abstraction. -fno-strict-aliasing for example. I'm not saying this is a good thing, I'm saying this is how it is and we wouldn't be any worse off, and having the flag you can set is better than requiring everything to be mutable by default. Also, I imagine you would likely get a compile error if you toggled the flag for a code base erroneously as const-incorrectness simply doesn't compile, which is the beauty of const.
@jan-lukas
@jan-lukas 2 жыл бұрын
@@indiesigi7807 do you know anything about clean code? You should const everything, and having it as the default is even better. An optimal program would be completely made up of constexpr statements, so that only the I/O is not const
@meisenmann-_-
@meisenmann-_- 2 жыл бұрын
Thanks for providing this talk! He already had me at nodiscard is a default. I think this experiment will decide about the future of C++. It has reached a level of complexity with a bunch of optional but actually essential rules to follow, that makes it unappealing to work with. Especially if you compare it to younger languages with all these features baked into the language standard. I hope this will bring C++ to a state of the art level.
@hilllasten7059
@hilllasten7059 10 ай бұрын
I' m so touched by this talk, thank you Sutter!
@0x000dea7c
@0x000dea7c 2 жыл бұрын
Much respect, Mr. Sutter. I will keep an eye on this; amazing work.
@CppCon
@CppCon 2 жыл бұрын
Much appreciated!
@KulaGGin
@KulaGGin Жыл бұрын
36:30 Calling free functions with object syntax is very good, too. C# extension methods. This is very good not only from the toolability perspective, this is also good to better follow single responsibility principle: we shouldn't define draw and save functions inside the classes, but ability to call object.draw() is very nice.
@igoremelianov5200
@igoremelianov5200 2 жыл бұрын
Amazing work! Hope this will get a future!
@VivekNa
@VivekNa 2 жыл бұрын
I have been ranting for years why C style arrays and pointer decay kills the consistent value semantics of C++ This idea of doing away with pointer arithmetic is absolutely the best thing. Also uniform syntax!!!
@lesto12321
@lesto12321 2 жыл бұрын
include std by default? once again, embedded guys are forgotten :(
@totheknee
@totheknee 2 жыл бұрын
This is a gold mine of explicit ideas for doing a C-2.
@Artoooooor
@Artoooooor 2 жыл бұрын
44:38 The problem is simple to solve. Refrigerator, vacuum cleaner, iron, coffee machine and TV have no place in the Internet, and any network at all. Maybe TV, when user explicitely allows it to do so.
@carldaniel6510
@carldaniel6510 2 жыл бұрын
Herb is such a BOSS! I hope this experiment leads somewhere - it'd make me get back to being a C++ developer again.
@TimTeatro
@TimTeatro 2 жыл бұрын
Onece I'm finished my thesis, I'm going to start working on LSP and treesitter for this (with Neovim support in mind). If this reaches escape velocity, it's going to be huge. A transpiler isn't as exciting as something like Carbon, but I think this is the right increment to move forward.
@DerDoMeN
@DerDoMeN 2 жыл бұрын
I wouldn't call that mess of Carbon exciting... Carbon was the main reason why it took me so long to view this video and take it seriously. Carbon from where I stand seems more like a disease while such project finally feels like a benefit to both C++ and programming in general. I'd love to see your transpiler in action but please don't ever implement yet-another-useless-new-language-that-should-stay-in-the-lab-and-instead-extend-C++-with-its-one-trick-pony-feature.
@TimTeatro
@TimTeatro 2 жыл бұрын
@@DerDoMeN Thanks for your comment. Just for clarity, when I was mentioning a “transpiler”, I meant Herb's. It seems to me that `cppfront` is (right now) a transpiler from Herb's Syntax 2 to ISO C++ and STL + cpp2. I was only talking about implementing some tools (a language server and treesitter support) for it.
@007LvB
@007LvB 2 жыл бұрын
How about cppfront being a compiler flag for GCC or clang or MSVC, similar to "-std=c++XX" ? Then potentially it would feel like a built-in part of the language. And since parsers are generated anyways, we could easily go from [Cpp2->Cpp->IL] to [Cpp2->IL]. The solution cannot possibly be to kill C++ by creating a new language, as that does not solve any existing problems but potentially creates several new ones. And C++ is too complicated for practicality in the future. Anyone who would do the same research that Herb Sutter has done, would likely arrive at the same conclusion (or a very similar one).
@roykin0929
@roykin0929 Жыл бұрын
​@@007LvB think the other way around, that's exactly cpp2. With cppfront, you can either write in pure cpp2 or mixed cpp1 and cpp2 and as time goes by, there def would be support for more things
@JohnWilliams-gy5yc
@JohnWilliams-gy5yc 2 жыл бұрын
I love rust grammar. Don't get me wrong. However instead of transpiling, why we can't simply deprecate all those dangerous sharp edges (malloc, allocating new, union, unboundchecked accesses) that now c++ already has safer alternatives then just remove or internalise/classical-mode them. If the *actual* problem is today people still *keep* using them as before. Why won't c++ just stop them from using those?
@tomekczajka
@tomekczajka 2 жыл бұрын
It's a different programming language that interoperates well with C++. Herb keeps saying "it is C++" but I don't know what that means.
@piotrarturklos
@piotrarturklos 2 жыл бұрын
I think he means that it's built using the same underlying concepts and features, as proven by the fact that it compiles down to C++
@tomekczajka
@tomekczajka 2 жыл бұрын
@@piotrarturklos C++ compiles down to assembly, but it doesn't make it assembly.
@yldrmcs
@yldrmcs 2 жыл бұрын
This is a revolutionary approach and I loved it :)
@juliejones8785
@juliejones8785 2 жыл бұрын
Herb, you have outdone yourself this time!
@Bolpat
@Bolpat 2 жыл бұрын
46:59 Does it really make sense to have _D_ *is* _B_ mean “is _B_ a base class of _D”_ and _“D_ is the same type that _B_ is?”
@nyanpasu64
@nyanpasu64 2 жыл бұрын
- How do you deallocate objects referenced by multiple intrusive linked lists (Linux kernel code) if you can't destroy raw pointers? - What happens when you pass the same value to an in and inout parameter, and mutate the inout parameter? Does the in parameter change or not based on its size?
@ZeroPlayerGame
@ZeroPlayerGame 2 жыл бұрын
I think using C syntax for something as specific and ultraoptimized as kernel data structures would be ok.
@nzer19
@nzer19 2 жыл бұрын
> What happens when you pass the same value to an in and inout parameter, and mutate the inout parameter? Does the in parameter change or not based on its size? That would seem to be the case. Same situation would happen if the in param was accessible from another thread. Guess would need something equivalent to volatile to stop this "copy if small" optimization.
@carl8703
@carl8703 2 жыл бұрын
I really want this to work as intended, but I start to have a sinking feeling right around 1:45:30 when Herb tries to reassure me that I can still use union with it if I want. Am I misinterpreting this? Because to me it sounds like Herb is trying to say you could always just mix and mash cpp1 and cpp2, just like you could always mix and mash c with cpp1, without any barriers or demarcation. I get that the prototype uses a transpiler, that's great that it makes it easy to prototype, and backwards compatibility with cpp1 is a side effect that is supported by that transpiler, but I'm thinking about how cpp2 would be implemented long term. Maybe it was a mistake to implement c++ using cfront - it just led to to the mindset that the language was an extension, when perhaps it would have served better as a clean break. Maybe now that mistake has reached a tipping point, only now we are repeating the same mistake by implementing another transpiler? Consider a dystopia: the year is 2050, Rust and Go are long dead - cpp2 stole all their market share since everyone thought that was the quick fix. However everyone still predominantly works with a bunch of broken legacy cpp1 code. The only difference now is that the resulting hybrid cpp1/cpp2 language is even more complicated than it was before, since alongside all the C++ sublanguages that existed circa 2022 (legacy C, macros, stl, template metaprogramming), there is now also the cpp2 sublanguage, which is so complex that it was designed to subsume all functionality from every other sublanguage. The language developers only served as the enablers to a stunted userbase. It's 2050 and no one ever bothered to implement any clean keyword demarcation or file type extension that could have helped tooling developers to make out what code is cpp1 vs cpp2. No one ever bothered to implement constraints that would have helped to coalesce the ecosystem towards cpp2 to the point where compilers could drop support for cpp1 and relegate it to special purpose compilers. No one ever even bothered to make the "-p" flag a default, and as far as that goes, the language still manages to get the default wrong by default. Backwards compatibility is so entrenched an idea that even when people want desperately to break from it they still find themselves clawing their way back to it. It's 2050 and all the compilers still have to support cpp1, and all the tooling has to work around a minefield of cpp1 code whose grammar is so complex they could never hope to support it without the backing of a major software company. I know we really want to avoid another Python 2->3 debacle, but the fact remains that Python made it through that migration no less popular for it and something was gained from it. And that isn't the only example. Fortran 77->90 comes readily to mind here - just as with pointer-arithmetic and memory-leaks-by-default, you have to admit it is a pretty stupid thing to say that type is assigned based on the first character of your variable names, and sometimes you just have to have the courage to admit that it was a stupid idea and make a clean break from it. Other times, just as when C made a clean break from Fortran, the resulting language is less performant. You just have to accept that some people will never change, they will always want their unions simply because that's faster, and to them you have to ask, "why aren't you using Fortran?"
@____uncompetative
@____uncompetative 2 жыл бұрын
Any sufficiently complicated C program contains an _ad hoc_ informally-specified bug-ridden slow implementation of half of Common Lisp.
@007LvB
@007LvB 2 жыл бұрын
This is nicely written! But I think it's still better than the alternative where everyone switches to Rust, and there will be no developers left to maintain the billions of lines of C++ that makes the entire world work. Dijkstra taught us to avoid goto, and so we don't use it even though our languages still allow it. If we adopt a rule of using Cpp1 to maintain legacy code and Cpp2 to extend it (open/closed principle), then we should see a gradual transition away from Cpp1 coding, resulting in a better world. Even though I understand (and actually appreciate) your sentiment, I think it's important to stay hopeful and optimistic - because that inspires people to solve problems. As long as there exists a healthy scepticism, which is abundantly present in the C++ community.
@fnizzelwhoop
@fnizzelwhoop 2 жыл бұрын
I have been on a "Rewrite it in Rust" path for the past few years, and am down to one last rather large C++ project that I was wondering if I should rewrite as well. Recently I decided to finally take the plunge, but this talk made me rethink it. I'll leave it C++ for now and see how cppfront develops. The cppfront code is surprisingly small, considering what it can do -- Herb managed do a lot with relatively little code. I'm cautiously optimistic!
@Megalcristo2
@Megalcristo2 2 жыл бұрын
1:24:56 That is called "naked return" in Go and is kind of controversy…
@QuickNETTech
@QuickNETTech 2 жыл бұрын
I'm not sure if there's much meaning to the fact, but with Cpp2 you can (or should be able to?) do main: () -> int = { std::println("Hello, World!"); } which is the first time we've had the ability to write that on one line to the best of my knowledge. No #include needed, not even an import, just code.
@somenameidk5278
@somenameidk5278 11 ай бұрын
you need to return an exit code
@driedurchin
@driedurchin 2 жыл бұрын
I see the value of this for C++ programmers, but I wonder what the experience (say 5 years from now if this is stable) for people who don't understand the generated code? Will the semantics stand on their own without contextualization with existing cpp jargon? Very interesting indeed.
@russianbotfarm3036
@russianbotfarm3036 2 жыл бұрын
Well, maybe - hopefully! - it’ll be fully implemented into compilers and won’t _be_ a ‘-front’ anymore.
@BryonLape
@BryonLape 2 жыл бұрын
I haven't programmed in C++ in nearly 20 years and can't really read the modern version.
@007LvB
@007LvB 2 жыл бұрын
@@BryonLape That is probably one of H.S.'s largest motivators? C++ should be a syntactically and semantically simple language that is easier to teach and learn. Bjarne Stroustrup seems to share this sentiment.
@xmk89
@xmk89 9 ай бұрын
Great talk, Herb ! As usual
@MrAbrazildo
@MrAbrazildo 2 жыл бұрын
11:58, ?? 18:40, I didn't get the idea: why this new syntax could update older code, and why the old not?
@feraudyh
@feraudyh 2 жыл бұрын
I worked for a company that built a front for a second language, and used Prolog to write this. Prolog was very powerful for this purpose (perhaps not that fast, though).
@indiesigi7807
@indiesigi7807 Жыл бұрын
So if we really do need a successor, having looked at all the contenders, I can get behind Herbs cpp2.
@nordern1
@nordern1 2 жыл бұрын
I didn't run of to a different language, I came in as a compiled language newcommer and chose rust, partly because C++ just appeared bloated, with a lot of "Yes, this is the most straight-forward way, but it's unsafe and we don't do that anymore", and no consensus as to what current best practice even is. I wish this project the best of luck :)
@soniablanche5672
@soniablanche5672 10 ай бұрын
implying rust isn't bloated
@cgerman
@cgerman 2 жыл бұрын
I don't think it's a matter of improvement, it's a matter of survival. When there is a guideline telling you to stop using C++ then it's not up to you anymore. When your company says that we have to change language because otherwise our software will be labelled as 'unsafe' because C++ is in a list of unsafe languages what will you do?
@CaleMcCollough
@CaleMcCollough Жыл бұрын
The way I solved this problem with Script2 (Serial Chinese Room Interprocess and Telemetry Script) was I didn't use the std library and I instead wrote everything by hand using contiguous Automaton SCII data types that auto-grow from stack to heap. I use a single translation unit that can compile all the code in seconds. You really don't need to use multiple translation units until you're trying to complete many huge libraries in parallel using one translation unit per library.
@zenteapot
@zenteapot 2 жыл бұрын
This is literally like a dream come true. More than once I've written fake cpp code in an empty editor just to imagine what a unified function syntax would be like, what a unified paramter passing paradigm would be like without all the const ref crap. There is an echo in my soul that this just makes so much sense, and I beleive it is a common feeling among many cpp coders. Yet cpp toolchain always felt like a behemonth that's too big and too complicated for a lone developer to tackle on. So a great many lone developers are left to just imagine what's possible. It really need someone like Sutter to push this venture. Please make this happen. Sutter is like jesus reborn for cpp.
@MikkoRantalainen
@MikkoRantalainen 10 ай бұрын
1:23:00 Do you think that this "cpp2" is C++? I think you could as well call this code E (because D was already taken) because the syntax doesn't even look like C++.
@totheknee
@totheknee 2 жыл бұрын
36:23 - Why is it required for tooling? Why can't a tool look up functions that take a data type? e.g., I type `myfile.` in pure C99 (where myfile is obviously a struct), and as soon as I hit the period key, Intellisense pops up all the functions that accept a `FILE` (or whatever `fopen` returns) as the first arg. They are equivalent, and only differ in syntax sugar, right?
@lobaorn
@lobaorn 2 жыл бұрын
Another amazing talk by Herb!
@monad_tcp
@monad_tcp 2 жыл бұрын
53:33 As you are there, can we remove aliasing, can't we ?
@jens6398
@jens6398 2 жыл бұрын
Apart from the left-to-right syntax, I wonder what part of this couldn't be implemented in the cpp-compilers?
@KillerMZE
@KillerMZE 2 жыл бұрын
If there's no preprocessor, what's the alternative for #ifdef and friends?
@SqueakyNeb
@SqueakyNeb 2 жыл бұрын
For things like #ifdef WINDOWS or #ifdef DEBUG? I'd assume some sort of constant injection.
@hughmanwho
@hughmanwho 2 жыл бұрын
So.. he's creating a new language that compiles to C++.. but saying he isn't? What am I missing?
@MichaelBehrnsMiller
@MichaelBehrnsMiller 2 жыл бұрын
Hits so hard. Imho this seems to be the path forward to keep our hands on the full power of C++ while getting more compiler-driven safety with least friction.
@DrGreenGiant
@DrGreenGiant 11 ай бұрын
Superb talk. Question regarding pointers; what happens when you have pointers that don't point to objects? I.e. registers or memory mapped devices, for example? Is this still possible in cpp2 pure?
@coolcax99
@coolcax99 2 жыл бұрын
I am not sure I understand banning null pointers. How would one create data structures like trees without null pointers? By allocating space for some placeholder null pointer?
@007LvB
@007LvB 2 жыл бұрын
Look at functional languages, e.g. F#: type BinTree
@piotrarturklos
@piotrarturklos 2 жыл бұрын
The parameter passing syntax looks like it would be non-trivial to learn and therefore may impede the adoption of cpp2 if it is implemented as shown in this talk. GC, if added, will probably lead to fatal fragmentation of the community, as it did with D, because half of the community will just switch it off. This whole proposal in general is great as an improvement to teaching, learning and safely using of C++. One other problem I see is that it is not a huge immediate improvement in most C++ use cases, so bottom-up adoption may be slow.
@oscarsmith3942
@oscarsmith3942 2 жыл бұрын
I don't think it's that complicated to teach primarily because the default (in) is the right answer 75% of the time, and when it's not it's obviously not, and inout is the answer.
@roykin0929
@roykin0929 Жыл бұрын
The presented system of parameter passing is far easier than what we have today.
@peregrin71
@peregrin71 Жыл бұрын
At 1:06:54 Why a const char*, this can point to a buffer with a non-null terminated string. Use something which has a size e.g. a string_view.
@herbsutter4340
@herbsutter4340 9 ай бұрын
Right, there's a comment in the code that the only reason it's not string_view right now is waiting for the standards update that guarantees string_view is trivially copyable, so that it's passed by value.
@peregrin71
@peregrin71 9 ай бұрын
@@herbsutter4340I must have missed that detail then. I am at the moment happy to pay a little runtime cost for using string_view. (safer code). Anyway I really like the way you're looking at C++, "there is indeed a smaller language waiting to get out" Now we still need to teach the teachers :)
@soniablanche5672
@soniablanche5672 4 ай бұрын
ok... now you have string_view that points to a non-null terminated string what did you accomplish ?
@ansakyt
@ansakyt 2 жыл бұрын
When Herb put C# handle allocation into a dialect of C++ (gc_arena, 2016), I thought "what a waste" . Making gc.new available is the appropriate place, the C++ place, to put this kind of compatibility. You can still have full cpp2-like syntax whether you must run in CLR or not. I saw gc_arena on an early slide and wondered how much time was going to be wasted there. Answer: NONE! As soon as he talked about allocating memory on the stack, on the heap, wherever, I realized that he'd arrived at an answer to this that anyone, even a curmudgeon like me, could be delighted at. Good Job, Herb. I've also been bounds-check resistant because -- well, short answer is, the last time this was a flaming conversation for me was in the 90s, before Moore's Law had done most of what it could to processor speed. I saw code-bloat and exec time grind-down in that direction. Having cpp2 do it naturally, natively like that (post-[size]Moore, too) is DEFINITELY a step in the right direction. And even from outside the US, we have to take "Wherever possible, do not use memory-unsafe languages" really, really, seriously. This is a way to do that. I want to be HAPPY to write C++ for a long time yet and cpp2 may be the best way forward. (see 40'00 - 45'00) okay, I'm a full-on C#/.NET hater.Hate on me for it. I think I have valid reasons but I acknowledge that there is lots of good code -- e.g. Zachtronics -- written in C#. This is not the place for those reasons.
@khatdubell
@khatdubell 2 жыл бұрын
"don't pay for what you don't use" and "bounds checking by default" seem mutually exclusive
@herbsutter4340
@herbsutter4340 2 жыл бұрын
That "by default" is important... you can turn it off and then you don't pay for it.
@anonydun82fgoog35
@anonydun82fgoog35 2 жыл бұрын
It's called learning to code, which is quite a bit different from building programs with copy/paste.
@LaserFur
@LaserFur 2 жыл бұрын
How would you implement the Quake Inverse square function? And embedded programs need reinterpret cast to pass floating point values in there native format over communications. Try sending a 32 bit float in C#. There used to be a function in C# that would let you get the binary bits, but they took it away and I had to move that program to C++. I do like the In and out functions. I already have _In and _Out in my functions. I also had to disable Null pointer checks on one project as the memory started at address zero.
@nathanchappell6308
@nathanchappell6308 2 жыл бұрын
Not the quake inverse square, but I had to do a conversion from IBM Mainframe floating-point to IEEE double in C#, I got at the bits okay. Here is a fragment of that code: ``` double result = 0; unsafe { ulong* result_p = (ulong*)&result; *result_p = (signVal
@sporefergieboy10
@sporefergieboy10 2 жыл бұрын
I don’t know what you’re referencing but using reinterpret_cast would be undefined behavior. So whoever told you not to was right. I looked it up and I guess you’re supposed to use memcpy since it takes void*’s so it won’t violate strict aliasing. And the compiler should be able to optimize it.
@007LvB
@007LvB 2 жыл бұрын
@@sporefergieboy10 reinterpret_cast is necessary when writing allocators, and possibly in other scenarios as well. This is why C++ contains a lot of stuff - because it's needed. If one creates an entire new language without those features, then people will actually not use it.
@MisterDan
@MisterDan Ай бұрын
Really nicee tal. Full of great ideas on FRONT.
@fareloz
@fareloz 2 жыл бұрын
I don't understand why people rave about this presentation. The problems described don't require new (ugly) syntax or compiler to be solved, we just need to improve current compilers. The real problem in cpp is that with every new feature it forces you to go templates which really hard to debug
@herbsutter4340
@herbsutter4340 2 жыл бұрын
Templates can be arcane, that's true. But a lot of the problems with C++ are around things like defaults, where we have to teach people to overcome language defaults that are often wrong, and it's not possible to change defaults because any change would be a massive break. For example, we teach people to be careful about the compiler-generated special class functions that are generated silently by default and that are dangerous for many classes, and to remember to suppress those when they're often wrong... but we can't change the language to not generate them because that would break all the classes that rely on them, we can only do that if we have a second syntax that is not in use today. Another set of problem is around where the language just has multiple divergent ways to do the same thing in different places, and we can't really fix that without unifying those ways. I have one suggestion: Would you please check out slide 95 at 1:39:00 and see if that list might be more persuasive regarding the amount of arcana we have to deal with in today's C++? If we can remove that 'accidental complexity' that isn't core to the language's value, I think we should try. $0.02!
@fareloz
@fareloz 2 жыл бұрын
@@herbsutter4340 You don't need another compiler or syntaxes. You just need additional flags and checks for current compilers. Then it is the same: if you want it - you use it.
@herbsutter4340
@herbsutter4340 2 жыл бұрын
@@fareloz I'd love that to be true. It needs more than assertion that it's possible though... a lot of smart language experts and tool developers have been trying that path for years. But perhaps you're right that there's something they've missed -- I welcome the detailed proposal and the working tool or prototype to try out, that demonstrates how it can be achieved in an adoptable way (tools for today's syntax that are efficient and noise-free enough for everyone to be able to turn on at build time) and also achieve the same goal (at least of reducing what we have to know/teach by 90%, and reduce CVEs by 98%... it can't make C++ 10% the cost to write tools for but I'd be happy just to get the first two if it's practically possible despite experience so far).
@fareloz
@fareloz 2 жыл бұрын
@@herbsutter4340 There are many caveats which compilers warning about already: usage if initialized variable or dereferencing of null pointer, usage of moved object and many other. You can always force this warnings to be an error. [[nodiscard]] can be added implicitly too by the compiler. Maybe I miss something from the talk (or just simply don't understand), but I don't why I need another layer for this.
@ElPikacupacabra
@ElPikacupacabra 2 жыл бұрын
I'm not convinced a systems level language should force smart pointers or particular trendy abstractions. For example, pointer manipulation is essential. There's too much handwaving in the answer to that question that was asked at the end. Maybe this is the direction of evolution of C++, but then it won't be C++ anymore. For me, C++ is the language I go to for maximum computing efficiency. This seems to be an example of the age-old tension in language design: Some people want a safe, productive language that is nice to use, but many want a useful language that can get out of their way when they program at a low level. Personally, I think that the safety features should be left to tools, and the language should be kept as simple and as unlimited/expressive as possible.
@007LvB
@007LvB 2 жыл бұрын
From a point of security, it actually makes a lot of sense for a systems language to enforce pointer safety. You gain more by having an extra indirection (which is not always used, as in the case where shared_ptr is passed as const&), than by risking a lot of security vulnerabilities. Our processors are quite a bit more powerful today than they were 20 years ago, and this question is less important today. The only place where this has some merit is in strict realtime applications, and even there we don't always want to manage everything. In my own opinion, safety is more important than speed. But we can test for safety and then disable those tests later with some compiler optimizations and flags. Besides, we also need to educate programmers as better programming practices evolve. Just as we did with goto, now it is happening with the preprocessor.
@JohnDlugosz
@JohnDlugosz 2 жыл бұрын
Can CPP2::in be used today, on its own? Now that we can write that instead of typename CPP2::in::type , I thought something like this would have been promoted already. Basically, for template types, automatically decide whether to pass by value or reference based on T.
@Dominik-K
@Dominik-K Жыл бұрын
Very interesting and thought-provoking talk, love the experiment proposed here
@notapplicable7292
@notapplicable7292 Жыл бұрын
Only c++ devs could look you in the face and say they like the status of c++ package management
@diakritika
@diakritika 2 жыл бұрын
Does it still allow "Null" as a person's name?
@JohnDlugosz
@JohnDlugosz 2 жыл бұрын
I think what wasn't clear in the talk about nullptr is that it's better to have compiler support for knowing a variable is uninitialized then to initialize it to something utterly useless. I'd like to see that generalized to any type, marking whether I want the default constructor or leave it uninitialized, and give the compiler freedom to elide the default constructor when it's capable of tracking definite first use.
@potter2806
@potter2806 2 жыл бұрын
I'm very impressed for the modern cppfront idea! Actually, the cpp1 is huge currently.
@defnlife1683
@defnlife1683 Жыл бұрын
I love programming in straight C. Maybe this is what I needed to jump into C++.
@aaardvaaark
@aaardvaaark 2 жыл бұрын
Herb has one of those beautiful brains that thinks incredible things and also has enough horsepower left over to explain it in a digestible way. I loved this idea so much. The semantics looks very simiar to object pascal, without the ugly verbosity. I wonder what anders hejlsberg would think about it.
@raceordie690
@raceordie690 2 жыл бұрын
Bravo! 👏 Bring it on.
@moderncpp
@moderncpp 2 жыл бұрын
When it comes to cppcon, Herb Sutter is my second favorite speaker (after bjourne stroustrup)
@kostaad
@kostaad 2 жыл бұрын
​Wasn't it the purpose of Carbon by google, to have a different syntax that yet will be able to cohabitate with C++ syntax?
@esra_erimez
@esra_erimez 2 жыл бұрын
C *has* abstraction. It abstracts the hardware in a way no other language did up to that point.
@nicbarkeragain
@nicbarkeragain 2 жыл бұрын
This really reminds me of how refreshing it is using the Burst compiler in Unity. Small bubble of "new c#" that is isolated and allows you to really claw back the performance where it matters.
Back to Basics: C++ API Design - Jason Turner - CppCon 2022
1:00:42
小丑女COCO的审判。#天使 #小丑 #超人不会飞
00:53
超人不会飞
Рет қаралды 16 МЛН
黑天使只对C罗有感觉#short #angel #clown
00:39
Super Beauty team
Рет қаралды 36 МЛН
Andrew Kelley   Practical Data Oriented Design (DoD)
46:40
ChimiChanga
Рет қаралды 153 М.
Herb Sutter - Peering forward  C++’s next decade
59:59
code::dive conference
Рет қаралды 4,4 М.
Why Can't We Make Simple Software? - Peter van Hardenberg
41:34
Handmade Cities
Рет қаралды 179 М.
Faster than Rust and C++: the PERFECT hash table
33:52
strager
Рет қаралды 613 М.
Delivering Safe C++ - Bjarne Stroustrup - CppCon 2023
1:29:16
小丑女COCO的审判。#天使 #小丑 #超人不会飞
00:53
超人不会飞
Рет қаралды 16 МЛН