I love how some of the patterns are "wtf is that monstrosity" while others are "oh, that's a pattern? I thought that's basic doing things".
@hoi-polloi1863 Жыл бұрын
That's how the whole "patterns" thing started... a bunch of 4 guys were just trying to codify good ideas they'd seen so they could share them around. Things then... well. Things got a little out of hand. MyClassFactory myClassFactory = new MyClassFactory(); MyClass myClass = myClassFactory.create(); BWA HA HAH AHA HAHAH AHAH AHAAA
@Lisekplhehe7 ай бұрын
I remember being asked which patter is a smart pointer in c++. I listed 3, before they told me it was a proxy and i was like yeah, i guess, but who cares?
@aameen9513 ай бұрын
Exactly, for example Singleton is simply a fancy name for a global variable!
@Lambda.Function Жыл бұрын
Interestingly there are also functional programming patterns. I've got the full list here: 1. Functions
@tablettablete1869 ай бұрын
I have been studying design pattern for some exams and this is just GOLD! Thank you for the laugh!😂
@johnmitchellvillanueva9 ай бұрын
That is all you need
@sameeranadgaonkar97569 ай бұрын
Lol, I'm studying design patterns after studying some functional programming and this is what I just realised. Strategy pattern == first class functions, visitor pattern == pattern matching!
Completely ignoring how functions can get other functions as an input, or even self-invoke them.
@ericm97 Жыл бұрын
Reasons I find these react type videos to be among the top best things to be happening to my career: 1) I find out amazingly informative tech KZbinrs from the original videos 2) Primes constant interjections is basically 100x-ing the information 3) He’s so f*in funny. 4) This kind of gold only seems to flow from highly technical senior engineers in the creamy layer of companies Thanks prime, continue to make these !
@heavenstone3503 Жыл бұрын
Couldn't agree more !
@lookingjust987654321 Жыл бұрын
No offense to prime, and he's about as good an engineer as it gets. People that write business apps adopt the OO things because its useful in that context. engineering for large scale isn't the right context. I know people making $300k a year building salesforce apps, and $300k a year building large scale streaming systems. Context.
@jglaab Жыл бұрын
Constructive criticism: "Creamy Layer of companies" makes me uncomfortable 🥴
@TacoMaster07 Жыл бұрын
Reason # 5) You have brain damage.
@Oi-mj6dv Жыл бұрын
Agreed
@LogicEu Жыл бұрын
So many religions in software nowadays
@iritesh Жыл бұрын
It's kinda weird ngl
@iritesh Жыл бұрын
Even IRL religions don't make sense, let alone software religions
@BboyKeny Жыл бұрын
Yeah, only religion that's valid it HolyC and TempleOS
The pattern of choice at my job: The Spaghetti Pattern
@highlanderdante Жыл бұрын
are we going to just ignore the fact that he's using camelCase on Python?
@tablettablete186 Жыл бұрын
@Chase Miller snake_case >>>>> everything else
@judewaide8328 Жыл бұрын
@@tablettablete186 camel case is the only way
@tablettablete186 Жыл бұрын
@@judewaide8328 oBjEcTivALy WRONG!!! 😤 (I wanna where this goes 😅😅😅)
@judewaide8328 Жыл бұрын
@@tablettablete186 lol
@jamesgood7894 Жыл бұрын
@@tablettablete186 snake_case gang
@icemojo Жыл бұрын
8:08 Well, as an avid Python programmer, I can vouch that while using decorators feels pretty nice (most of the time), writing them is an absolute mind numbing experience.
@ShadowKestrel Жыл бұрын
same goes for rust macros: I love when they are provided but now I am writing them my sanity is simply not here any more
@BboyKeny Жыл бұрын
@@ShadowKestrel I'm doing the proc_macro workshop and doing the derive(Builder) macro as my first 1 since yesterday. It's all fun and games, till I got to the optional-field part. I shudder at the realization that there are so many way to make a struct field optional and I would need to check all of them. I'm just starting out with it so there are without a doubt tons of pattern and tools to help with these kind of things that I don't know of. Although do think it's probably a very useful tool to have in my arsenal and way more powerful than macro_rules.
@ThatOpinionIsWrong Жыл бұрын
Me: "How does decorator work behind the scenes?" Senior dev: "It just works"
@greglocker2124 Жыл бұрын
@@ThatOpinionIsWrong with a smile on its face, that's how!
@Maric18 Жыл бұрын
how a decorator works: you write a function that takes in a function and gives back the "same" function plus you can do code on the side def print_instead(func): return print will give you a decorate that replaces the decorated function with print :D
@maxteer2800 Жыл бұрын
I'm gonna take a shot every time you mention you work at Netflix
@ThePrimeTimeagen Жыл бұрын
should i call an ambulance?
@DryBones111 Жыл бұрын
I too love the strategy pattern. Higher order functions are the most beautiful way to do the strategy pattern. Functional programming is just the strategy pattern all the way down. I love the strategy pattern btw.
@iambilbobaggins1884 Жыл бұрын
Do you love the strategy pattern?
@Gamester1128 Жыл бұрын
@@iambilbobaggins1884 I think he loves the strategy pattern... Can he confirm?
@ericbwertz Жыл бұрын
@@Gamester1128 I, too, wish I knew how he felt about this, and where/if he works.
@Hytpu9 Жыл бұрын
i was a bit confused at the begining of your message - does he rly love the strategy pattern, but at the end I put aside my doubts - you DO LOVE STRATEGY PATTERN!
@vikingthedude Жыл бұрын
Bro. I think you love the strategy pattern
@cas97553 Жыл бұрын
It would be cool to go through examples of patterns in rust. I haven't looked at the code for serde but it seems to use interesting patterns such as adapters to support different serialization formats.
@onelastkiwi80412 ай бұрын
i really didnt know that prime worked at netflix, im glad he mentioned it 10 times
@PasiFourmyle Жыл бұрын
KZbin REALLY wanted me to watch this, popping up on my end screens and recommended list for like 2 weeks now. I finally watched it..... sadly I'm not far enough on my coding journey to have learned anything or understood what was going on other than the great Prime jokes🤣
@purdysanchez2 ай бұрын
Builder and factory are just semantic variations on a constructor. Builder just turns parameter assignments into individual functions that can be chained together.
@axelfoley133 Жыл бұрын
Video: Screw too small for the hole. Primeagen: We've all felt this... Me: I thought the idea was you couldn't feel it.
@TehKarmalizer Жыл бұрын
You know what you should feel by knowing what you don’t feel.
@Santa19369 ай бұрын
Some of the patterns are so ubiquitous that you almost don't need to know them. Like I don't need to know that air is called air because I just breathe it naturally
@mattwilliams1844 Жыл бұрын
Singletons are really nice for hardware abstractions in embedded systems. For example I only want one instance of my keyboard structure, not 2 or 20.
@potaetoupotautoe7939 Жыл бұрын
I actually want 20, one for japanese , English and macro all in 1 keyboard
@mechantl0up Жыл бұрын
I use the builder pattern for all my JS Web Components. I am surprised people are surprised at returning this. It works nicely with a functional style, too, with a builder class whose final commit returns a DOM node and other methods return this. The web component then basically builds as one function call that when returned returns the ready component. You may get away with using not a single if else for a full and fully parametrised component with ES6 if returning this from each build method except commit. Listeners and any other features are just properties inserted with the builder as each sub component is described by joining build calls with the dot notation. The build tree will thus extrapolate to any complexity, as a component can always comprise any of the builds, which can comprise any builds, and so on, till the call stack returns to the top level and a full HTML component with any child components is returned, and is inserted in the DOM with the final commit. In theory, the whole web page could be built thusly. Prettier than some React stuff I have seen.
@khhnator Жыл бұрын
the idea of patterns is great. how people found patterns and tried to put everything in a pattern shaped hole was not. specially when "patterns" became some sort of bizarre synonym of OOP
@avwie132 Жыл бұрын
When someone confused patterns with OOP and confused OOP with classes it is quite difficult to take them seriously
@ethanwasme4307 Жыл бұрын
@@avwie132i don't program, they come off pretentious at the least 😢
@spittylama5 ай бұрын
Why do you think that happened? My suspicion is that most Modeling languages focus on OOP.
@cerulity32k3 ай бұрын
Builder is my favourite. You can omit and add whatever you want, the depth and detail that you ask of the struct is (USUALLY) directly paired with the amount of chaining you do. You can go with defaults, specify a few parameters, add more if you need to, or you can do the equivalent of in-place initialisation (which although it may not be as performant unorganized unoptimised, compilers might recognise the simplicity of the chained functions and would be able to evaluate the code into an object literal).
@sealer1675 Жыл бұрын
14:00 I don't think you're supposed to raise exceptions on regular functionality (reaching the end of the list)
@doomguy6296 Жыл бұрын
Python decorators are the best. They are the easiest form I saw for metaprogramming. It is really easy to read and understand the logic behind them
@fedeanastasis7040 Жыл бұрын
I'm just about to suggest in my project to start using a Factory for a single reason. We have 5 different classes that create the same object using a builder BUT it isn't clear how many fields of that class have to be set up(spoiler all of its parameters so always the complete builder). To isolate in a single place how the creation of that object has to be, enforce validations and ensure one of the fields that is a map is always created correctly depending on 1 of those 5 usecases. If not we will snowball into having distribuited the creation logic across multiple places
@CottidaeSEA Жыл бұрын
And *that* is what factories are made for. To unify and hide away complexity from the developer who shouldn't have to worry about that stuff, and you still need to have some unified way to create everything. Oh, and I dislike factories (honestly not too keen of builders either) so I have every reason to absolutely shit on them. It's just that in some cases they actually do make sense. They are simply abused to infinity and beyond.
@NihongoWakannai Жыл бұрын
@@CottidaeSEA i feel like this how it goes for a lot of patterns. We hate them because of how they get misused, but by god they are very useful in their actual niche.
@wadecodez Жыл бұрын
don't use a builder or factory if instantiation params are wonky/unknown. you should consider writing a context object. then any methods/classes that have the wonky/painful params pull from a single source. you'll see this a lot in JS when working with large libraries. There will usually be a single settings object which describes how the library should behave. The key to keeping settings objects maintainable is making them immutable. Once you allow mutations to settings, you are no longer passing around context, you are passing around state. immutable context is predictable state is not.
@CottidaeSEA Жыл бұрын
@@NihongoWakannai Yeah, I feel like that also translates to OOP getting a lot of undeserved hate.
@CottidaeSEA Жыл бұрын
@@wadecodez Doesn't that pattern also use a factory? I've never seen it without a factory at least.
@holthuizenoemoet591 Жыл бұрын
the arch user strategy pattern sounds interesting
@first-thoughtgiver-of-will2456 Жыл бұрын
Iterators in java: sugar Iterators in Rust: honey Iterators in python: 8 year old stevia packet
@TechBuddy_ Жыл бұрын
I don't know why but I crave more of these 💓💓
@tech3425 Жыл бұрын
That casual "when I was at Google" also got me going "weird place to flex, bud" 😂
@ProjSHiNKiROU Жыл бұрын
Peak of OO culture: Implementing Strategy and Visitor patterns (I still can't implement the visitor pattern without looking it up). Peak of FP culture: Monad transformers
@wlockuz4467 Жыл бұрын
I still don't know wtf is a monad.
@stdprocedure Жыл бұрын
@@wlockuz4467 SIMPLIFIED: it's a "wrapper", which takes closures/functions/lambdas which modifies the internal data (aka map function) It also needs a "pure/unit/wrap" function and also a bind/flatmap function. *Example without monads:* let person = Person { name: "John" }; function print_name(person: Person) { if person != null { if person.name != null { print(person.name) } } } print_name(person); *Example with a monad (Option):* let person = Person { name: "John" }; function print_name(person: Option) { person.map(p -> p.name).map(name -> print(name)); } print_name(person);
@adambickford8720 Жыл бұрын
@@wlockuz4467 Instead of getting the data and applying your code to it (like a loop), you pass your code to the monad an IT will apply your code to the data. You just don't exactly know if, how or when cuz abstraction, which is the entire point. For example, in an Option/Maybe/Try monad your code will only be applied to the data if it exists.
@aoeu256 Жыл бұрын
outside of Monad Transformers you have MTL, Lenses and for many types of programs instead of using MTL many people use Freer Monads/Extensible Effects. Also arrows
@T1Oracle Жыл бұрын
The only reason to use a factory is to hide the complexity of object creation. If a design pattern does not result in simpler code, then you are using the wrong design pattern.
@mattymerr70118 күн бұрын
All the patterns that seem simple and commonly used now show that these designs really were foundational.
@c4tubo Жыл бұрын
Common confusion: Observer is not Pub-Sub. Observers listen directly to their Observables/Subjects, so then each Observable/Subject must keep references to all of its Observers and become bound to their lifetimes. Publish-Subscribe adds one more level of indirection by having publishers and subscribers both depend directly upon a Channel between them; therefore they are tied to the lifetime of the channel rather than each other. Subscribers only become aware of publishers when notified with a message that provides the reference to the publisher if necessary.
@JJ-hb9in11 ай бұрын
“Patterns” is just something to grab if you don’t have lambda, the ultimate abstraction
@seans4290 Жыл бұрын
This is exploding my brain - ive had such a hard time listening to other peoples coding videos. Not this, im fully engaged. Thank you!
@josephp1263 Жыл бұрын
I love how straight to the point reactions Prime Reacts have
@hackmedia77553 ай бұрын
You could have a class called Food. It can be composed of an array of various ingredients and include a name variable.
@patrickshepherd13415 ай бұрын
Ngl... sometimes listening to the definitions of these named patterns,I feel like the next one is gonna be "and the Typing Pattern is where you press keys on the keyboard to put code in a computer!" "The Press Play Pattern is where you have to click a button to make your code run after it's written!"
@jogewe Жыл бұрын
I loved head first design patterns 🥰
@akshay-kumar-007 Жыл бұрын
The book is just so awesome. The way they teach design pattern by first introducing the problem and slowly building up the solution is great!
@Leto2ndAtreides Жыл бұрын
I usually think about the Facade pattern in terms of delineation between groups of developers, or major functions in an app... But one could just consider it a part of UX (or DX) → You make stuff easier to communicate, understand, and use. I wouldn't think of it normally as an endpoint though - unless you were explaining the endpoint with docs in a "This is all you need to know to do this" sense. But I think that perspective comes from seeing Facades as typically being a class with clear features, and not just any point that simplifies interactions between one system and other systems.
@mchisolm06 ай бұрын
Thanks for going over this. I feel like I must be missing something because I’ve watched this and Fireship’s video on it and feel like this doesn’t actually help me think about the way data can be structured or organized. I’m a high school teacher, so working on learning to relay the lessons to students in my CS classes. Thanks Prime. 😊
@spittylama5 ай бұрын
The main idea is to not reinvent the wheel every time a similar problem occurs. Back when the book came out, the idea was that software engineering was a relatively new discipline in comparison to e.g. engineering or architecture. So they started to look for standard solutions in patterns at the design or implementation stage of a project
@mchisolm05 ай бұрын
@@spittylama Thank you. I do understand that’s the *purpose*; I’m saying I can tell I still have yet to understand the content. I have been working on building projects with data, but I’m not sure I see the patterns, yet. I hope that makes sense.
@spittylama5 ай бұрын
@@mchisolm0 patterns with data are even more recent! So no worries with that. The well established patterns often have a OO design approach.
@mchisolm05 ай бұрын
@@spittylama do are you saying this is *not* about patterns with data? If so, I must have been really misunderstanding…
@AceofSpades5757 Жыл бұрын
Decorators are one of my favorite things about Python. They're so fantastic.
@banatibor83 Жыл бұрын
One of the most useless language feature :) They have very limited use if you do not want to end up with totally unreadable code.
@grantpeterson2524 Жыл бұрын
I used to dislike decorators, but I'm currently working in C# (which doesn't have them) and I keep running into instances where it would be really nice... I have a class that makes API calls asynchronously, but I need to limit the number of async calls being made at a time. So, I need to use a semaphore to force threads to await if all the other threads have used up the semaphore. Would be super nice to just use a decorator at the top of every method that makes an API call so that it wraps the execution with an await to the semaphore, but not an option for vanilla C#. I ended up creating another class called RequestExecutor that has methods that take lambda functions and do this instead, but it feels less clean.
@aoeu256 Жыл бұрын
@@banatibor83 If you think decorators are bad, what about the abstractfactory patterns here. They are used for black-box aspect oriented programming to simplify your code, and are in JavaScript as well.
@techsuvara8 ай бұрын
Reactive programming works a lot with Observer, Iterator and Strategy patterns. For some historical insight, it's called RX because Microsoft did a lot of work with something called Reactive eXtensions, hence it evolved to RXJava.
@StuartLoria Жыл бұрын
First video from this guy that I like
@kiffeeify Жыл бұрын
I think the Singleton pattern as just a special case of "execution contexts" where there is only one global context. It can simplify code by removing the need to explicitly pass down dependencies into the callstack. However, as with all static globals, it creates global coupling. staying with the python example from the video I would always rather use a construct as below instead of a singleton: ```python with some_context_of_type_y(): with some_context_of_type_x(): foo() def foo(): y = get_y_object() x = get_x_object() ``` IMHO it gives better composability on the outside scope and has the same advantages as singletons on the inside scope.
@ThomasZero288 Жыл бұрын
Yea there are very few scenarios to actually use this pattern once you have DI, in fact it only interferes with/breaks DI. The only two examples I can think where I would actually use it are A) a tiny app where I'm not going to include an IoC library or B) In the very initial boot of your app when the IoC container/AppContext is either half constructed or has not finished initializing and is in an unsafe/incomplete state, yet you still need access to critical components like a preInit logger. Cause if AppContext fails to initialize... and that's where you get your logger from... and you want to log the error... and it IoC fails to initialize.... so you want to log it... but it has the..... wait.. where was I? where am i? WHO ARE YOU PEOPLE???? Can someone call my mom, im scared
@MEZOMEZO20116 ай бұрын
What is the iterator pattern? 14:11 It's just a loop!
@hassan2868-u7q Жыл бұрын
Dr.disrespect of programming
@porky1118 Жыл бұрын
16:30 I recently had a similar problem. My solution was buying bigger screws.
@stephenreaves3205 Жыл бұрын
How are decorators different from derive macros in rust?
@nickbanderson Жыл бұрын
One is RUST and the other is NOT RUST
@Ether_Void Жыл бұрын
There are a few differences. For one derive macros can only be used on types (struct, enum, union), they see the definition and return the implementation for a certain trait and can't really do much else. Rust also has attribute macros which are less often used but they are a bit more similar to decorators. However Rust macros will always run at compile time and work on the syntax tree, where Python decorators run at runtime and work on class or function instances. Since the decorators in Python are running at runtime, they can already call functions and access attributes in the classes which isn't really possible with macros in Rust.
@tqwewe Жыл бұрын
I'm a rust fanboy, but true.. they're pretty much the same tbh
@v1Broadcaster Жыл бұрын
this channel is my favorite netflix advertisement
@0xCAFEF00D Жыл бұрын
2:45 I'm completely missing why the factory is a separate class and not just a set of static create functions on the burger. Am I just to imagine we're passing the factory somewhere to use as a customization point? So others can make the burger I want. This just feels like code obfuscation until you have a LOT of places where you instantiate burgers that all should be uniform or at least follow the standard as a baseline. Alternatively a very complex standard burger. But if that's all I still think the static method makes more sense. It also seems like a mess to have such diverse objects that don't express that in the type system. Code that operates on burgers with customization significant enough that you have to abstract away some complex init function must be very hard to operate on and it doesn't seem the code subdivides the problem enough. The example doesn't show that because it's too simple to even consider writing. 5:00 Even more confused now. The builder pattern doesn't seem to be replacing the factory.
@ACAndersen Жыл бұрын
It doesn't need to be a class in python, you can just make a factory function. Also the example is not ideal. The factory pattern usually instantiates different subclasses, with different internal implementations. Using the pattern for different sets of arguments is not the common usage that describes the pattern.
@HrHaakon Жыл бұрын
I am convinced that the US has a different Java than the rest of us. The only place I know of that has abstract factories are frameworks like Spring. Because Spring can make a case for "I need to have a way of producing objects of whatever type specified", as well as "and I need to allow more than one way of doing it". And that's just because of the very generic way the IoC-container works.
@DagarCoH Жыл бұрын
Saw the original before, generally good comments as far as my experience with these patterns go. One critique I have is your statement that "Everything is a facade, becaus you hide information" with something something private. Facade does obfuscate variables and functions from the programmer, but they are still accessible from the outside. Basically, Facade (at least as stated in the GangOf4) is an interface to a functionality that says "Hey, 99% of the time, you will want to use me by calling these couple of functions here. If you need more custom behaviour and you REALLY know what you are doing, you can also tweak all my other variables and use these other functions". So Facade gives you a set of convenient functions to use it with, but also allows for access to everything else about the interfaved functionality, if you want to.
@alexcook4851 Жыл бұрын
love the design patterns book, great video!
@MihoKozloffsky Жыл бұрын
The idea of a factory is to provide only one interface create so client class could use it to create object of given interface. Like when you need some default value (like in data classes) when constructing object.
@karlsassie840310 ай бұрын
You mean like a function 😅
@lethicanthus Жыл бұрын
Design patterns in functional programming: strategy pattern: functions builder pattern: functions observer pattern: functions adapter pattern: believe it or not also functions
@aoeu256 Жыл бұрын
Builder pattern is record syntax + functions, adapter is record of functions.
@evancombs5159 Жыл бұрын
Functional programming uses functions instead of objects, this checks out.
@xBZZZZyt Жыл бұрын
03:56 why put functions in class BurgerFactory instead of global?
@mattymerr70118 күн бұрын
Is the strategy pattern just more complicated higher order functions?
@tricky2014 Жыл бұрын
The implementation of the linkedlist iterator in the video is actually faulty. If you would create two iterators they would actually both modify the object.
@MrAbrazildo Жыл бұрын
2:48, they just gave a name for a thing that has been made in C for decades: struct CheeseBurger { const char *ing_1, *ing_2, *ing_3 }; #define createCheeseBurger CheeseBurger { "bun", "cheese", "beef-patty" } And then call it by: CheeseBurger a_cheese_burger = createCheeseBurger; 5:20, this is a "lesser version" of C++ for 2 reasons: a) If 1 just wants to customize the initialization, C/C++ way is much better, as exposed above, due to compact syntax. b) If the goal is to customize it along the way, not only on initialization, it should has a control of which f() is allowed do that - _and it seems that only C++ has this feature_ . Otherwise, all sorts of bugs can come from it, because everything will be public, which is the worst nightmare, depending on the project complexity. 10:57, why use an interface for that? Couldn't it be just a class? 16:00, again, why an interface? This thing is awkwardly slow! 21:00, and that's why f() programming < OO: the 1st lacks good facades. In C, you can let that memory management "encapsulated" away in a different file. But there are issues: a) Each file like this will be dedicated to each object, which hurts scalability. b) If only 1 generic file like this is created, then the user will has to keep traveling alongside with that array, which is exposed to dumb mistakes for long unnecessary time. It's still possible to create several macros, trying to hide that array exposure, but it's still a precary solution.
That opening was like a man confessing adultery to his wife.
@ezg5221 Жыл бұрын
Python canonically uses exceptions for control flow lmao. Exception zealots in shambles
@zerosandones7547 Жыл бұрын
beginner question: what's the difference if I just use: new Burger("bun-type", "patty-type", "cheese-type"); vs the builder pattern?
@zachmanifold Жыл бұрын
The main difference is if there's a varying amount of options when building an object. Say that I'm a really weird person and only want a burger with only a bun (no patty or cheese). Then I can use burger = BurgerBuilder().addBun().build() Or if I only want bun with cheese (no meat), burger = BurgerBuilder().addBun().addCheese().build() Otherwise you'd need several different constructors to handle every possible combination (which quickly gets messy when multiple options are involved.) The burger example is not the greatest to show this difference but hopefully that made some sense
@aoeu256 Жыл бұрын
the code is in Python but you used the new keyword hahah. You don't need builder in Python cuz of default arguments, keyword arguments and dicts in Pythons.
@zerosandones7547 Жыл бұрын
@@zachmanifold ooh,, now that you said something about those constructors, I got it now, thanks! :)
@jma42 Жыл бұрын
im a bit new to design patterns, and ive been struck into the type state pattern from rust, is type state pattern also a form of builder pattern?
@armynyus9123 Жыл бұрын
As a netflix btw guy Prime could/should have really said a bit more about the observer pattern. ReactiveX was a live changer for me, and that netflix talk about it sold it to me, back then.
@akirakosaintjust Жыл бұрын
Observer, Iterator and Strategy are great. Singleton is ok if you're careful with state (Rx singleton Observable for instance). Adaptor and Facade are unavoidable, but I hate how coupled they can get. Factory and Builder are meh - I feel they're needed sometimes but they get overused. ps. lol at Primer reacting to Python OOP in real time
@ISKLEMMI Жыл бұрын
8:25 - What is this contraption?? 16:18 - ngl this caught me off guard mid drink
@kodekata Жыл бұрын
Great comment at 15:48 . From a functional perspective, the "interface" you are crying out for, is just a function. However I don't think it's worth a full fedora-tip here, because as competent engineers we need to be prepared for any situation we may walk into. Such as George Clooney walked into in From Dusk Till Dawn.
@hamzahmd_ Жыл бұрын
I first thought it was about PrimeReact UI Library. Your videos are fun to watch; I've subscribed.
@sameeranadgaonkar97569 ай бұрын
he looks so guilty when talking about factories :P
@htrOfLiesfub Жыл бұрын
This video was good. Why? We learnt something, unlike some videos where you just rant or do irrelevant optimisations, in this I actually learnt something which can get someone hired.
@ericbwertz Жыл бұрын
Rant material is often a flash-forward to a problem or conflict that you just haven't run into YET -- artifacts of some clear, prior trauma.
@mrrolandlawrence Жыл бұрын
12:50 i had the similar experience. Microsoft tried to hire me with a 40% cut of my city salary. They said oh but we do value you, we intend to hire you out to clients for $5000 a day. This was in 2000 when $5000 was still quite an impressive amount.
@SuperKhezar Жыл бұрын
8:45 - what is prime holding?
@porky1118 Жыл бұрын
8:00 No, if used like this, singeltons are pretty stupid. I just use them when I can't have global state, or I don't have control over the main function or something similar. (only in Unity) And I never define a static method when using them. I just use a public static parameter, or different static methods to access it.
@ElderSnake90 Жыл бұрын
Close your eyes and listen and you half expect Prime to throw out a random "Morty" during his speeches. Y'ALL KNOW I'M RIGHT (seriously though if Prime wasn't a software dev he could probably take over for Rick's VA)
@FaceBookAutomated Жыл бұрын
Can you dump full vods as well? I’d like to re-experience everything from the stream.
@ajtan2607 Жыл бұрын
"I work at Netflix btw" has similar vibe as "I use Arch btw"
@shaunmolloy_ Жыл бұрын
Laughed at the, "is this bash now!?" comment 😂
@DuRoehre9021010 ай бұрын
11:00 Yeah, yeah, but there are languages *cough* where managing the lifetimes of the subscribers kept in the list can cause you a lot of trouble, and even using smart pointers might not save your day in cases where certain strange runtime dependencies in the destructors cause race condition or some runaway loops or similar fun. And yes, Facade is not an actual pattern of it's known, it's only a special case of the Wrapper.
@Jubijub Жыл бұрын
It's funny how the borrow from the French language lost the cédille, but kept the pronounciation : it's façade in French, where ç is pronounced like double s
@im-a-trailblazer Жыл бұрын
This guy is intense. But i think he works at Netflix right?
@CamembertDave Жыл бұрын
Builder isn't "better" than factory, they are just suited to different circumstances - builder for flexibility; factory for simplicity. E.g. a library class uses builders in order to provide maximal functionality, but an app using that library wraps this in a factory to provide a simpler interface for the small number of specific uses its needed for in that app.
@ThePrimeTimeagen Жыл бұрын
I just tend to find that factories are not what I want, yet. That's what I find myself doing. But a builder almost universally is what I want. Oftentimes you can even interchange them and I find the results almost always better with builder and a good setup defaults
@TehKarmalizer Жыл бұрын
I agree with Prime. I’ve never liked factories. They aren’t as flexible as builders.
@nandomax3 Жыл бұрын
I love the builder pattern, it's so useful. And the factory pattern is also super helpful
@aoeu256 Жыл бұрын
In Python keyword arguments and dictionaries tetrisgame(func1={arg1: 5}, object2={arg2: object3}) can replace builder pattern...
@SAsquirtle Жыл бұрын
@@aoeu256can you elaborate?
@TheEVEInspiration Жыл бұрын
It is only useful when you need to control what actually gets instantiated or how it gets configured during or after constructing. In all other cases, just doing a "new" of the proper class is both simpler and easier to follow. So if there is this need, sure, go for it. But I will never consider it a pattern to default to.
@TheNewton Жыл бұрын
Developer-Experience is the missing pattern category. 17:55 Facade is a DX pattern for every clean http endpoint , convenience functions , the porcelain over the plumbing.
@MeriaDuck Жыл бұрын
As a Java developer I stay away from factories if I can. But yes, I've had my share of Complicators on teams. And yes, (fluent) builders to create immutable instances ❤
@aoeu256 Жыл бұрын
I hate the new keyword that forces you differentiate between factory methods and class constructors, well at least the IDE can fix it for you.
@byronservies4043 Жыл бұрын
I had that book. I tore it apart before I trashed it so nobody else would be infected by it.
@robgrainger5314 Жыл бұрын
Where did you work again? Was it Prime Video? (ducks)
@IgorGuerrero Жыл бұрын
Did I hear I hate decorators? How do you love this though? #[Derive(Debug,Clone,Display)] on all your structs? :)
@hugo-garcia Жыл бұрын
Netflix is implementing java today
@JohnWasinger Жыл бұрын
17:45 Adapter pattern is just the application of a strategy pattern.
@ov1kenobi663 Жыл бұрын
4:20; Composition over Inheritance
@martim1379 Жыл бұрын
7:05 why Python is the worst language to do classes?
@aoeu256 Жыл бұрын
Python doesn't need classes for a lot of these patterns, because your module is an object and functions are objects as well. Closures can replace Strategy/Command pattern. Keyword arguments + dicts replace the builder pattern. Etc... etc...
@thirdvect0r Жыл бұрын
builder pattern with rust is good because of the TypeState Pattern
@asimssheikh Жыл бұрын
Whats the link to the original video being reacted to?
@Leto2ndAtreides Жыл бұрын
"btw, I work at Netflix"... "Oh, you work at Netflix? Why don't you ?" lol
@porky1118 Жыл бұрын
15:00 That's why I hate pattrens. They give things I do everyday, which aren't special to me, names, and call them patterns. And I'm supposed to know these patterns now. I had no idea what the strategy pattern is. I just pass functions to make my code more generic and that's it.
@sch3me52110 ай бұрын
I feel the same way. They're patterns in the sense that they appear a lot but I think the moment you start naming then and teaching useless toy examples to people they go from "common problem solving technique" to "tool I need to know and fit in my code somehow". I swear software engineering is the worst thing that has ever happened to programmers
@jearsh Жыл бұрын
"if only...if only react was dying"...lol you get a million internet points