one question that developers may have is maybe adding stored property impacts the size of the memory, let's talk about it. Note: type = class/structure stored properties have state, they maintain their own values and from a responsibility standpoint it's not the job of extensions to maintain state to the type that it's extending and hence we have compile time errors. coming to the question of memory management if SUPPOSE adding stored properties was allowed in the extension, then this would have caused the entire object to be re-initialized OR maybe not since whatever is added to the type is decided during compile time the compiler will compile the code and will link everything to the type so that the task of memory allocation is smooth and done right so assuming that extensions could alter something on runtime or change memory structure which also is a runtime task is invalid, because before initialization we have the process of compilation where such checks are done it also raises a question that who manages the state of that new stored property? is it the type? is it the extension? because initially the type never had the new stored property to begin with, the extension added it the compiler just checks if the code that you added in extension, creates a new state or not and if it does then throw a compilation error so I look at it from what the extension can and cannot do, extension can add stateless routines but not the one that maintain state in this case stored properties.
@@CodeCat15 There is another perspective to it if you think about it. Extensions give you the capability to add functionality to any type. Be it something we have defined or if it is defined in a framework, both dynamic or static. So it is quite convenient to say that, extensions can only add dynamic computations, where memory can be allocated anywhere and need not be contiguous. Hence stored properties can only be part of the concrete implementation and not loosely defined like as in an Extension.
that's one more way of looking at it, thanks for sharing your views this is a nice insight as well, I really wished if apple could've taken efforts to mention few lines as to why this decision was made.
@@CodeCat15 If Apple was really good at writing documents. You might have lost few subscribers 😉 Take it as a blessing disguised. You're doing a great job here. Keep going.
Hey Ravi…. Your way of explanation is really great. I have one small question.. do you know why we use get and set… if you have made a video on get set topic please send.. I could not found it in your playlist ..
Thanks Mandeep, I think am dropping the idea of two way binding as a video but perhaps can do a discord event on this, reason why am not making a dedicated video is coz two way binding does a lot and the code I did using observer pattern is not close enough to few of the things what two way binding does
I have a 3 part video on the coordinator pattern, I don’t recommend that pattern at all coz it just increases code complexity for no reason, search coordinator in my videos and you’ll see the videos also, do read the comments of each videos coz the comment section of this channel is a knowledge library of its own
As always a new and different and easy stuff / information about the topic. Thanku brother for this explanation. Also needs more stuff like this for ex:- Why open keyword can’t be use with struct.
Thanks Pratap, yes this is indeed a good topic and perhaps questions like these are more of a brain teaser as they test your knowledge on the language and programming. I'll make a video on the open keyword, although I wanted to explain it in the comment but I think a code example and visuals would add more value
Open Keyword works with reference types i mean with classes and overridable members of classes so using the open keywords with values types doesn't make sense so swift compiler will not like it , hence it will throw compile time error . Ravi brother waiting for the video and more technical reason on this topic . That being said thank you happy i coding !!!
@@CodeCat15 I mean to say if adding stateful properties in extension it will going to violate open/close principle and as per the open/close principle it is not a allowed to modify the existing implementation, extension act as adding new behaviour using existing states (be it computed properties or new behaviours manipulating existing states) and provide implementation based on new requirements.
Perfect, yes that is also a case. Good explanation Rupesh. It also breaks SRP as adding states is only the responsibility of class & structs and not extensions so if suppose extensions did add states then now in a way we are violating SRP as well.
It is to do with the memory allocation. When you make a class or a struct and declare a stored property inside it, the memory boundaries can be pre defined for each object that we declare later on. With computed properties, it does not completely become the part of the objects memory. How else can we manage the object memory.
I have pinned a comment of mine on this, let me know what you think about it. Yes for a smoother memory allocation the compiler does a check for anything that can hold state in extension and then raises the compilation error.
In few Interviews I faced this QN. Need answer and give explanation with any demo example for better understand I’m getting user data from api response Previously I’m getting key as “username” Now I’m getting key key as “userName” How you handle from ur end ..?
if they response keys keeps on changing continuously then this means the api developers are not doing a good job in making a concrete response, a change in the response would mean you would have to change your contract as well, you could use the dictionary approach and add required checks on your side to check if the dictionary contains the following key i.e username, userName, name, UName, firstName, userFirstName, first_name, user_first_name and god knows how many more combination i guess by now you must realize why it's important to have a concrete keys in the response and why this is something that should not be handled on the iOS side.
INITIALISATION issue could be the reason why extension can't contain stored properties. Say for example original class had one property and it is used by another classes in same module with one property initialiser, now if we add another property in extension then the classes using the one property initialiser would be required to add newly added property in extension, which would not be possible later on. I may not be quite right but it could be the one of reasons.
Checkout the pinned comment of mine. No matter what usecase we are in, it all boils down to state management as explained in the video, if you are dynamically creating a container to hold state then the object has to be destroyed and re-constructed again.
Yes, it’s one of their favorite questions. I hope this video was helpful and do read the pinned comment of the video as it adds more inputs that I missed adding in the video.
In my opinion, Extensions can't be initialized and that's why they can't hold stored properties. The extension is like a shadow of a type that gives some extra functionality but doesn't exist on its own.
Very well said, the entire idea of extension is just to extend non-stateful behavior and anything that involves state will not be allowed by the compiler.
I'm speculating slightly here, but it could be to do with the amount of memory required to store an instance of an object. Adding functions and computed variables (which are basically just functions without arguments) don't require any additional memory to store an object. Adding a new stored variable requires additional memory to be allocated to store that object. It would make sense that this would be an issue if a class / struct was declared in a module, and then extended outside of that module to add an additional variable. I guess the module would need to be recompiled to be aware of the user's extension, which would break encapsulation and really defeat the whole purpose of a module. If it were pre-compiled this wouldn't even be an option. In my head it seems that it could be theoretically possible to extend a type to add additional stored properties in the same module that it is defined. The compiler should theoretically have enough information there to put all of the pieces together. Someone who knows a little more might be able to provide some more insight.
I have pinned a comment of mine with regards an assumptions I have, tried to keep it relevant from programming standpoint but then would’ve been great if apple took efforts in mentioning this in the documentation than leaving it to the opinions/theories and assumptions. I think when you declare an extension we think that we are creating a boundary but I think there’s no boundary to begin with since all those extension functions can easily be accessed with that one object. We can try something what you mentioned and see how the compiler reacts to it, curiosity is a good thing testing that curiosity with code is even better.
Hey Ravi…. Your way of explanation is really great. I have one small question.. do you know why we use get and set… if you have made a video on get set topic please send.. I could not found it in your playlist ..
one question that developers may have is maybe adding stored property impacts the size of the memory, let's talk about it.
Note: type = class/structure
stored properties have state, they maintain their own values and from a responsibility standpoint it's not the job of extensions to maintain state to the type that it's extending and hence we have compile time errors.
coming to the question of memory management
if SUPPOSE adding stored properties was allowed in the extension, then this would have caused the entire object to be re-initialized OR maybe not
since whatever is added to the type is decided during compile time
the compiler will compile the code and will link everything to the type so that the task of memory allocation is smooth and done right
so assuming that extensions could alter something on runtime or change memory structure which also is a runtime task is invalid, because before initialization we have the process of compilation where such checks are done
it also raises a question that who manages the state of that new stored property? is it the type? is it the extension? because initially the type never had the new stored property to begin with, the extension added it
the compiler just checks if the code that you added in extension, creates a new state or not and if it does then throw a compilation error
so I look at it from what the extension can and cannot do, extension can add stateless routines but not the one that maintain state in this case stored properties.
This is quite elaborate. Well explained. 👍🏻
@@AbhishekSrivastava_ab Thank you, I am glad this was helpful.
@@CodeCat15 There is another perspective to it if you think about it. Extensions give you the capability to add functionality to any type. Be it something we have defined or if it is defined in a framework, both dynamic or static. So it is quite convenient to say that, extensions can only add dynamic computations, where memory can be allocated anywhere and need not be contiguous. Hence stored properties can only be part of the concrete implementation and not loosely defined like as in an Extension.
that's one more way of looking at it, thanks for sharing your views this is a nice insight as well, I really wished if apple could've taken efforts to mention few lines as to why this decision was made.
@@CodeCat15 If Apple was really good at writing documents. You might have lost few subscribers 😉
Take it as a blessing disguised.
You're doing a great job here. Keep going.
Apple needs people like you "Ravi" as we do 😅. Thanks a lot for such conceptual reasonings. Kash aap jaise seniors mile hote pehle!!!
Hey Ravi…. Your way of explanation is really great. I have one small question.. do you know why we use get and set… if you have made a video on get set topic please send.. I could not found it in your playlist ..
Appreciated .. we need these kind of in-depth explanation ..
Thank you 😊 I am glad this was helpful
Thanks a lot Ravi for this video
Glad it was helpful Nidhi 👍
Good tutorial brother. Explained well.
Thank you, am glad it’s helpful Adnan
You made this easy to understand.
Thank you so much
Thank you Vishal 😊 I am glad this video was helpful.
Very well explained
Thank you, i am glad this video was helpful, please share the same with your ios groupand fell free to ask questions.
thank you for this amazing explanation
Glad it was helpful
Best Swift Teacher in India ❤️
Thank you for your kind words Geetam
clear explanation. 👏👏👏
Thank you, am glad it was helpful
Outstanding.....🤩
By the way great job ravi by making the concepts even more clear.
Do checkout the pinned comment as well, I hope that too provides more insights to the topic
very useful Information about an extension💥💥 , bro please make video on MVVM two way binding
Thanks Mandeep, I think am dropping the idea of two way binding as a video but perhaps can do a discord event on this, reason why am not making a dedicated video is coz two way binding does a lot and the code I did using observer pattern is not close enough to few of the things what two way binding does
Amazing video and I don't know why this channel is underrated.
Thank you Pushpender 🤗
Great explanation!!
Thank you Mukesh
Ravi did you created for KVO and KVC video ??
I did not 🥲
@Ravi can you help me out for Coordinator exact purpose in swift
I have a 3 part video on the coordinator pattern, I don’t recommend that pattern at all coz it just increases code complexity for no reason, search coordinator in my videos and you’ll see the videos also, do read the comments of each videos coz the comment section of this channel is a knowledge library of its own
As always a new and different and easy stuff / information about the topic.
Thanku brother for this explanation.
Also needs more stuff like this for ex:-
Why open keyword can’t be use with struct.
Thanks Pratap, yes this is indeed a good topic and perhaps questions like these are more of a brain teaser as they test your knowledge on the language and programming. I'll make a video on the open keyword, although I wanted to explain it in the comment but I think a code example and visuals would add more value
Open Keyword works with reference types i mean with classes and overridable members of classes so using the open keywords with values types doesn't make sense so swift compiler will not like it , hence it will throw compile time error . Ravi brother waiting for the video and more technical reason on this topic . That being said thank you happy i coding !!!
Ravi i faced many time software model interview question , but i did't found exact answer for it can you please make a brief discussion about it
What was the question being asked in the interview?
@@CodeCat15 Question is what type of software model you follow. in your project
@@poojaraghuwanshi1914 the answer to this is related to what architecture you follow in your current application and why.
must be violating open close principle?
Can you elaborate on this please, also check the pinned comment for more details on memory management of extension.
@@CodeCat15 I mean to say if adding stateful properties in extension it will going to violate open/close principle and as per the open/close principle it is not a allowed to modify the existing implementation, extension act as adding new behaviour using existing states (be it computed properties or new behaviours manipulating existing states) and provide implementation based on new requirements.
Perfect, yes that is also a case. Good explanation Rupesh.
It also breaks SRP as adding states is only the responsibility of class & structs and not extensions so if suppose extensions did add states then now in a way we are violating SRP as well.
@@CodeCat15 Yes it will also violate SRP..
you can create static store property in extension .
Like :- static let test = "Test"
Wow, 😮 Keep Sharing
Indeed, I hope the video was helpful. Do share with your iOS group 😊
@@CodeCat15 Sure
Very well explained Ravi, thanks for it. Can you please tell us more about this State and Stateless and how does it work in Swift.
It is to do with the memory allocation. When you make a class or a struct and declare a stored property inside it, the memory boundaries can be pre defined for each object that we declare later on.
With computed properties, it does not completely become the part of the objects memory.
How else can we manage the object memory.
I have pinned a comment of mine on this, let me know what you think about it.
Yes for a smoother memory allocation the compiler does a check for anything that can hold state in extension and then raises the compilation error.
In few Interviews I faced this QN. Need answer and give explanation with any demo example for better understand
I’m getting user data from api response
Previously I’m getting key as “username”
Now I’m getting key key as “userName”
How you handle from ur end ..?
if they response keys keeps on changing continuously then this means the api developers are not doing a good job in making a concrete response,
a change in the response would mean you would have to change your contract as well,
you could use the dictionary approach and add required checks on your side to check if the dictionary contains the following key i.e
username, userName, name, UName, firstName, userFirstName, first_name, user_first_name and god knows how many more combination
i guess by now you must realize why it's important to have a concrete keys in the response and why this is something that should not be handled on the iOS side.
INITIALISATION issue could be the reason why extension can't contain stored properties. Say for example original class had one property and it is used by another classes in same module with one property initialiser, now if we add another property in extension then the classes using the one property initialiser would be required to add newly added property in extension, which would not be possible later on. I may not be quite right but it could be the one of reasons.
Checkout the pinned comment of mine.
No matter what usecase we are in, it all boils down to state management as explained in the video, if you are dynamically creating a container to hold state then the object has to be destroyed and re-constructed again.
I think extensions are run time so it will change the memory allocation if it allows the stored property in extension. That is the reason.
I have a comment pinned about this, do check it out and let me know what do you think about it.
This question I asked by an interviewer
Yes, it’s one of their favorite questions. I hope this video was helpful and do read the pinned comment of the video as it adds more inputs that I missed adding in the video.
Thanks bro
In my opinion, Extensions can't be initialized and that's why they can't hold stored properties. The extension is like a shadow of a type that gives some extra functionality but doesn't exist on its own.
Very well said, the entire idea of extension is just to extend non-stateful behavior and anything that involves state will not be allowed by the compiler.
I'm speculating slightly here, but it could be to do with the amount of memory required to store an instance of an object.
Adding functions and computed variables (which are basically just functions without arguments) don't require any additional memory to store an object. Adding a new stored variable requires additional memory to be allocated to store that object.
It would make sense that this would be an issue if a class / struct was declared in a module, and then extended outside of that module to add an additional variable. I guess the module would need to be recompiled to be aware of the user's extension, which would break encapsulation and really defeat the whole purpose of a module. If it were pre-compiled this wouldn't even be an option.
In my head it seems that it could be theoretically possible to extend a type to add additional stored properties in the same module that it is defined. The compiler should theoretically have enough information there to put all of the pieces together. Someone who knows a little more might be able to provide some more insight.
I have pinned a comment of mine with regards an assumptions I have, tried to keep it relevant from programming standpoint but then would’ve been great if apple took efforts in mentioning this in the documentation than leaving it to the opinions/theories and assumptions.
I think when you declare an extension we think that we are creating a boundary but I think there’s no boundary to begin with since all those extension functions can easily be accessed with that one object.
We can try something what you mentioned and see how the compiler reacts to it, curiosity is a good thing testing that curiosity with code is even better.
Hey Ravi…. Your way of explanation is really great. I have one small question.. do you know why we use get and set… if you have made a video on get set topic please send.. I could not found it in your playlist ..