For the SRP part, I would say its a bad idea to create dependencies inside a method (at least do a method injection instead), for example how would you test your Invoice implementation? You can't mock InvoicePrinter nor the InvoicePresitence, yes you can test them separately but there is no way to test Invoice in integration with InvoicePrinter and InvoicePresistence so you should use preferably constructor injection here, also another thing Invoice is a model, it should cointain only data not some kind of functionality of printing or saving. You could have some kind of InvoiceManager which depends on InvoicePrinter and InvoicePersistence and therefore you could test everything easily and also those dependencies depending on the case should be protocols not concrete implementations, but overall nice explanation about separating into different classes/structs and so on
@iLoveAppl3947
7 ай бұрын
thank you bro. After watching this its easier to understand the Networking Masterclass course i just purchased
@lensvana
8 ай бұрын
Thanks dude, really helpful content all around. "Liskov Substitution Principle" sounds like something out of a 1960s sci-fi novel related to time travel heh
@appstuff5778
8 ай бұрын
Sounds so scary, but is actually so simple lol
@devdev1
8 ай бұрын
Clean and very relevant to the iOS domain, it is better to explain with real world examples not Animal etc. classes. Thank you :D
@sukumarreddy6085
7 ай бұрын
great video stephan, thanks. can you make video on important design patterns as well .
@KiriKiriKiki
6 ай бұрын
I think a lot of people are going to get confused by your example of not using an actual Class data type to first represent the single responsibility rule. When you create a struct it doesn't matter when or where youre calling your objects, theyre going to be created new every time. thats why you can create more complex things in structs that you shouldnt do with a Class type. Your idea of extracting functions into their own struct actually creates more net objects, they need to create 3 new item objects instead of just the one you'd initially call , for example. On top of that, that's not how you'd refactor a struct, to make it more readable you'd easier just create an extension. why would you create more structs????? also sometimes are absolutely unnecessary, atleast in my app, for that simple task. I think if you'd want to show something that would required added functionality, you'd show a protocol with an enum not with a struct, that, again, IS MADE FOR ADDED FUNCTIONALITY. Im watching this with the same energy that you made this with where you're essentially saying that people are bad coders unless they do it your way and so hence, your code or atleast examples, seem more predatory than edifying and meant more to get people to purchase your masterclass after your example was just... idk.
@appstuff5778
6 ай бұрын
Go ahead and make your own video explaining it your way then 🫡
@BABEENGINEER
6 ай бұрын
Absolutely love your videos. Please make more
@appstuff5778
6 ай бұрын
Make sure to check out our premium content! Links in description of all videos
@Kurortn1y
27 күн бұрын
thx!!! best!
@martinwainaina4529
6 ай бұрын
From the Open/Closes Principle, Kindly how do we implement the save(invoice: Invoice) with different function signatures ? i.e. save() function defined in DatabasePersistence is async while save() function defined in CoreDataPersistence is not async. Yet both must conform to protocol InvoicePersisableProtocol { func save(invoice: Invoice) }
@kironet
7 ай бұрын
Great video! But this is all really cool if you're working on your own project or maybe at a company with their own product. Cause at an agency where I work atm, I have no time to think about & implement all this. Explaining to a client why something "simple" took so much time is also close to impossible. 😫
@appstuff5778
7 ай бұрын
Welcome to the professional world lol. You gotta prioritize getting things done over having clean code. Which is why most companies code bases are trash 🗑️🗑️
@yugeras
4 ай бұрын
Wow! I would say the best explanation for SOLID!
@hieuangtrung3285
Ай бұрын
Thank for team, video very efficient
@rahmonali7
8 ай бұрын
I appreciate your gratitude. As always, your course provides excellent clarity in explanations.
@seamlessproductions
8 ай бұрын
When should we follow the SOLID principle? Should we do during updates or adding new features?
@appstuff5778
8 ай бұрын
Ideally you would follow it at all times. It shouldn’t have limitations on when it’s implemented
@alenayoutube1574
8 ай бұрын
i am seeing this for the second time for practicing , but still i have a doubt in implementing in our reallife project in our company , so can you do a video of solid architecture in a small project , i think project based learning is more effective
@appstuff5778
8 ай бұрын
As stated in the video, check out the Swift Networking Masterclass on our website
@marior5361
8 ай бұрын
Do you have a discord or one on one sessions. I have a project of my own with a couple of bugs that I can’t seem to fix.
@appstuff5778
8 ай бұрын
Contact me on my website! Link is in my KZitem profile
@awakeFromNib
8 ай бұрын
Everything is very clear, thanks!
@khakiBeanie
8 ай бұрын
like before watching!
@seninman
6 ай бұрын
Hello. I buy this subscription but don’t have an access to couses. Can you help me please?
@appstuff5778
6 ай бұрын
Hey! Just contact us on the website and we can help you out
@marcoalonsoiosdev
8 ай бұрын
Excellent explanation, thanks!
@rohlmayers1792
6 ай бұрын
Excellent video!
@ghreacts
8 ай бұрын
So in a real implementation, would you have to create all these structures in one file if the functions are related or in different files?
@appstuff5778
8 ай бұрын
Different files for sure!
@ghreacts
8 ай бұрын
Hello Stephan, in the first principle you were talking about classes but in your examples, you just spoke about structs and not classes, but learnt from your other tutorials that they are not the same. Can you please clarify for me?
@ahikmatf
8 ай бұрын
thanks!
@alenayoutube1574
8 ай бұрын
i was waiting ......great
@appstuff5778
8 ай бұрын
Thank you!
@casadogaspar
3 ай бұрын
Theres a presentation by Bruno Rocha in the SwiftConf about controlling your app size, where he talk about how structs are "expensive" for the compiler to handle. (probably a will improve over time, but at this moment it's suboptimal.) By your examples looks like you favor a well fragmented approach in your code, do you feel any impact in your apps size? Been working on any big App recently that can be affected by it?
@micahburnside2281
2 ай бұрын
Ok, something all tutorialists need to learn. Dont show the bad way to do something when you’re trying to teach someone the proper way.
@appstuff5778
2 ай бұрын
Bro shut your dumb ass mouth. Don’t tell people how to do their job, if you aren’t doing it better with proof to show it. You’re just a fucking clown with a meaningless opinion. On top of that, an opinion that’s ultimately negative and does nobody any good. Meanwhile creators like myself are out here busting our ass to bring quality content to people for FREE. Fuck way off you dork.
@micahburnside2281
2 ай бұрын
@@appstuff5778 I worked for Ray Wenderlich / Kodeco as an iOS editor. I think you leftist tech bros are losers.
@micahburnside2281
2 ай бұрын
@@appstuff5778 This is my job. Are you going to delete my comments again?
@appstuff5778
2 ай бұрын
I worked at Meta. As an actual engineer, not an editor. Kodeco is also trash. Why you’re trying to bring politics into the equation makes zero sense, much like your comments. We can go blow for blow dawg, I’m smarter than you and I make a lot more money than you do. So maybe just shut the fuck up and keep editing other peoples code? Or try building something yourself to gain some actual credibility.
@micahburnside2281
2 ай бұрын
I already built my own app in the apple store, so I quit working there. I also wrote my own encryption library. Have fun with UI's and being a little bitch who crumbles under an ounce of criticism from someone who knows how to teach.
@StianF
6 ай бұрын
I didn't really understand the point of Liskov Substitution Principle.. When is that ever not true? Wouldn't a derived or child class always be passable as parent in these cases? That's like.. the point of heritance..? At least for objects with pointers. Are we talking about how structs can be sliced, or what is the point of the principle? Showing what's NOT correct for each principle would help a lot, I think. Also, couldn't the protocols at 21:40 be optional instead of split, for such a consise scenario?
@rank1macro
8 ай бұрын
Thank you man, appreciate your dedication for the last months. Love how you are taking a deeper look into those more advanced things that every iOS Developer at some point has to face. Btw what do you personally think about VIPER aka clean architecture? Do you like it or is it more over engineering for you?
@appstuff5778
8 ай бұрын
I’m making a full swift architecture course! Going to do all of the different patterns. Personally, I think VIPER is definitely over engineering. It’s like killing a fly with a bazooka 😂
Пікірлер: 66