CppCon 2018: Kate Gregory “Simplicity: Not Just For Beginners”

  Рет қаралды 61,088

CppCon

CppCon

Күн бұрын

Пікірлер: 66
@bilbobeutlin6979
@bilbobeutlin6979 6 жыл бұрын
Her course on coursera "Beautiful C++: STL algorithms" really changed the way I code C++ and made me appreciate it much more. Awesome talk!
@naps9249
@naps9249 6 жыл бұрын
it's on Pluralsight, I think
@IncompleteTheory
@IncompleteTheory 2 жыл бұрын
Timeless wisdom from Kate once again. Thanks for this great talk! Every dev - no matter the language! - should watch and embrace this. On a personal note, I have to do lots of work for certifiable software, and most certification processes are inherently very, very hostile towards code refactorings. Effectively, refactorings are often too expensive to be made because while the tools do it in sub-seconds, the subsequent paperwork will take days or weeks. So often times, code is not allowed to be made better in the spirit of this talk, and that is an extremely unpleasant thing to experience.
@WiktorWandachowicz
@WiktorWandachowicz 6 жыл бұрын
Several important parts of this talk (meaningful names, short functions, caring about the reader of code, etc.) are very, very similar to "Clean Code" practices, as praised by Robert C. Martin a.k.a. Uncle Bob. While "Clean Code" mostly referred to Java, Kate's approach is C++ oriented - which I find very valuable. I was practicing clean code for over 3 years already, personally and with my students. And I can easily observe how much the quality of code improves. Especially my beautiful code ;) So go for it Kate! And big thanks for this wonderful talk :)
@LuluTheCorgi
@LuluTheCorgi 5 жыл бұрын
The book was mentioned by an audience member in the end too :p
@KulaGGin
@KulaGGin 2 жыл бұрын
Clean Code isn't referred to Java. Uncle Bob's Clean Code and Clean Architecture is applicable to any language. He even talks about specifics of applying the techniques in different langauges.
@JasonMercer000
@JasonMercer000 6 жыл бұрын
Thank you for this talk. I'll buy pizza for my department and we'll be watching it together over an extended lunch.
@tobiasl.9977
@tobiasl.9977 6 жыл бұрын
I've often seen experienced developers writing a lot of hardly understandable and complex code along with a ten line comment that's even harder to understand. An attitude associated with this is that they think their code is great, because it "works" and nobody else is remotely able to understand it without spending a lot of time. That is detrimental to product development and team work. The real art is to write code that's simple yet capable of doing the job.
@mozismobile
@mozismobile 6 жыл бұрын
I work for someone who can't describe requirements simply and clearly. It's very rarely possible to implement those requirements except as a long list of special cases. Drawing little matrices of input conditions and program states leading to outputs seems to be required, and it gets messy. After 4 years I'm convinced that he doesn't exist in a systematic world (whether that matches external reality is largely irrelevant, I don't have access to it).
@tobiasl.9977
@tobiasl.9977 6 жыл бұрын
mozismobile That doesn't sound good. I'd recommend you talk to them and if that doesn't help, get out as soon as possible. You shouldn't be driven by someone's purely technical requirements even if they were well worked out. That external reality you describe should be the driver of your work and you should have access to it. Let me know if you need help. I'm sure we'll find a way to connect.
@thorham1346
@thorham1346 6 жыл бұрын
Not all algorithms can be implemented in a simple way.
@mozismobile
@mozismobile 6 жыл бұрын
Yeah, thanks, but I think having someone else filtering customer requirements is a benefit to me. My code has to deal both with the internet and with people, so it's necessarily quite complex. Whether there exist simple rules describing any of the systems I deal with is only known when it's negative. Like "what can go in a UDP packet" where the answer is either "anything" or a long, long list of "if this then that" type rules.
@tobiasl.9977
@tobiasl.9977 6 жыл бұрын
@radbarij Yes, it's easy to say and hard to do in practice. That's the whole point of the video, isn't it? Feel free to demote "Simple yet capable of doing the job" or "As simple as possible, but not simpler" as "weasel words" if you like, but this is the only general thing one can really say to address your point. Everything else is problem-specific, hence writing simple code is hard work as outlined in the video.
@Ptr-NG
@Ptr-NG 5 жыл бұрын
Love the way this woman simply presents the stuff! I am a simple man, love simple women, and i must learn simply simple things.
@gal88b
@gal88b 6 жыл бұрын
Kate, you are a treasure
@jvsnyc
@jvsnyc 3 жыл бұрын
This talk is great. There are two kinds of people who don't like it. Those who already do everything she says, and the talk really isn't for them, and those that like their complexity and don't think they need it...if they get thru it without being convinced, it probably isn't for them either. I knew a lot of these, but do I always DO them? No, and it makes a difference.
@ABaumstumpf
@ABaumstumpf 2 жыл бұрын
Recently i did finally use the immediately-invoked-lambda-initialisation. It was handling a user-input that sets some context-specific member-value - with the option of default-values and for different types. For tracing and styleguide we have to trace out the old and new value and the name of the member that was changed. It is not simple code but a dedicated function for a single-use object that requires several variables of the surrounding scope also seemed excessive. But sure as hell i want that "newValue" to be const as i had previously seen people doing a *"if(newValue = -1)"* and then wonder for ages why it does not work like they intended.
@davidmiller1376
@davidmiller1376 Жыл бұрын
Brilliant talk. Clear, concise, well explained. Thanks, Kate.
@beastyshout
@beastyshout 2 жыл бұрын
Writing complex code requires experience, simplifying complex code requires mastery.
@benhj
@benhj 6 жыл бұрын
Absolutely awesome talk! Thanks!
@kamilziemian995
@kamilziemian995 2 жыл бұрын
She is great, entertaining speaker, no doubt about it.
@TheLavaBlock
@TheLavaBlock 6 жыл бұрын
I like it simple. It can be so easy. Great talk!
@LiveseyMD
@LiveseyMD 6 жыл бұрын
The main question is how to convince the management that code base should be rewritten because it is not maintainable?
@BretKuhns
@BretKuhns 6 жыл бұрын
If you think your whole codebase needs to be rewritten, you have already lost. Instead, learn how to "Work Effectively With Legacy Code". As Kate said, that UpdateDatabase() function that might be 12,000 lines long doesn't need rewritten if it does it's job. It's effectively 0 lines long to you, the caller. *If* however, there's a bug in it and you need to change it, that's what you start identifying seams and making gentle refactorings; maybe get some characterizations tests in place first. Start sprouting functions or classes, maybe use "form method object" to tackle long functions, etc etc.
@kamilziemian995
@kamilziemian995 2 жыл бұрын
What a great and inspiring talk.
@CppCon
@CppCon 2 жыл бұрын
Your comment is very much appreciated.
@andreasnilsson4300
@andreasnilsson4300 2 жыл бұрын
A fantastic talk.
@ЮрийВосель
@ЮрийВосель 6 жыл бұрын
58:00 - what's 'chase the const'?
@crogersdev
@crogersdev 4 жыл бұрын
"chase the const" is when you try to identify where in your code a value is being changed when it wasn't supposed to be. if you add `const` to one spot and then re-run the code or re-test it, and your bug still appears or your values keep changing but in new and unexpected ways, then you have to keep trying to chase what changes and protect it with const as values and objects are passed from module to module. it's an argument in favor of 'const correctness,' which you have probably heard of. if not, read this to start: isocpp.org/wiki/faq/const-correctness
@KarelDonk
@KarelDonk 6 жыл бұрын
Good advice, very pleasant to watch and listen to.
@tommyqjr
@tommyqjr 6 жыл бұрын
Wonderful talk! Thank you :)
@PixelPulse168
@PixelPulse168 6 жыл бұрын
I need more C++ talks!
@tomkirbygreen
@tomkirbygreen 6 жыл бұрын
Fantastic video Kate. Much stuffs for reflection.
@code_report
@code_report 6 жыл бұрын
Clicked like button 1 minute because i know talk will be awesome!
@slavamelanko5992
@slavamelanko5992 6 жыл бұрын
I like simplification too - "Make Simple Tasks Simple!" (c)
@gvbezoff
@gvbezoff 6 жыл бұрын
Care to try to apply this to assembly language? Or is that a pipe dream.
@botetescribavicentej.2326
@botetescribavicentej.2326 6 жыл бұрын
Great talk. In 20' I would add that "auto don't justify the absence of const" Moving from for( auto p: people) to for( auto& p: people) will not protect you from modifying p. If you need performance, don't forget correctness for( auto const& p: people) Another core rule "Don't forget const when using auto if you want immutability"?
@masheroz
@masheroz Жыл бұрын
Modifying p and auto are orthogonal. The first is a copy, and the second is a reference to the thing in the collection. Both are modifiable, just one has side effects. You can use const without auto.
@Mempler
@Mempler 3 жыл бұрын
Ngl, the one thing i do when i use other people's libraries: i wrap them around to 1( Simplify it, 2) To make it fit my code style.
@danielro1209
@danielro1209 4 жыл бұрын
So true. Great talk.
@PeterSommerlad
@PeterSommerlad 6 жыл бұрын
For the const recommendation, at least give our Constificator plug-in a try (as part of the Cevelop IDE). It will recommend adding const where appropriate and do so for you.
@jonathanccast
@jonathanccast 5 жыл бұрын
Walls vs fences: it's not a wall until your co-workers start blindly applying it during code review
@FreeER
@FreeER 6 жыл бұрын
like 4 minutes in and sure, teach what you're trying to teach. But the problem of not showing error checking is that NO ONE EVER TRIES TO TEACH ERROR CHECKING. Therefore, it's NEVER shown and no one ever learns it from others because it's simply not taught. Until it matters, hopefully. Agree with essentially everything else :) Not sure I agree invisible functions are 0 lines long but that's an issue when it's an issue or you want a challenge (that you're willing to verify your solution to) xD
@masheroz
@masheroz Жыл бұрын
I want to see a presentation on a console program that asks your name and says "hi $name". And then goes over the fuzzing, malicious input, unit testing exception handling...
@Bolpat
@Bolpat 6 жыл бұрын
46:57 the conditions are not flipped. They *seem* to be flipped, but for floating point numbers, (x < 0 || x >= 0) is not generally true. Not considering Not-a-Number values is a serious mistake and a subtle cause of bugs. If you need (x > 0), use if (!(x > 0)) { errorRoutine(); } because (x
@a.arredondo
@a.arredondo 6 жыл бұрын
47:08 "it is a possible bug so tests will help you".
@tauicsicsics
@tauicsicsics 6 жыл бұрын
Old talk, CppCon deserved a new talk from the great Kate...
@WalderFrey
@WalderFrey 6 жыл бұрын
She always does the same talk. Well, I think so, I can't watch to the end.
@gregcons
@gregcons 6 жыл бұрын
I have done Simplicity a few times before. This was an expanded version and also a rearranged one. I think it's a lot better than the previous versions
@rdstevens1
@rdstevens1 6 жыл бұрын
WalderFrey I buy
@rdstevens1
@rdstevens1 6 жыл бұрын
Taw Moto mlhumtuuiuok
@marekruszczak460
@marekruszczak460 5 жыл бұрын
This talk is about obvious things. Sad thing is that I'm keep seeing code which is in contradiction with this simple rules and when I'm pointing it out in code reviews I'm ignored :(. So we need more presentation like this, which in simple words explains why magic numbers are bad, why long functions are bad and so on.
@Stierguy1
@Stierguy1 5 жыл бұрын
const everything is really great until you accidentally prevent a copy elision. Don't const variables used as operands to return statements when their type matches the return type.
@FedJimSmith
@FedJimSmith 6 жыл бұрын
If u have mastered a certain language, her message is easily obvious without anyone teaching you
@multigladiator384
@multigladiator384 5 жыл бұрын
But the logical "&&" is just great.
@mrlithium69
@mrlithium69 6 жыл бұрын
@ 38:00 + 39:37 She willfully ignores that one is clearly Windows platform specific C code , and the other is C++. @ 32:50 - She mentions a wall of variables at the top, and why didnt you assign when you declare? Because that comes from C.
@jamesofnoaffiliation
@jamesofnoaffiliation 6 жыл бұрын
C++ is a superset of C. A lot of older or poorly designed C++ codebases have either (1) legacy C code or (2) developers from a C background that wrote their code to be 'C with Classes'.
@gregcons
@gregcons 6 жыл бұрын
Your point is valid and I've added it to my slide notes. Both slides are live code (before and after) from a real project. Yes, the original used TRUE and FALSE and I switched it to true and false. It was Windows-specific, it was being compiled as C++, and I replaced it with C++ that was (at least in that function) no longer Windows-specific. That made the code better, which was my point with the two examples.
@nottellinganyoneanything
@nottellinganyoneanything 6 жыл бұрын
simple and simpler
@cicciobombo7496
@cicciobombo7496 6 жыл бұрын
49:27 7/10 joke
@ashw6015
@ashw6015 6 жыл бұрын
This is kind of why I hate the c++ community. It's utterly embarrassing that this room of experts needs such a basic talk. The standard library design is garbage, boost APIs are garbage. Pretty much every C++ book is full of garbage code too. If someone writes C++ and only C++ and has done it for a long time, there's a high chance that they just write garbage because they go through their careers without ever seeing a good example of professionalism. I do like Kate Gregory and enjoyed a lot of what she had to say but I agree with the guy's point at the end that seemed to go straight over her head. Architecture is required for testability. We don't abstract so we can switch out mythical production components. We abstract so we can mock. But the lack of decent unit testing and dependency injection infrastructure in the language and tooling means this isn't part of the consciousness in some parts of the community.
@orangestapler8729
@orangestapler8729 6 жыл бұрын
The mocking part really sucks for C++. I had to give up mocking because none of the frameworks are good, or the one that was good was unstable. I wish it was as easy as say Java. I also dislike the insanely and wildly varying code styles, they differ so much between projects that I feel like I'm reading a new language. I've never had this experience in any Java or C# project yet (and I do this for a living, though from a devil's advocate point of view I might have just worked at good places).
@kousoulides
@kousoulides 5 жыл бұрын
disagree.
@slyy4096
@slyy4096 5 жыл бұрын
Simple, but TL;DW :lol:
@slyy4096
@slyy4096 5 жыл бұрын
I totally agree that we continuously write simpler and simpler code, especially when the underlying system is inherently complex or would gain some precision or needed quality when being able to make it more deep. Generally, pushing 3 dimensional thing into 1 dimension of text is over simplification. I support that 1 dimension of code is self-explaining what i does, 1 is doing error checking, 1 is for debug output, 1 is for comments. Similarly this video is like billion codes in 1 dimension used to encode the idea, but pushing it to X & Y & t dimension, makes it shorter... Consists of language that the watcher knows, not some other language. Same with code - if your audience is old-skool embedded C gurus, it would feel overly verbose to write/read 1 screenful of code into 4 screenfuls for new-age high-level-lang / scripters or beginners audience. Not worth to write: variable_stored_in_stack_as_first_input + variable_stored_in_stack_as_second_input. a + b loses less of the meaning as reading time is limited too. There's a compromize making code longer or deeper. For example: if call stack is already 20 different functions deep, just to keep all function short and 10 lines long instead of 20 lines long and 10 levels deep...
Cheerleader Transformation That Left Everyone Speechless! #shorts
00:27
Fabiosa Best Lifehacks
Рет қаралды 16 МЛН
Chain Game Strong ⛓️
00:21
Anwar Jibawi
Рет қаралды 41 МЛН
CppCon 2018: Jason Turner “Applied Best Practices”
1:03:19
CppCon 2015: Kate Gregory “Stop Teaching C"
1:00:11
CppCon
Рет қаралды 170 М.
CppCon 2018: Jason Turner “Surprises in Object Lifetime”
1:01:28
CppCon 2016: Jason Turner “Practical Performance Practices"
1:00:29