The S.O.L.I.D. Principles of OO & Agile Design - Uncle Bob Martin

Ғылым және технология

No copies of this video may be made and shared. This video belongs to David Schinkel.
READ FIRST:
This video is more valuable that just "another SOLID talk".
This talk is still very entertaining and informative so sit back, relax, and enjoy! Sometimes it's good for us to learn and understand the past, so that we do not make the same mistakes that have been made over and over again in this profession.
If you want a more in-depth training on it, UB has that on his CleanCoders.com site. Very good vids there...very in depth on coding techniques and he codes a lot there.
www.CleanCoders.com - ton of vids by UB, very in depth technically
www.WeDoTDD.com/interviews/com...
/ unclebobmartin
blog.cleancoder.com
blog.8thlight.com/uncle-bob/a...
Source:
This presentation was given by Uncle Bob on Feb 4, 2015 at the Arlington Lakes Golf Club in Arlington Heights, IL.
Schaumburg Microsoft .NET Technologies Meetup bit.ly/1hAO2ln
Be sure to change the video to 1080p when watching it
Recorded with my IPhone 6+ 1080p (60fps)
Side Note:
UB talks little about SR and DI toward the end, but it's more a talk around business and more top level tech talk around around decoupling code and history of coding (where the idea of decoupling stemmed from, how objects came into existence and why, and how programming languages were affected by it ended up providing polymorphism... and a lot of other interesting things around the importance of plug-in software....all indirectly related to the topic of SOLID itself as a whole.
The S.O.L.I.D. Principles of OO and Agile Design
What happens to software? Why does is rot over time? How does an Agile Development team prevent this rot, and prevent good designs from becoming legacy code? How can we be sure our designs are good in the first place? This talk presents the agile S.O.L.I.D. principles for designing object oriented class structures. These principles govern the structure and inter dependencies between classes in large object oriented systems.
The principles include: The Open Closed Principle, The Liskov Substitution Principle, and the Dependency Inversion Principle, among others.
About "Uncle Bob" Martin:
Robert C. Martin has been a software professional since 1970. In the last 35 years, he has worked in various capacities on literally hundreds of software projects. He has authored "landmark" books on Agile Programming, Extreme Programming, UML, Object-Oriented Programming, and C++ Programming. He has published dozens of articles in various trade journals. Today, He is one of the software industry's leading authorities on Agile software development and is a regular speaker at international conferences and trade shows. He is a former editor of the C++ Report and currently writes a monthly Craftsman column for Software Development magazine. software craftsmanship

