Cohesion and Coupling: Write BETTER PYTHON CODE Part 1

  Рет қаралды 216,089

ArjanCodes

ArjanCodes

Күн бұрын

Пікірлер: 388
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Learn more about how to launch a software product faster here: kzbin.info/www/bejne/g4aVYZSeathsrdk
@AlexB-op7kb
@AlexB-op7kb 3 жыл бұрын
Remind Me! 1 week
@javierfry97
@javierfry97 Жыл бұрын
@@AlexB-op7kb how goes it?
@AlexB-op7kb
@AlexB-op7kb Жыл бұрын
@@javierfry97 haha remind me 1 year. I forgot to follow up
@kannankalidasan
@kannankalidasan 3 жыл бұрын
Believe me. There are no videos on youtube other than you to my knowledge that explain the design pattern before and after effect with real practice examples . Thank you so much !
@ArjanCodes
@ArjanCodes 3 жыл бұрын
You're welcome Kannan, happy that you're enjoying the videos!
@muyewahqomeyour7206
@muyewahqomeyour7206 3 жыл бұрын
I third this
@ZeonLP
@ZeonLP 3 жыл бұрын
True! I have only seen very abstract examples that almost completely overlap with the pattern description. Not bad, but real world examples are much more insightful once you get the general idea.
@MaBuSt
@MaBuSt 3 жыл бұрын
have you found any more? This is also exactly what I was looking for. I am concerned his newer stuff is a bit more faster-paced, but still good. I know we can slow the videos down, but this isn't about teaching us 'what to do', this level is all about 'how to think' is this video is a really really great example of this. Looking for more samples around the web if you found them
@andgatehub
@andgatehub 10 ай бұрын
aws re:invent has some really good videos on software development, way beyond this. However, arjan’s video is great if you’re still at the level where you need practical examples.
@DaviSilveira
@DaviSilveira 3 жыл бұрын
Thank you for not making 'hello world' tutorials!!!!!!! Keep going! :)
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thank you! Will do :)
@jsallan7
@jsallan7 3 жыл бұрын
Agreed! Thank you Arjan, this is super helpful stuff!!
@ShanilPanara
@ShanilPanara 3 жыл бұрын
Honestly, this is some of, if not the best, intermediate/advanced level content out there! Too many people focussing on the pure basics, but you presented this in such an easy to understand way! Forget binging Netflix, time to binge Arjan 😂 Thanks a lot ❤️
@mrdupreez9061
@mrdupreez9061 3 жыл бұрын
This is exactly the sort of level of information I need at my stage of learning to code. thank you so much really appreciate the thought you've put into this!
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thank you! Happy that you enjoy the videos.
@larrytroxler7017
@larrytroxler7017 3 жыл бұрын
I'm glad you got something out of this , but read my post.
@mrdupreez9061
@mrdupreez9061 3 жыл бұрын
@@larrytroxler7017 Can't see your latest comments, so I can't unfortunately. Why don't you make your own video?
@MaBuSt
@MaBuSt 3 жыл бұрын
were you able to find any other examples of this level of code teaching? This is where I landed too.
@talhaamir9023
@talhaamir9023 3 жыл бұрын
Highly Underrated Video, should have more than a million views. There are very important concepts which programmers don't even know. Thanks for the High Quality Content !!
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thank you Talha, I’m happy you’re enjoying the videos!
@larrytroxler7017
@larrytroxler7017 3 жыл бұрын
True, but as a explained in my initial reply, there are some problems with this guy's post.
@Dgrayfit
@Dgrayfit 3 жыл бұрын
I absolutely love this channel. I have always really struggled with the idea of trying to identify what "intermediate" level coding is, and I would say this channel really fills that gap in the existing KZbin literature for python coding. I think this channel is going to really level up my skills, can't wait to see more!
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thanks Dennis, I’m glad you’re enjoying the videos and that they’re helpful to you.
@Dgrayfit
@Dgrayfit 3 жыл бұрын
@@ArjanCodes Certainly very helpful! Do you have any other ideas in the pipeline for content that we can look forward to?
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Absolutely :).
@MaBuSt
@MaBuSt 3 жыл бұрын
did you find any other channels that are similar? I did not but I am also looking to do much better here as well at this level.
@5thbatman
@5thbatman 3 жыл бұрын
It is not even possible to get this kind information from paid sources, but you are great person that making these kind of valuable lessons available on youtube. Thank you very much for all the effort, Respect.
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thank you, Space Walker - glad you like the content!
@hudabdulwahab2499
@hudabdulwahab2499 2 жыл бұрын
I was so frustrated of going through tonnes of leetcode interview exercises/tutorials and was looking for a more philosophical understanding of how to design python codes. Then I found your channel, I am now more confident after going through some if not all of your videos. Keep it up! The coding challenge is soon, will update if your content helped me land the job.
@marookegberosamuel
@marookegberosamuel 2 жыл бұрын
Did you land the Job yet ?
@hudabdulwahab2499
@hudabdulwahab2499 2 жыл бұрын
@@marookegberosamuel I did! but unfortunately (or fortunately) it's not just python - so a lot of learning curves!
@Ben-kz2km
@Ben-kz2km 2 жыл бұрын
Great video. I'm a data scientist but moving more and more to software development. I'm still having a hard time writing good code, but I'm starting to be able to recognize it when I see it. Videos like this are super helpful with that.
@CristianHeredia0
@CristianHeredia0 3 жыл бұрын
This is a such a great series! I've been looking for intermediate level design content for years. You've nailed the delivery and content. Looking forward to seeing more videos.
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thank you Cristian, happy you are enjoying the series!
@Victorinoeng
@Victorinoeng 3 жыл бұрын
Completely agree! Loving this series! Looking forward to more videos! Great job!!!
@olegpopov3180
@olegpopov3180 3 жыл бұрын
I noticed cohesion and coupling are pretty similar to the concept of between and within dispersion in cluster analysis. Kinda cluster should be maximized by between-cluster distance and minimize by within distance of elements inside. Why I noticed this only after your video? Your explanations are really genious.
@robharwood3538
@robharwood3538 3 жыл бұрын
Nice observation! It makes sense to me.
@kanwaradnan4849
@kanwaradnan4849 Жыл бұрын
Sir, you are really amazing teacher. Your teaching style is very explicit and clear. But there are several other parts of the programming world I would like to learn from you, and these are (mentioned based on my interests) 1) Data Structure and Algorithms 2) Programming along with any GUI Library (I prefer tkinter) 3) Also teach us about Databases (SQL , NoSql (mongoDb etc)) Thank you Sir, I hope, We'll be blessed with these videos in future.
@mrdbourke
@mrdbourke 2 жыл бұрын
Absolutely outstanding video Arjan! I've been coding Python for ~5 years and always saw these techniques in play but never really knew where they were coming from. Looking forward to the rest of the series.
@ArjanCodes
@ArjanCodes 2 жыл бұрын
Thank you so much, Daniel, glad you enjoyed it!
@ahmedlv5499
@ahmedlv5499 2 жыл бұрын
Your videos have changed the way I code. This is my second time going through this playlist. Since watching your videos I have been writing better code. Trying to do better every time. I have even done better at interviews. Thank you so much for great content. Merry Christmas and Happy New Year!
@mikaeilnorouzi5631
@mikaeilnorouzi5631 5 ай бұрын
I can even tell how much I love your content sir, thank you for creating these videos all for free, you are a hero.
@ArjanCodes
@ArjanCodes 5 ай бұрын
Thank you for the kind words, Mikaeil! I'm glad you like the videos :)
@omni4376
@omni4376 3 жыл бұрын
Fully agree. Basic concepts like this are highly undervalued by many devs since they struggle to grasp the rather abstract benefits. Unfortunatly todays high demand on devs also has lead to many people working in this field now who better should not be writing code for a living.
@NateROCKS112
@NateROCKS112 3 жыл бұрын
There are a few design things I feel like I'd change: 1. As others have mentioned, Vehicle and VehicleInfo would be good as dataclasses. 2. Using enums instead of a boolean "electric" flag. This would allow for adding more vehicle types in the future, such as "hybrid" or "diesel," if one needs to differentiate the two. 3. __str__() is much cleaner when printing stuff, rather than using a unique print() method. This is obviously a boon if, as you said, one wants to develop a GUI.
@kevinjerome5954
@kevinjerome5954 2 жыл бұрын
One interesting concept to add to this: We could define the string we print as the return value of the __str__ method of the class instead. Then in print method of the class put print(self). That way we can both print the str with a call to print or get the str as an output to write somewhere else with str(instance)
@janekschleicher9661
@janekschleicher9661 Жыл бұрын
Usually the way would be to overwrite both, the __str__ and __repr__ (the latter should contain a representation similar how we would reconstruct the object in python). __str__ overwriting should be done carefully and usually keep it as simple as possible. Most often, we would not want to have a formatted string containing arguable design decisions. Especially, having newlines in __str__ should always taken with some careness. If these objects are included in other objects, you'll start having problems visualizing them without getting corrupt visualizations. Just think about printing out a little table as one example. There are useful exceptions, e.g. pandas dataframes, so they work very well with interactive environments. Here I'd argue that __str__ should just contain the information a bit more minimal in a one liner. Nowadays in recent python, we'd usually just define the data classes as dataclasses and then we'll automatical get a useful __str__ and __repr__ and __init, what reduces the need to even think and debate it. The usual way to deal with a pretty printing or a formatted output is to add a formatted_str or similar called function. One reason is also, that you want to influence the formatting with options (and you can't really do that in __str__). E.g. whether you want a colon there, or maybe you want output it as a csv (so you can pipe into a database). Indeed, very often, you could even think about delegating it to a specialized library like python-tabular or similar. Anyway, the only thing I really disliked in this video is to call the method "print". I would always suggest, especially to learners, not to use any keywords or global function names as function names. Even if it fits the purpose of the method very well, the chance for both confusion and hard to debug errors is significant. You can even see it in this video. There are three prints in three consecutive lines: the first is in a method name declaration, the 2nd one calls the global standard python print and the 3rd one calls the print method of another object. It's even worse that the three methods will do something similar. It's only a question of time till the wrong print is used, not caught immediately and the ending up in a subtle and close to impossible findable bug. I mean, you still can call print(vehicle) or vehicle.print() that both will do something similar, but different. Anyway, this video is outstanding good!
@michaelmichelotti460
@michaelmichelotti460 3 жыл бұрын
Fantastic series! I think all of the concepts you're discussing are vastly under-appreciated
@szabolcsjobbagy30
@szabolcsjobbagy30 10 ай бұрын
You create the Best videos on refactoring, design patterns, OOP, thank you a lot!! Most of the videos on youtube are very basic, with ridiculous, generic "foo", "add_numbers" etc. examples, but you show real, practical examples, and superb refactoring, just as if we asked a senior mentor to review our junior codes and recommend improvements. You are creating fantastic videos, thanks a lot!!
@pimdubuf3272
@pimdubuf3272 3 жыл бұрын
This series is great, both the topics and your way of explaining stuff. Thanks for taking the time to make these!
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thanks Pim, glad you like it!
@fuuman5
@fuuman5 3 жыл бұрын
You could use dataclasses to save a lot of boilerplate. And I like to implement __str__ methods to print objects. But I guess you left that out to make it not too complicated. Anyway nice videos. Good to watch.
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thank you! Yes - dataclasses are really helpful, as are the __str__ methods for printing. It's always a challenge to make sure the examples used to explain a concept do not introduce too many other 'new' things at the same time. I do think a video about these 'helper' libraries would be useful, as they really save you a lot of time.
@fuuman5
@fuuman5 3 жыл бұрын
Yeah, that's an important point. But you are doing great at finding the right mix which is shown by your amazing growth over the last month. Will definitly follow your upcoming videos - keep going!
@alvaro_ch
@alvaro_ch Жыл бұрын
I hate python but I watched the video anyways because nowadays almost nobody talks about cohesion and coupling. As you stated, the concepts shown apply to any language since they are abstract, language independent ones. Grats!
@DistortedV12
@DistortedV12 3 жыл бұрын
You are a god for uploading this series. Starting out as a python developer, I found myself coming across difficult issues when returning to old code I've written where better understanding of design patterns could've helped. The very few tutorials covering this stuff are either long form lectures, and the best books on software design use Java as a reference. This is such a great niche that you're tackling and I hope your account accrues more subscribers and viewers. Thank you!
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thank you so much - glad you like the content!
@raccoonteachesyou
@raccoonteachesyou 3 жыл бұрын
I just discovered your channel, I always found Design Patterns boring, but I watched almost all your videos about it. Thank you, you make it very playful and concrete and the rhythm is also perfect !
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thank you so much! I’m happy that you’re enjoying the videos.
@MaBuSt
@MaBuSt 3 жыл бұрын
Exactly the kind of content that so many are actually looking for!!! If we have developer jobs without great code-review and training practices, we are stuck trying to figure out how to improve our code quality by ourselves. This is appreciated 1000x. Something I'd please ask going forward, and the reason I am responding in THIS video instead of your others - please don't go TOO FAST in your videos. This video was a great speed and I am concerned that in some of the vids you have made since that you are moving too fast. Please remember that this isn't about 'how to do' something, it is about 'how to (structure your) thinking'. This takes time to settle into the brain and the programmers watching are constantly trying analyze the 'why' of what you are doing and fit it back into their own models. Please use this type of video pacing as an example in your newer videos. Also, please always debug on screen, we've all been there and it is really great to watch what you do too.
@GrooveMonkeeloops
@GrooveMonkeeloops 3 жыл бұрын
Great stuff, thank you!! I really appreciate this kind of intermediate+ material. There is very little available. Looking forward to the rest of the series.
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thanks! Happy you liked it!
@devkiwboy
@devkiwboy 8 ай бұрын
This is outstanding content, creatively and articulately presented. Bravo.
@ArjanCodes
@ArjanCodes 8 ай бұрын
I'm glad you enjoyed the video!
@vxsniffer
@vxsniffer 2 жыл бұрын
your work stands out in flood of basics tutorials with silly examples, thank you Arjan!
3 жыл бұрын
Thanks for this info series. It is nice to know the CS terms for some of the things I have learned from practical experience. In particular, a favourite of mine is to store the info and related methods in an Enum. In this case I would have defined `class Vehicle Registry(VehicleInfo, Enum)` and define the different type of vehicles as Enum members.
@larrytroxler7017
@larrytroxler7017 3 жыл бұрын
Exactly. You should never store classifications like these as bools. His final code would never pass a software review.
@Eriddoch
@Eriddoch 3 жыл бұрын
First person I've subscribed to in over a year. Great videos sir :D
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Welcome aboard!
@kubape84
@kubape84 Жыл бұрын
Thank you Arjan for sharing your knowledge in such easy and clear way, appreciate
@ArjanCodes
@ArjanCodes Жыл бұрын
Thanks so much Jakub, glad the content is helpful!
@stewpatterson1369
@stewpatterson1369 3 ай бұрын
great walkthrough. the example code really demonstrates the concepts
@AdobadoFantastico
@AdobadoFantastico 3 жыл бұрын
This really pulled the concepts together for me.
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Glad to hear it was helpful!
@hackergr325
@hackergr325 2 жыл бұрын
Words can't describe how awesome your job is. Watching your videos makes me want to refactor all my shitty code
@nijataliyev1470
@nijataliyev1470 3 жыл бұрын
Holy cow, this is first video that I am subscribing, liking and sharing right away. This is a gem. Thank you very much Arjan.
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thank you very much! I’m happy you liked the video.
@kcramo
@kcramo 3 жыл бұрын
Hallo Arjan. Dank voor je uitstekende uitleg zeer leerzaam ik ga de rest van de video's bekijken educatie moet vrij en toegankelijk zijn voor iedereen een kopje koffie komt zeker. Dank Khaled
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Graag gedaan, Khaled!
@thesupercoach
@thesupercoach 2 жыл бұрын
Love your work man. Your calm and clear delivery is a breath of fresh air. Keep it up.
@robertchang5096
@robertchang5096 2 жыл бұрын
Your videos are absolutely amazing! I can only imagine how much work and hours you have put into this. Thank you for sharing your knowledge to all of us learning Python!
@shreedaghatpande1878
@shreedaghatpande1878 3 жыл бұрын
As a senior dev in my team your sample code for bad example gave me a slight headache. But your explanation to all the changes made me way too happy. Thanks for the great content 👍. After completely watching the video this reminded me why people say good code doesn't need any mandane comments.
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thank you, glad you liked the example (at least the after part ;) ).
@plashless3406
@plashless3406 2 жыл бұрын
This is what I was looking for almost a year. Thanks, Arjian.
@denissipchenko2455
@denissipchenko2455 8 ай бұрын
Regarding naming convention and it's connection to your "Functions vs Classes" video... Functions = action_focused, Classes = StateFocused... I don't know, is it unwritten rule or just coincidence, but in your code: Classes are named like NounSomething (like VehicleRegistry, Noun = State) Functions are named like verb_something (like register_vehicle, verb = action) Nice! :)
@mannchuoyyam1509
@mannchuoyyam1509 2 жыл бұрын
Found it, watch it, love it. You're awesome!
@ArjanCodes
@ArjanCodes 2 жыл бұрын
Thank you, glad to hear you liked the video!
@wojwesoly
@wojwesoly 3 жыл бұрын
Great video, but @18:40, wouldn't it be better to write a __str__ method rather than creating our own print method?
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Probably that’s a better option indeed!
@EW-mb1ih
@EW-mb1ih 2 жыл бұрын
Great video! If we want to go further, we can create abstract class and give an object VehicleRegistry to the application and thus increase the decoupling We can also create another class to compute financial stuff like prices, taxes and even reduction and thus increase coupling.
@ayva1106
@ayva1106 2 жыл бұрын
20:26 Truer words have never been spoken 🙏🙏
@victoradukwu2719
@victoradukwu2719 5 ай бұрын
Great video. I wish I knew about your channel long before now. Thanks a million!
@ewilliamson9696
@ewilliamson9696 3 жыл бұрын
This is such a great series. Thanks so much!
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thank you Erik, happy you are enjoying it.
@alessandroferrari2166
@alessandroferrari2166 3 жыл бұрын
Great stuff Arjan! You got a new subscriber! Groetjes uit Den Haag!
@imadetheuniverse4fun
@imadetheuniverse4fun 2 жыл бұрын
8:00 this is excellent advice, just what I needed tbh. think about the data first before doing any coding, let the data and their relationships guide the program structure!
@goulartto5616
@goulartto5616 2 жыл бұрын
I'm so grateful to have found your channel. Very great content. Thank you very much! Cheers from Brazil!
@ArjanCodes
@ArjanCodes 2 жыл бұрын
Hi Goulartto, I'm happy to hear you like the content - cheers!
@ramirotell
@ramirotell 2 жыл бұрын
Im really happy to have found this channel, I'm really enjoying this Better Python Code playlist!, thank you!
@dasiqelder9018
@dasiqelder9018 3 жыл бұрын
Love it. It would be extremely more helpful to also explain the details of how Expert is used to produce these Lowly Coupled and Strongly Cohesive design. For example you mention that register_vehicle having to know about implementation details of another class is a "bad thing" and it would be better to add it to Vehicle_Registry.... and you explained why doing this would help clearly. But Larman also suggests that abstracting these patterns as much as possible is good, and so perhaps go into how you are assigning responsibility to the class that has the information to fulfill the responsibility. This is the solution Expert provides, as noted by Larman, and continuously using these terms to explain what you're doing is helpful.... Otherwise you'd have to look up the book and the read the chapter on GRASP to understand more deeply and not everyone is inclined to do so!
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Hi Dasiq, thanks for the feedback! That's an excellent suggestion - in this example, I wanted to focus on the cohesion and coupling concepts, but the other aspects of GRASP such as Information Expert are definitely useful to talk about as well. I might do another video in the future, where I talk specifically about this.
@alexgreenberg1709
@alexgreenberg1709 3 жыл бұрын
Good, just python has __repr__(), so implementing it you can do print(vehicle) instead of vehicle.print()
@nickfratto2439
@nickfratto2439 3 жыл бұрын
he was trying to showcase design principles as simply as possible, which is why he probably didn't do it this way. But... yes!
@NateROCKS112
@NateROCKS112 3 жыл бұрын
repr should provide all the information necessary to reconstruct the object. (Ideally, it's a string form that, when run through eval(), produces an equivalent object.) __str__() should be used for a "user-readable" format, e.g., for a print() statement.
@murghay01
@murghay01 3 жыл бұрын
Yes please. Can't even believe you made a reference to bridger and template pattern. Fantastic.
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thank you!
@benjamincabalona9014
@benjamincabalona9014 3 жыл бұрын
This video is underrated. Well done!
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thanks Benjamin, glad you liked it!
@bigutubefan2738
@bigutubefan2738 2 жыл бұрын
Great video! just a minor vocabulary pointer (business people have committed far worse sins): if you can't actually measure it, it's not a metric by definition. Cohesion and Coupling are heuristics. It's an esoteric word I'm trying to bring back!
@chuckles8519
@chuckles8519 2 жыл бұрын
I'm learning a lot from your videos - thanks.
@ArjanCodes
@ArjanCodes 2 жыл бұрын
Glad to hear the videos are helpful!
@drygordspellweaver8761
@drygordspellweaver8761 2 жыл бұрын
add_vehicle_info arguments should definitely be in VehicleInfo class as attributes instead of defined in the VehicleRegistry class. Then when you instantiate your vehicle and pass the brand, it automatically assigns those attributes.
@jcbrena
@jcbrena 3 жыл бұрын
Regarding 13:40, this is why I like Pycharm more. It will let you know if you haven’t used a parameter. I’m sure there’s something similar in VSCode but in Pycharm it’s on by default. Anyone one else agrees?
@darrellleong4780
@darrellleong4780 2 жыл бұрын
Arguably, add_vehicle_info should not fall under Vehicle Registry (which is supposed to only process new registrations) but under a separate module that posts to the vehicle_info database. It would also be convention to add _ infront of generate_vehicle_id and generate_vehicle_license to indicate private methods.
@cocoonkid4321
@cocoonkid4321 3 жыл бұрын
Well well done! You've got another fan here. I'm digging your videos.
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thank you @cocoonk1d! I’m glad you like the videos!
@MagnusAnand
@MagnusAnand 3 жыл бұрын
This series is gold
@swehba
@swehba 3 жыл бұрын
I am not familiar with declaring instance variables at the class level as you have done with brand, price, and electric in the VehicleInfo class. I assume that because you only specified a type and not a value these are instance variables and not class variables. Is that correct? If so, where is this pattern discussed in the Python docs? Many thanks and fantastic videos.
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Glad you like it, Steve. Initially, I was using dataclasses for this example which require you to declare instance variables at the class level, then removed that, and forgot to turn the class-level declarations into regular instance variables. In more recent videos, this has been fixed. For example of using dataclasses with this pattern, see this video: kzbin.info/www/bejne/rIO5h6yibtqUkMU.
@ahmetanbar6346
@ahmetanbar6346 2 жыл бұрын
At 24:24, the application class should have a init method that makes VehicleRegistry(). I think the VehicleRegistry() must not depends on register_vehicle method. If you register new vehicle, VehicleRegistry() method will also be run. So it is wrong, I think. Thanks for your good video.
@cetilly
@cetilly 3 жыл бұрын
What a really great topic that no one ever seems to discuss. And very well presented. New subscriber.
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thank you Chuck, happy you like it.
@janimakermeenmanhom4416
@janimakermeenmanhom4416 3 жыл бұрын
this is very perfect constringe of python code that I never have it's so amazing, it has more knowledgeable pattern design
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Glad it was helpful!
@chrisk8703
@chrisk8703 2 жыл бұрын
Thank you for the great video about cohesion and coupling, I can learn a lot from these videos about code structure design. One question about the types you added at minute 10:00 to the classes. When to use it that way compared to when using it directly in constructor e.g.: __init__(self, x: str)?
@mr_skumar_vlogs
@mr_skumar_vlogs 3 жыл бұрын
One of the best content. Thank you so much for sharing your knowledge. I am going to watch all of your other vedios. Please keep on the great work.
@aayush10001
@aayush10001 2 жыл бұрын
Hi Arjan, This video is immensely helpful, and I look forward to seeing the rest of the playlist! However, I am commenting because a coding practice you demonstrate is confusing to me. As I do not use Python day to day and don't come across the latest coding practices, I am trying to seek some clarity from you and other folks who are more proficient! In the Vehicle and VehicleInfo classes, you are defining variables that are class members, and later using them as object members (referencing via self). This is allowed in Python, but the issue is that self(dot)id = id statement for example would create an object member of the same name on the spot. This will shadow the class member id defined earlier whenever self(dot)id is accessed. As per my understanding, defining the variables in a C++ like style at the top has distinctly different semantics in Python than defining them in __init__ (class member vs. object member). From what I could make of it, the only defined class member at the top of the class that gets used is VehicleRegistry.vehicle_info dictionary, the rest are object members created in __init__ that shadowed the original class member definitions.
@khmsalhuas1
@khmsalhuas1 3 жыл бұрын
Great stuff! I like to think of a class as a bunch of cohesive tiny functions (either return one thing or has one side effect, rarely having both) that work on shared data or attributes. If the tiny functions have no shared data between them, write them in just normal functions. All the data/attributes should be defined in __init__ method or as class variables if they affect the class a whole rather than an instance (class variables are at the same indentation level as class methods). I refuse to add new attributes in any other method besides __init__. If I had to create a new attribute in a method so I can use it in another method, I could add that attribute in the __init__ method and default it to a reasonable value (None, 0, [], {}, "", etc.) so anyone reading my code can understand this class has these attributes/data and if they have default values, I know those attributes could be changed later if a method has been invoked.
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thank you! Separating declaration of data from usage of data wherever you can is an excellent best practice. It’s a pity Python doesn’t enforce this like most other object-oriented languages. As a developer, you need to be able to easily understand what the structure is of the data in a class, otherwise, what is the benefit of using a class in the first place?
@khmsalhuas1
@khmsalhuas1 3 жыл бұрын
@@ArjanCodes yeah that’s true. There is a way around it by inherently from typing.NamedTuple or using the __slot__ class variable. But that is extra work. Adding attributes dynamically could have its merits in GUI classes like PyQt5 but it confuses me when reading someone’s else code. Even when i do GUI classes and the attributes have not been created yet until a signal is emitted, I still define them in the __init__ method and default it to None. I know the code will be verbose but the intention of what I am doing is clear to my future me and future reviewers I hope. Speaking of GUI, i dislike putting my widget data/attributes in a method called setupIU and calling that method within the __init__ method. I could put all the UI data and other data in the init method and separate them by empty lines or comments.
@dariuszspiewak5624
@dariuszspiewak5624 2 жыл бұрын
Hi there. Arjan, a question. You use a print method in the 2 classes, Vehicle and VehicleInfo. This, of course, limits the printing capabilities to the standard output (not saying you can't repoint the builtin print method to some other function but let's say you don't want to do it this way). What would you do if you wanted to be able to print to other devices? How would you implement this? Would you create a field in both of these objects that would be assigned a Printer object so that the print method could use it, or would you pass objects to a Printer to print info from them? In other words, would you inject a printer into the 2 objects or would you inject the 2 objects into a printer device? What's the guidance on how to properly structure this? What's the SOLID rule that would help me decide?
@MagnusAnand
@MagnusAnand Жыл бұрын
Great video Arjan. One question: 1. def create_vehicle(): return Vehicle(id, license_plate, self.vehicle_info[brand]) 2. def add_vehicle_info(self, brand, electric, catalogue_price): self.vehicle_info[brand] = VehicleInfo(brand, electric, catalogue_price) Aren't this classes/methods too coupled with Vehicle and VehicleInfo? Thanks 😜😜
@amardeep.sahota
@amardeep.sahota 2 жыл бұрын
This is some really good quality video. You covered so many concepts , thanks
@das_papa4873
@das_papa4873 2 жыл бұрын
Excellent video. Thank you very much for this serie.
@ArjanCodes
@ArjanCodes 2 жыл бұрын
Thanks so much Das.
@triple-oe4hw
@triple-oe4hw 3 жыл бұрын
Thanks man really wished I'd learned this sooner
@bennykopilov2819
@bennykopilov2819 2 жыл бұрын
Wow , this is something different , there are tons tutorials but you are good ! keep doing . Looking for descriptors and design patterns lecutres, any idea ?
@cooliospeep7047
@cooliospeep7047 2 жыл бұрын
Dear Arjan, thank you for sharing such a detailed and thoughtful video. I loved how you explain the though process of improvement. It's hard to find such content out there. Please keep going. I look forward to studying all of your catalogue (see what I did there!) ;)
@LookNumber9
@LookNumber9 3 жыл бұрын
I love seeing beautiful code. Thank you for this!
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thanks Mark, glad you liked it!
@larrytroxler7017
@larrytroxler7017 3 жыл бұрын
It is not beautiful code, unfortunately. See me latest comment.
@ljaimovich
@ljaimovich 2 жыл бұрын
Good channel with very very good content!! Keep sharing your knowledge like this Arjan!!! Thanks so much!!!
@ArjanCodes
@ArjanCodes 2 жыл бұрын
Thank you Leonardo, glad you like the content!
@connorkenway1941
@connorkenway1941 2 жыл бұрын
Immensely helpful and well explained! Thank you so much...looking forward for more 😃
@ArjanCodes
@ArjanCodes 2 жыл бұрын
Thanks so much Connor, glad the content is helpful!
@galenseilis5971
@galenseilis5971 2 жыл бұрын
I like the gist of the concepts of cohesion and coupling, however they're not really 'metrics' until you find a way of (at least operationally) measuring them. How would you quantify these notions?
@esmondong9198
@esmondong9198 3 жыл бұрын
Great series with many valuable insights!! Could you elaborate the different types of couplings and cohesions happening in the code? But nonetheless the video was fantastic.
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Glad you liked it, James. I’ll definitely revisit cohesion and coupling again soon, and then I’ll also talk about the different types.
@MPatrickN
@MPatrickN 3 жыл бұрын
Easiest sub of my life.
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thank you! And welcome onboard ;).
@Megosks
@Megosks 3 жыл бұрын
I think you should start looking more into shortcuts :D Like copy line to bottom and multi-line caret
@wilhelmngoma9009
@wilhelmngoma9009 3 жыл бұрын
Very challenging, yet very interesting, and great to learn and understand. Thanks
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Glad you enjoyed it!
@houterm
@houterm 2 жыл бұрын
What is the reasoning behind specificying types to the class attributes line 5`brand: str` VS to the instance attributes `__init__(self, brand: str, ...)`. When should you do which?
@fabhi
@fabhi 2 жыл бұрын
Arjan, one small request : Can you make a video on how to structure a python project, or package? Regarding your question, one badly designed library is the collections package in python.
@lorieannecastillano3052
@lorieannecastillano3052 2 жыл бұрын
Super thankful of this content!
@JohnDoe-ch7bo
@JohnDoe-ch7bo 3 жыл бұрын
I really enjoyed this video to the point I had to go back and try to refactor some of my project. The issue I'm having is trying to refactor my database models. Could you make a video refactoring code for a database related project?
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thanks, great suggestion!
@JohnDoe-ch7bo
@JohnDoe-ch7bo 3 жыл бұрын
@@ArjanCodes thank you for your awesome videos, I look forward to learning more with you
@MaBuSt
@MaBuSt 3 жыл бұрын
When you do this, please go as slow and 'simple' as we did in this type of example. This video is perfect in many ways. It is a bit slower, more of 'figuring it out as we go' type of feel then the newer material. If the material goes too quick or is too refined, it won't help the intermediate level programmer as much since we are all here trying to learn how to think, not how to do. Thank you for making these videos!!
@iandthopper
@iandthopper Жыл бұрын
Thank you, Arjan. Superb content.
@ArjanCodes
@ArjanCodes Жыл бұрын
Thanks so much Ian, glad the content is helpful!
@andreacazzaniga8488
@andreacazzaniga8488 3 жыл бұрын
Also a video on how to avoid circular imports. Am i doing smtg wrong when it happens?
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thank you for the suggestion!
@andreacazzaniga8488
@andreacazzaniga8488 3 жыл бұрын
@@ArjanCodes I just figured out the main point: you can solve elegantly circular imports by making use of abstract classes and using these for the dep. injection when defining classes that need to know about each other beforehand. The sloppy solution is to delay the import of, say instance B, in the method of instance A that actually use instance B. works the same way, probably the most common solution but it leaves a lot more to the coder to debug and all the rest. If you want a descritpion of the program, just ask me. btw tried to use discord but says I am not allowed to post messages int chats. thanks for reading, cheers!
@robharwood3538
@robharwood3538 3 жыл бұрын
@@andreacazzaniga8488 Yes, the concept of Dependency Inversion is one of the biggest design/architecture patterns that 'blew my mind' 🤯 when I first learned about it and finally understood it. When I put it into practice on my project at the time, it really improved the overall structure, and when done consistently it pretty much eliminates the problem of circular imports. BTW: Just to be clear, Dependency Inversion is different (more abstract) than Dependency Injection. You can do Dependency Inversion without necessarily doing Dependency Injection. I understand Dependency Injection is also very powerful, but in my case it would have been much more complicated than just reorganizing some classes, introducing a few interfaces/abstract-classes, and modifying the 'direction' of which 'modules' import from other 'modules'.
@andreacazzaniga8488
@andreacazzaniga8488 3 жыл бұрын
@@robharwood3538 yes maybe I meant dependency inversion I am still not clear with which one one is which, but yes, you got the point!
@RazmikPoghosyan
@RazmikPoghosyan 2 жыл бұрын
Thanks for a tutorial. It's really very useful and unique.
@uguree
@uguree 3 жыл бұрын
Perfect, really very very strong nice clear explanation thank you One little thing could be added as extra, argument parser so we can call the scrpt with --vehicle bmw or ,--vehicle tesla etc You showing how to consider writing/ refactoring our codes perfect, Thanks a lot
@TheFaltajan
@TheFaltajan 3 жыл бұрын
Great series! Thanks so much. Could you also touch the topic about Python and DI container?
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thank you Jan, I’m happy you’re enjoying the series. Thank you for the suggestion, I’ll keep it in mind for one of my next videos!
@hbar45
@hbar45 3 жыл бұрын
If I'm understanding this correctly, cohesion and decoupling can be closely achieved in general by convenient grouping of information, such that methods that operate on that information can be colocated in the same class? I have many questions, but I'm in luck, as this is only the first video in this wonderful series. Keep it up!
@GuRuGeorge03
@GuRuGeorge03 3 жыл бұрын
It's really cool that you used composition and not inheritance!
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Thanks! Yes, I'm a big fan of composition over inheritance (you may have noticed that in some of my other videos 😉).
@robertbrummayer4908
@robertbrummayer4908 3 жыл бұрын
Hi Arjan, thank you for your great video series. I have some comments: 1) You talk about low cohesion of a single function, however cohesion is usually a concept defined on the module/class level: en.wikipedia.org/wiki/Cohesion_%28computer_science%29. High cohesion means the methods and data of a class work well together to fulfill the (hopefullfy single) responsibility of the class. The problem of your function is rather that it does too many things and has too many responsibilites, however the problem is not low cohesion since this is a concept on the module/class level. 2) Enums instead of string constants such as "BMW 5" would greatly improve the example. 3) Enabling pylint in VS code would help you to find typos much earlier. 4) I recommend to use "is_electric" instead of "electric" as a name to improve readability. The name "is_electric" clearly tells the reader that this is a boolean while "electric" is vague in comparison and does not sound boolean.
@ArjanCodes
@ArjanCodes 3 жыл бұрын
Hi Robert, thanks for your suggestions! About cohesion: I don't think this is as black-and-white as you state it. "module" can mean different things in different programming languages. On top of that, the distinction between a function and a class is not always that clear. For example, in Python you can define functions within a function. Shouldn't we be able to talk about cohesion of the outer function? If you use React for web development, you have functional components, which are functions with state. These functional components can get quite big and behave like classes, and we should be able to look at cohesion of a functional component even if it's not a class. So how I see cohesion is that a piece of code should have one main responsibility. The scope of that responsibility changes depending on the level at which you're operating (library, namespace, class, function/method).
@robertbrummayer4908
@robertbrummayer4908 3 жыл бұрын
​@@ArjanCodes Hi Arjan, thank you for your response. I see, you mean cohesion in a broader sense here. I am not a dogmatic person anyway :)
@andreacazzaniga8488
@andreacazzaniga8488 3 жыл бұрын
Python logging library does not allow different handlers to use different logging levels. Once you set the log level globally, all the handlers will stick to it no matter how you initialize them. I wanted to log to two differente files infos from two different logging levels. I gave up..
Dependency Inversion: Write BETTER PYTHON CODE Part 2
9:03
ArjanCodes
Рет қаралды 82 М.
7 Python Code Smells to AVOID at All Costs
22:10
ArjanCodes
Рет қаралды 372 М.
Ничего не делаю всё видео 😴
00:33
Miracle
Рет қаралды 693 М.
Clean Code is SLOW But REQUIRED? | Prime Reacts
28:22
ThePrimeTime
Рет қаралды 307 М.
Composition Is Better Than Inheritance in Python
23:29
ArjanCodes
Рет қаралды 259 М.
The Strategy Pattern: Write BETTER PYTHON CODE Part 3
15:31
ArjanCodes
Рет қаралды 112 М.
Naming Things in Code
7:25
CodeAesthetic
Рет қаралды 2,1 МЛН
Coupling and Cohesion Explained
11:43
Gui Ferreira
Рет қаралды 4,8 М.
Writing My Own Database From Scratch
42:00
Tony Saro
Рет қаралды 225 М.
25 nooby Python habits you need to ditch
9:12
mCoding
Рет қаралды 1,8 МЛН
How principled coders outperform the competition
11:11
Coderized
Рет қаралды 1,7 МЛН
All Rust string types explained
22:13
Let's Get Rusty
Рет қаралды 172 М.
The Ultimate Guide to Writing Functions
24:31
ArjanCodes
Рет қаралды 182 М.
Ничего не делаю всё видео 😴
00:33
Miracle
Рет қаралды 693 М.