Interfaces vs Abstract Classes

Поділитися
Вставка
  • Опубліковано 7 чер 2024
  • A popular C# interview question is to explain the differences between interfaces and abstract classes, why use an interface over an abstract class or an abstract class over the interface.
    Support my Work 🤝 / raw_coding
    Buy my Courses 📚 learning.raw-coding.dev
    Buy my Merch 🛒 shop.raw-coding.dev
    Join the Community 💬 / discord
    Tweet Tweet 📣 / anton_t0shik
    Tune in LIVE! 🎥 / raw_coding
    #csharp #dotnet #interview

КОМЕНТАРІ • 49

  • @81NARY
    @81NARY 7 місяців тому +1

    Best lighting on the tubes, welcome back!

  • @neelamrani6884
    @neelamrani6884 7 місяців тому +6

    We need more of these interview tips gems

  • @trustingod0
    @trustingod0 7 місяців тому +4

    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  7 місяців тому +2

      what's the question?

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

      @@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.

  • @lw5482
    @lw5482 7 місяців тому +10

    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  7 місяців тому +1

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

    • @jonasgranlund4427
      @jonasgranlund4427 7 місяців тому +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 7 місяців тому +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 7 місяців тому

      @@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 7 місяців тому +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.

  • @victorchisomnwisu9776
    @victorchisomnwisu9776 7 місяців тому +4

    He's back 🎉🎉

  • @Noceo
    @Noceo 7 місяців тому +9

    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  7 місяців тому

      noted, thank you

    • @trustingod0
      @trustingod0 7 місяців тому +2

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

    • @Michael-lo3ht
      @Michael-lo3ht 4 місяці тому +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.

  • @ManderO9
    @ManderO9 7 місяців тому +1

    the legend is back

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

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

  • @amnesia3490
    @amnesia3490 7 місяців тому +1

    oh my boi is back

  • @neelamrani6884
    @neelamrani6884 7 місяців тому +4

    Nice lighting😊😅

  • @noctavel
    @noctavel 7 місяців тому +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

  • @m_stf
    @m_stf 7 місяців тому +1

    welcome back

  • @MultiBadway
    @MultiBadway 7 місяців тому +1

    I like your wall its intresting

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

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

  • @oladipotimothy6007
    @oladipotimothy6007 7 місяців тому +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

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

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

  • @EdsonViniciusSchmitt
    @EdsonViniciusSchmitt 7 місяців тому +1

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

    • @RawCoding
      @RawCoding  7 місяців тому +1

      Oooops! thank you

  • @fabianosobreira7581
    @fabianosobreira7581 7 місяців тому +1

    😎

  • @damilareoyebanji2834
    @damilareoyebanji2834 3 місяці тому

    "The Square at that point has schizophrenia "🤣🤣

  • @yourockst0ne
    @yourockst0ne 7 місяців тому +1

    🎉 nice seeing your FACE in my notifications

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

      Thank you Florian )

  • @andrewiecisa2907
    @andrewiecisa2907 7 місяців тому +1

    Idea for content: openiddict-core

  • @allinvanguard
    @allinvanguard 7 місяців тому +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  7 місяців тому +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 7 місяців тому +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?

  • @cocoscacao6102
    @cocoscacao6102 7 місяців тому +1

    What's the editor?

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

    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.

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

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

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

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

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

    Mate, Dark theme please.

  • @ImReddyBasha
    @ImReddyBasha 7 місяців тому +1

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

  • @rahiyansafin449
    @rahiyansafin449 7 місяців тому +1

    first one to watch!

  • @erhanalankus
    @erhanalankus 7 місяців тому +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 3 місяці тому

    slow down man ..u r talking too fast