Пікірлер: 86

  • @tddtv
    @tddtv Жыл бұрын

    Hey All: I just started TDD TV. TDD Practitioners apply SOLID principles and all sorts of other practices like Clean Code, etc when we practice TDD. SUBSCRIBE & hit the BELL to Learn! Many videos to come! (Also check out WeDoTDD.com!) 👾📺👾📺👾📺👾📺👾📺👾📺👾📺👾📺👾📺👾📺👾📺👾📺👾📺👾📺👾📺

  • @camelcase9225
    @camelcase92255 жыл бұрын

    Before the talk starts: "Ok what crazy tangent is he going to start with this time?" Talk starts: "WHY DO WE HAVE A MOON?" Not disappointed lmao

  • @hasan0770816268
    @hasan07708162682 жыл бұрын

    notes to self: 29:00 polymorphism is why OO is so successful 47:00 a DLL is not a logical grouping of classes but a grouping of classes that you want loaded at runtime 49:00 single responsibility means design the class so it has a single reason to change or, to put it in another way, gather the things that change for the same reasons and separate the things that change for different reasons 56:00 the database exists to make accessing data from a disk easier for us, disks are disappearing and in the future we will have virtually infinite amount of persistent ram 59:00 open-closed: being able to change what the class does without changing its source code (you write new code but don't touch old code)

  • @znacly1184
    @znacly1184 Жыл бұрын

    Most I’ve learned from a single KZread video in a very long time! Thank you for posting this lecture!

  • @GrindThisGame
    @GrindThisGame5 жыл бұрын

    I could listen to him for hours.

  • @Nick-db1zp

    @Nick-db1zp

    2 жыл бұрын

    I have been, and I can tell you, it is worth it

  • @morantNO1

    @morantNO1

    2 жыл бұрын

    All talks of him I find on youtube are roughly the same though :(

  • @pastafarian3758

    @pastafarian3758

    2 жыл бұрын

    I do same

  • @devofshane4399
    @devofshane43997 жыл бұрын

    Gotta love Bob's little tangents he has before he starts his talks. It is really effective at getting the listener's engaged in the talk.

  • @honkderhase8724
    @honkderhase87242 жыл бұрын

    So cool to hear him talking about the "old" days and how thing were actually implemented... I started with C and C++ and still remember lots of this stuff.

  • @notdrone
    @notdrone7 жыл бұрын

    starts at 3:23

  • @dashenno

    @dashenno

    6 жыл бұрын

    Anecdote ends at 8:14

  • @binaryum

    @binaryum

    5 жыл бұрын

    doing god's work

  • @Gunth0r
    @Gunth0r6 жыл бұрын

    I'm starting to get why they call him "Uncle Bob". It's the crazy stories that make you think about the other more serious stuff he's saying. He oscillates wildly between foolishness and wisdom, which is the sign of a true teacher.

  • @ottorask7676

    @ottorask7676

    4 жыл бұрын

    I thought the name came from a co-worker who liked giving odd names to their colleagues.

  • @jodypipowski2376

    @jodypipowski2376

    2 жыл бұрын

    To me he is the Stephen King of code. Always on the edge of your seat.

  • @somebodyoncetoldme1704

    @somebodyoncetoldme1704

    2 жыл бұрын

    And the sign of a true uncle.

  • @stevehyles743
    @stevehyles7438 жыл бұрын

    A fascinating overview of the history of programming languages. After 50 mins two SOLID principals are introduced SRP and OCP but only surface deep.

  • @roeelcohen

    @roeelcohen

    4 жыл бұрын

    I haven't seen 1 lecture of him explaining the whole 5 principles

  • @ismailm123
    @ismailm1237 жыл бұрын

    I did clean code course with uncle bob and the tangent talks at start of each topic kept you focused also they were really interesting stories

  • @TheRaspPie
    @TheRaspPie8 жыл бұрын

    Wonderful insight into the history of OOP and what's it's really about. In fact, OO can be just an extension to some functional language or procedural one.. it has nothing to do with mutability or state at all.

  • @MartinJungblut
    @MartinJungblut7 жыл бұрын

    9:30 "We used to call it C++ for dummies."

  • @dannyknowlton
    @dannyknowlton2 жыл бұрын

    Uncle Bob is a national treasure.

  • @Paretozen
    @Paretozen8 жыл бұрын

    What a fun and engaging speaker! Thanks.

  • @GK-rl5du
    @GK-rl5du8 жыл бұрын

    Thanks for the upload, a really fascinating talk.

  • @javiermarchetti1520
    @javiermarchetti15208 жыл бұрын

    This guy is crazy, but I really like his videos

  • @adrianmotasilverio
    @adrianmotasilverio Жыл бұрын

    This guy is awesome.

  • @alexandersoltesz8103
    @alexandersoltesz81036 жыл бұрын

    this guy is golden

  • @yonathanhailemelekot5238
    @yonathanhailemelekot52382 жыл бұрын

    I love this man

  • @reyou7
    @reyou76 жыл бұрын

    Uncle Bob

  • @Atharvak1910
    @Atharvak19107 жыл бұрын

    So wait how do we fix the class he described in the Single responsibility principle example? Edit : Oh ok he talks about it at 1:05:00

  • @miikavihersaari3104
    @miikavihersaari3104 Жыл бұрын

    57:18 I don't think tables (arrays) are going away any time soon. It's true we don't have spinning disks anymore, but it still is much more efficient to read data that is contiguously laid out. Also, even though we'll have more memory in the future we'll still need to serialize our data. And lastly, computers aren't getting that much faster anymore. All capacities are still finite, and the idea that we don't need to care will (and has) lead to poor performance, and as such, poor software quality. In the end, programming is engineering, and engineering is about the physical reality. I don't think trying to 'escape the hardware' as an underlying principle and goal is a wise way forward. Abstractions aren't like math, because all abstractions are imperfect and each one comes with a complicated price tag. I absolutely agree with Bob on the point he makes about not "trusting" frameworks. The technical relationship is the wrong way around. Most websites have somehow missed this point, but then again web development is very broken.

  • @guybrushthreepwood2910
    @guybrushthreepwood2910 Жыл бұрын

    Great talk, as usual with Uncle Bob. Too bad he only made it to the "S.O." out of "S.O.L.I.D.".

  • @nathangrube2374

    @nathangrube2374

    Жыл бұрын

    Ha. Yes. I came here specifically hoping for I. and D. since in the previous talked I just watched, he only got through S.O.L. Someone should try to book him for a D.I.L.O.S. talk.

  • @jay6645
    @jay6645 Жыл бұрын

    At 20:05, Bob explains C had perfect encapsulation, and explains why C++ does not. He says, in C++, since the new operator needs to know the size of a class's object, it's definition therefore must be in a header file, hence losing encapsulation. My question is: Even in C, wouldn't you need to know the size of the structure you want to malloc?

  • @miikavihersaari3104

    @miikavihersaari3104

    Жыл бұрын

    That's a good question! I think he means the paradigm encouraged by C++, instead of what you can do with C++. In C, you'd often have a function that would do the malloc for you, and you'd be responsible for calling the corresponding clean up function once you were done. As long as you'd be operating with a pointer to the struct and pass that to the functions in the header, the compiler would allow you to do that. You can do this in C++ too, but I believe the point Bob is making is about going the C++ way, i.e. using classes and 'new'.

  • @williamdavidwallace3904
    @williamdavidwallace39047 жыл бұрын

    You say that Sun was the first to realize that winning the hearts and minds of programmers. Way back in the 50s and 60s IBM figured it out too and gave universities huge discounts on systems. Unfortunately for IBM they forgot about it.

  • @luke11.35
    @luke11.357 жыл бұрын

    What IDE does he name at ~ 35:18? I can't make it out & I don't work with C#, NET, or Java.

  • @luke11.35

    @luke11.35

    7 жыл бұрын

    Many Thanks. 8)

  • @TJ-hs1qm
    @TJ-hs1qmАй бұрын

    14:26 Algol: "Algorithmic Language" also a star and Arabic for Daemon (al ghoul)

  • @insertoyouroemail
    @insertoyouroemail4 жыл бұрын

    bob: "any good class couples data and behaviour" me: *triggered in haskell*

  • @abdulwahidgul
    @abdulwahidgul4 жыл бұрын

    8:15 where the actual talk starts

  • @RobertLeather
    @RobertLeather9 жыл бұрын

    I loved this video, but lets be honest... all those wonderful recollections meant we didn't actually cover the subject of the video.

  • @GireesanNamboothiriP

    @GireesanNamboothiriP

    8 жыл бұрын

    +Robert Leather I strongly disagree and I think you are missing the main point : AGILE. To design software systems in agile, Uncle Bob always suggests to think in the most loosely coupled ways of structuring the program blocks. Starting with the business logic with no gui and no db, which can be tested in each iteration, you will add your gui and db as dynamically "pluggable" modules. Most funniest-perfect way to tell the programmers that they should think beyond the injected and repeated keywords "inheritance, polymorphism etc and make things loosely coupled.

  • @GireesanNamboothiriP

    @GireesanNamboothiriP

    8 жыл бұрын

    +Dave Schinkel Really appreciate your team effort to improve the coding and having such great sessions, which we could watch on-line. I started following Uncle Bob right when I found them from NDC at Vimeo. Since then, kept on watching such videos, then further debates and hangout sessions from David (DHH) , Beck and Martin. Started practicing it throughout my codings, refactoring (using Boy's scout rule) and in an year, the program I wrote became complex; yet well maintainable. I could change my UI from native to web without cascading it to my logic, or change the database without cascading again. First time I really felt; "yeah! I did something good". What I missed is adding unit tests from the beginning; which I am trying to incorporate now. :-) . Problem again is the mindset from the management on spending that 30 seconds extra for unit tests and further the TDD :( Not yet there when marketing guys can just take the latest build and sell it when they want it, but I am striving to.

  • @Paretozen

    @Paretozen

    8 жыл бұрын

    +Dave Schinkel Absolutely Dave! I had a lovely day programming thanks to using TDD. All is covered, everything in the green, great tangible process. Now I have to stop working, but I don't want to.. so what better alternative than watching Uncle Bob :) I'll eat bread & water before dealing with fast, messy and untrustworthy code again!

  • @pafauk361
    @pafauk3612 жыл бұрын

    Doesn't PL/SQL have functions local to other functions?

  • @MrMasterKaio
    @MrMasterKaio5 жыл бұрын

    18:36 bob gettin angery

  • @rakeshmali1727
    @rakeshmali17272 жыл бұрын

    at 36:50 what did the guy say?

  • @umer.on.youtube
    @umer.on.youtube2 жыл бұрын

    Does he have a problem with C# ? Is there some passive-aggression in his tone? Not sure!

  • @playwtmk
    @playwtmk5 жыл бұрын

    does anyone have a link where he gets past o?

  • @tddtv

    @tddtv

    5 жыл бұрын

    CleanCoders.com

  • @gmoschwarz
    @gmoschwarz8 жыл бұрын

    The moon is made of the same material as the earth, except for the iron core of the earth, which comes from another body (the body of the size of Mars), but it couldn't belong to the solar system, because another sun must have produced it, the solar system either captured or it simply collided with earth.

  • @MrBct524
    @MrBct5249 жыл бұрын

    Sorry it's my audio device.

  • @sumertheory
    @sumertheory5 жыл бұрын

    did he mention objective c and jobs?

  • @comicsans1689

    @comicsans1689

    5 жыл бұрын

    Not in this talk, he mentioned Java and C# instead. In one of his other SOLID talks, he talked about Objective C and Steve Jobs.

  • @Frangles00
    @Frangles008 жыл бұрын

    Can someone explain joke from 36:50 to not native English speaker please?

  • @ryanfoothills6059

    @ryanfoothills6059

    7 жыл бұрын

    The comment made by the audience suggests that uninstalling Resharper(Jetbrains) from your Windows(Microsoft) computer is not easy, and that it's a headache(it's difficult and unpleasant) to uninstall.

  • @zainulabidin5554

    @zainulabidin5554

    7 жыл бұрын

    I think it implies that if user uninstall re-sharper Microsoft will be in trouble because v. studio won't be that effective without it. So Jetbrains do have a way to damage microsoft

  • @alejandro_hierro

    @alejandro_hierro

    4 жыл бұрын

    I think he says "have you ever tried to uninstall it?"

  • @uRamPlus

    @uRamPlus

    Жыл бұрын

    Because it’s sometimes even when you uninstall it, it won’t get completely uninstalled😂

  • @injSpasov
    @injSpasov Жыл бұрын

    😮

  • @videofountain
    @videofountain7 жыл бұрын

    SOLID at kzread.info/dash/bejne/pmxq2JWHZLLZmLQ.htmlm16s

  • 6 жыл бұрын

    What's the question in 1:08:35 ?

  • 6 жыл бұрын

    Dave Schinkel thanks! I got the second part of the question which is about dependency injection or inversion. Couldn't catch the first part that was answered with the rect/square example.

  • 6 жыл бұрын

    Oh, FYI, just got what they are talking about by paying attention to Uncle Bob repeating the question. He says: "Should i touch briefly on LISKOV----- and Dependency Inversion?". Those are the L and the D from SOLID. That's why he talks about the rectangle/square example, and why square cannot inherit from rectangle. Basically the answer is: "both Rectangle and Square should inherit from SHAPE, to comply with the Liskov's substitution principle". A Square IS a Rectangle, and that's Uncle Bob's bait because Square doesn't BEHAVE as a rectangle. en.wikipedia.org/wiki/Liskov_substitution_principle

  • @AtanasovPetar
    @AtanasovPetar6 жыл бұрын

    A correction about similarities between Java and C#. While they are similar, some of the similarities are only on the surface. Yes, the syntax is the same but the implementation is different.

  • @mortenbork6249

    @mortenbork6249

    2 жыл бұрын

    This whole talk is about how to communicate with your code, to OTHER PROGRAMMERS. Your point is literally, that machines read 100101010101010 NOT code. So the point of this talk is -> How to write code a human can understand. And your correction is, to say, what was already said... You weren't paying attention my friend.

  • @ehabahmedyassen
    @ehabahmedyassen2 жыл бұрын

    It is the fifth not the 2nd or 3rd.

  • @karanbhatt9320
    @karanbhatt9320 Жыл бұрын

    Uncle Bob entere 3:20

  • @MrPDTaylor
    @MrPDTaylor Жыл бұрын

    Don't get screwed by your GUI

  • @BenPearson_kd7uiy
    @BenPearson_kd7uiy7 жыл бұрын

    C# is Java done right;-)

  • @daanbouws1538

    @daanbouws1538

    6 жыл бұрын

    Microsoft products are not for programmers

  • @MrBct524
    @MrBct5249 жыл бұрын

    Three principles are covered nicely, but last two are not.

  • @_aullik

    @_aullik

    8 жыл бұрын

    naresh dhami its always the same, i cannot find a talk about everything

  • @behnamrasooli8801

    @behnamrasooli8801

    8 жыл бұрын

    +naresh dhami You can go to his own website and watch more videos like this. www.cleancoders.com

  • @behnamrasooli8801

    @behnamrasooli8801

    8 жыл бұрын

    I watched almost all of them and I highly recommend them. Although the Design Patterns section of it wasn't very helpful but the rest specially SOLID section was fantastic.

  • @mauriciorossi8477

    @mauriciorossi8477

    2 жыл бұрын

    He never really covers them because they arent as interesting and as insidious and subtle as the first 3 I feel. You can just read them from his book. For example DIP is simply to use an interface because high level (ie policy) modules shouldn't contain direct references (be dependent) on particular implementation. Its not much more nuanced than that. But the points he covers are way more nuanced.

  • @ayylmao1558
    @ayylmao15582 жыл бұрын

    Who else is doing ICT283?

  • @LetTheNewDayBegin
    @LetTheNewDayBegin2 жыл бұрын

    S.O.L.I.D. principles start at 49:18

  • @ninjedi6710
    @ninjedi67104 жыл бұрын

    OOP > FP

  • @HikarusVibrator

    @HikarusVibrator

    Ай бұрын

    You haven’t done FP have you. And if you did it was a JVM based language wasn’t it.

  • @ninjedi6710

    @ninjedi6710

    Ай бұрын

    @@HikarusVibrator I work with react. FP is my daily life.

  • @ninjedi6710

    @ninjedi6710

    Ай бұрын

    @@HikarusVibrator and python for backend

Келесі