Interfaces vs Abstract Classes

Поділитися
Вставка
  • Опубліковано 1 гру 2024

КОМЕНТАРІ • 56

  • @neelamrani6884
    @neelamrani6884 Рік тому +7

    We need more of these interview tips gems

  • @trustingod0
    @trustingod0 Рік тому +5

    Thanks for this video, very informative. Just a couple of questions about Abstract Classes compared to Interfaces. You mentioned that an abstract class is when you have a set of things that have a commonality and then you take that commonality and abstract it into an abstract class. Whereas with interfaces you said you want to separate the thing that a component is dependent on or the things that its consuming and this is where the bridge or contract comes in ultimately used to decouple your components into code. That went straight over my head lol. What I think I have discovered and why some people struggle with getting a sound understanding of the concepts is that maybe its because there is a coding benefit in using abstract classes and interfaces as well as practical advantage.

    • @RawCoding
      @RawCoding  Рік тому +2

      what's the question?

    • @trustingod0
      @trustingod0 Рік тому

      @@RawCoding Just a couple of questions about Abstract Classes compared to Interfaces. You mentioned that an abstract class is when you have a set of things that have a commonality and then you take that commonality and abstract it into an abstract class. Whereas with interfaces you said you want to separate the thing that a component is dependent on or the things that its consuming and this is where the bridge or contract comes in ultimately used to decouple your components into code. Just wodering if you could elaborate on that. I thought it was insightful that i mentioned that a lot of the coding paradigm has more of a readability or design benefit than necessarily any practical benefits, and I think thats where a lot of people get confused. For example to some people they think that when it says an interface is a contract that means just make sure that your classes implement the interface. But as you are designing a system it takes on a much different meaning. So there are levels to understanding and if you have an average understanding of interfaces you really dont understand them at all.

  • @81NARY
    @81NARY Рік тому +1

    Best lighting on the tubes, welcome back!

  • @lw5482
    @lw5482 Рік тому +11

    one thing is, if you wanna change the interface like adding new method / property to it, it will break all implementations. And if you make new interface to replace it, you need to document it and educate other devs in the team. It's disaster especially for package / framework devs. So one important rule would be: If you are going to design an interface, design it very carefully and target it to the future.

    • @RawCoding
      @RawCoding  Рік тому +1

      100% agree, interfaces on their own don't bring any degree of correctness.

    • @jonasgranlund4427
      @jonasgranlund4427 Рік тому +3

      How about using interface Segregation if there are many implementations of the original interface where some of them dont need this new method, I like really small interfaces most of the time and in worst case there are a possibility to use a default implementation of the new method since c# 8.0, if you dont want all implementations of the "god interface" to explode when you add the 78th method. :)

    • @lw5482
      @lw5482 Рік тому +1

      @@jonasgranlund4427 Actually the interfaces should always be "minimal" (as small as possible) to represent a specific contract (as you mentioned the solid principle). If an interface got like more than 20 methods (or even 10, it depends), it could much be a design failure. What I meant is, you need to think carefully about your "contract", like what belong to the interface and what not, method signature and possible demands in the future. Even an interface is minimal, it could still face the problem I mentioned.

    • @jonasgranlund4427
      @jonasgranlund4427 Рік тому

      @@lw5482 I agree on that and I think that on your first point that if there are many places that implement this interface that need the new method you can add it to the "main interface and if the implementations cant implement it at once there is the possibility to do a default implementation of the new method to not break. But if one or more dont need the new method it makes sense with breaking it ut to its own interface or group it somewhere else where it makes sense. I use both but it is usually atleast 20 to 1 where I use interface compared to abstract class. Happy coding.

    • @andrii.h258
      @andrii.h258 Рік тому +1

      In C#8 was introduced default methods for interfaces, so when you are adding new method in interface you can write some default logic to this method and do not break any implementation.

  • @Tiago-up3tw
    @Tiago-up3tw 3 місяці тому

    Loving this channel

  • @victorchisomnwisu9776
    @victorchisomnwisu9776 Рік тому +4

    He's back 🎉🎉

  • @Noceo
    @Noceo Рік тому +10

    Given that this would be a great topic for newer developers to understand better, I think the video would benefit from slowing down a little bit (or reducing the scope, if you want to keep it sub 15 minutes). Don't get me wrong, you are saying a lot of really important thing, but even with 5 years of .NET experience, I had a hard time keeping up on everything.

    • @RawCoding
      @RawCoding  Рік тому

      noted, thank you

    • @trustingod0
      @trustingod0 Рік тому +2

      I agree he really knows his stuff. Relaying that to others might be more difficult.

    • @Michael-lo3ht
      @Michael-lo3ht 10 місяців тому +1

      Way too fast. I watched another video that was talking about the 2, but not why or a good explanation. So I found this one, hoping it would help. Talking fast and jumping around the screen. It's hard to keep up with all of it.

    • @Sub0x-x40
      @Sub0x-x40 4 місяці тому

      the thing with youtube is you can just pause rewind and rewatch 15 times if you need

  • @rmcgraw7943
    @rmcgraw7943 Місяць тому

    I often inherit an Interface into my Abstract class, then put default implementation into my class. Now, of course, you can do that via default interface implementations, but I don’t recommend doing that, because that’s more of a versioning hack that should be kept in reserve for your Enterprise Architect.

  • @ManderO9
    @ManderO9 Рік тому +1

    the legend is back

  • @damilareoyebanji2834
    @damilareoyebanji2834 9 місяців тому +1

    "The Square at that point has schizophrenia "🤣🤣

  • @noctavel
    @noctavel Рік тому +2

    good video, tho i would suggest going/running the code to exarcebate the difference between any 2 approaches. You did show the code, but it's hard to grasp between the 2 without running them

  • @amnesia3490
    @amnesia3490 Рік тому +2

    oh my boi is back

  • @shashikantnipanikar860
    @shashikantnipanikar860 7 місяців тому

    That's a really great explanation. I think the interviewer wanted this from me. 😅

  • @m_stf
    @m_stf Рік тому +1

    welcome back

  • @oladipotimothy6007
    @oladipotimothy6007 Рік тому +1

    I noticed I could use public, internal, and protected access modifiers in the interface. I couldn't use private though
    Update: doesn't work when inherited from another project. Insisted on public modifiers but worked when implemented 'explicitly' for protected modifiers regardless

  • @rmcgraw7943
    @rmcgraw7943 Місяць тому

    One thing that you don’t mention is that creating generic interfaces let you accomplish some pretty great things, via the IN and OUT keywords, by means of covariance and contravariance. That’s probably beyond the scope of this channel, but it’s a good thing to know if you like know what an expert interviewer might follow up this question with.

  • @neelamrani6884
    @neelamrani6884 Рік тому +4

    Nice lighting😊😅

  • @yourockst0ne
    @yourockst0ne Рік тому +1

    🎉 nice seeing your FACE in my notifications

  • @ntson1710
    @ntson1710 Рік тому

    what's your ide and what theme were you using in this video?

  • @purplepixeleater
    @purplepixeleater Рік тому

    Abstract Base > Inherit > Implement abstracted target interface... avoids issues with dual inheritance. why not just use virtuals?

  • @robsonfaxas6574
    @robsonfaxas6574 Рік тому

    Nothing related to coding, but I like the fact you didn't unwrinkle your t-shirt and don't care about the late afternoon sun removing half of your facial expressions at the beginning of your video.

  • @allinvanguard
    @allinvanguard Рік тому +2

    Great video! I have two more points which were not mentioned (I think? Or maybe I also forgot haha) - A class can implement multiple interfaces, but only one abstract class. Also maybe the fact that default interface implementation methods can't act on any dependencies coming from the implementing class, it's essentially a static context.

    • @RawCoding
      @RawCoding  Рік тому +2

      point 1 - was mentioned
      point 2 - that's wrong, in a static-context members belong to the type (there are no objects, only compile time), default implementation cant be called like: IInterface.DefaultMethod, they have to be called on an object the class for which implements the interface.

    • @allinvanguard
      @allinvanguard Рік тому +2

      @@RawCoding Oh, I see, then I missed that, my bad - For the second point I think I picked a poor wording, I meant that the context is basically the interface and potentially accessing other static contexts, but you can't interact with other dependencies like an abstract class / method can. Like, you can't just supply other dependencies to the interface itself unless you do it through property accessors. Just a minor point I figured might be interesting as well. On a side note, I think that a default implementation can be static as well?

  • @EdsonViniciusSchmitt
    @EdsonViniciusSchmitt Рік тому +1

    Hey there! You are missing a "t" on your thumbnail. Welcome back btw!

  • @ezmooj
    @ezmooj Рік тому +1

    I like your wall its intresting

  • @DucaTech
    @DucaTech Рік тому

    I think in C++, you can have multiple inheritance just not Java and C# using abstract classes.

  • @cocoscacao6102
    @cocoscacao6102 Рік тому +1

    What's the editor?

  • @andrewiecisa2907
    @andrewiecisa2907 Рік тому +1

    Idea for content: openiddict-core

  • @PrasannaCE
    @PrasannaCE 11 місяців тому

    Hi, pls create a video to explain for Covariant and contravariant

  • @fabianosobreira7581
    @fabianosobreira7581 Рік тому +1

    😎

  • @Bourn77
    @Bourn77 Рік тому

    Mate, Dark theme please.

  • @rmcgraw7943
    @rmcgraw7943 Місяць тому

    IS A vs CAN DO

  • @ImReddyBasha
    @ImReddyBasha Рік тому +1

    Sir, please explain bit slow. Content not able to reaching.

  • @theguitarden8530
    @theguitarden8530 Місяць тому

    TOO FUCKING FAST. started out ok but started flying.

  • @rahiyansafin449
    @rahiyansafin449 Рік тому +1

    first one to watch!

  • @slrtgaln4065
    @slrtgaln4065 Місяць тому

    more focused on showing off than teaching.

  • @erhanalankus
    @erhanalankus Рік тому +1

    Thanks for the explanation. I think your voice tone and speaking rhythm could use a bit variety. I lost my attention while watching several times.

  • @ahlembs790
    @ahlembs790 9 місяців тому

    slow down man ..u r talking too fast