this post was submitted on 10 Feb 2026
328 points (95.8% liked)

Programmer Humor

29713 readers
1596 users here now

Welcome to Programmer Humor!

This is a place where you can post jokes, memes, humor, etc. related to programming!

For sharing awful code theres also Programming Horror.

Rules

founded 2 years ago
MODERATORS
 
top 50 comments
sorted by: hot top controversial new old
[–] FreshLight@sh.itjust.works 37 points 3 days ago* (last edited 3 days ago) (3 children)

In case anyone is wondering:

The artist is Princess Hinghoi.

[–] Not_mikey@lemmy.dbzer0.com 28 points 2 days ago (1 children)

Looks like some circular inheritance, that's going to cause some issues down stream.

[–] ICastFist@programming.dev 3 points 2 days ago

Trust the vibe, bro, if it was wrong it wouldn't vibe like that bro

[–] FEIN@lemmy.world 21 points 3 days ago (1 children)

sometimes i wonder what dignity means to certain artists

[–] FreshLight@sh.itjust.works 18 points 3 days ago* (last edited 3 days ago) (1 children)

My guess is that money overwrites dignity in some cases.

[–] ICastFist@programming.dev 3 points 2 days ago

Implying that's not their kink in the first place

[–] Gonzako@lemmy.world 11 points 3 days ago (1 children)
[–] FreshLight@sh.itjust.works 12 points 3 days ago (1 children)
[–] Gonzako@lemmy.world 9 points 3 days ago (2 children)

I'm taking the blonde with the succubus tattoo

load more comments (2 replies)
[–] tiramichu@sh.itjust.works 171 points 4 days ago (10 children)

I'll say this now.

Inheritance is the most misused capability of OOP which programmers think makes their code look smart, but most of the time just makes a giant fucking mess.

[–] VibeSurgeon@piefed.social 1 points 1 day ago

In all honesty, the protocols and structs-thing they talk about in Swift-land is the way to go. Interfaces and data classes in JVM-land

[–] red_tomato@lemmy.world 103 points 4 days ago* (last edited 4 days ago) (1 children)

Hold on, I’m in the middle of drawing an inheritance graph so I know how Dog is related to AircraftCarrier.

[–] blackn1ght@feddit.uk 78 points 4 days ago* (last edited 4 days ago) (5 children)
public interface ICanTravelThroughTheAir
{

}

public class Flea : ICanTravelThroughTheAir
{

}

public class AircraftCarrier
{
  private readonly List<ICanTravelThroughTheAir> _aircraft = new();

  public void AddAircraft(ICanTravelThroughTheAir flyingThing)
  {
    _aircraft.Add(flyingThing);
  }
}

public class Dog : AircraftCarrier
{
    public void Woof()
    {
        Console.WriteLine("Bitch I'm an aircraft carrier!");
    }
}

public static class Program
{
  public int Main(string[] args)
  {
    var dog = new Dog();
    
    for (var i = 0; i < 10000; i++)
    {
        dog.AddAircraft(new Flea());
    }

    dog.Woof();
  }
}
[–] jenesaisquoi@feddit.org 62 points 4 days ago (2 children)

Needs more AbstractDefaultProxyBeanFactoryFactories

[–] VibeSurgeon@piefed.social 2 points 1 day ago

I managed to organically create a StrategyFactory at work once.

It was a good design, but it felt extremely wrong

[–] Supercrunchy@programming.dev 24 points 4 days ago (2 children)

And dependency injection!

Every class needs to use DI for calling other classes, even though we'll have anyway just a single implementation for all of them, and we won't be using this flexibility at all (not even for tests where it might be useful for mocking dependencies).

[–] VibeSurgeon@piefed.social 1 points 1 day ago

Why even use DI if you're not planning on faking dependencies for unit testing purposes

load more comments (1 replies)
load more comments (4 replies)
[–] mesamunefire@piefed.social 45 points 4 days ago (12 children)

Its the best/worst thing about OOP no matter what language.

We had a rule at work that if you are 3 levels or more down an inheritance tree, then you are too far. The cognitive load is just too much, plus everything stops making sense.

One level can be great (MVC all have great conventions, MCP as well). Two can be pushing it (Strategy pattern when you have physical devices and cant be connected all the time, Certain kinds of business logic that repeat hundreds of times, etc...) But even there you are kinda pushing it.

I need code that I can look at a month from now and know WTF is happening. And sometimes its better to have less DRY and more comprehension. Or maybe im just a forever mediocre dev and dont see the "light". I dunno.

[–] tiramichu@sh.itjust.works 20 points 4 days ago (5 children)

This is exactly how I feel too. A little bit of repetition is totally worth it, versus having inappropriate coupling, or code that jumps in and out of parent/child classes everywhere so you can hardly keep it in your head what's going on.

I freely accept that I AM a mediocre dev, but if that lends me to prefer code that is comprehensible and maintainable then I think being mediocre is doing my team a favour, honestly.

load more comments (5 replies)
[–] firelizzard@programming.dev 6 points 3 days ago (3 children)

When I first started using Go I bemoaned the lack of true inheritance and classes. Now I love it.

load more comments (3 replies)
load more comments (10 replies)
[–] Wirlocke@lemmy.blahaj.zone 5 points 2 days ago* (last edited 2 days ago)

I've moved away from Classes in general unless it truly makes code more streamlined. The main language I was taught in highschool was Java and it's just so liberating not needing to turn everything into an object.

But recently I've used a Class specifically for Inheritance. I'm making an extension to Pytorch and almost everything in Pytorch uses Tensors as a medium. I made a new kind of tensor that inherits the Tensor class to add specific restrictions on how it behaves. Because of this, this new tensor object can be used with any of the preexisting pytorch functions while also validating the results, reverting to a Tensor if it becomes invalid.

Even in this situation though, all my programming logic rests in it's own static functions, and the class contains functions that call the static version. The only actual logic the inherited object handles is validating the data.

Because of this, I feel like inheritance is most useful when you're inheriting someone else's code to make it compatible with their library. I don't think I'll ever inherit my own objects because that's how you end up with Java.

load more comments (6 replies)
[–] ZILtoid1991@lemmy.world 14 points 3 days ago

Entity Component System all the things!

I might write an XML ECS parser, as a joke. Practical? No! Probably even slower than the XML DOM? Yes! Funny? Yes!

[–] kibiz0r@midwest.social 48 points 4 days ago (1 children)

The venerable master Qc Na was walking with his student, Anton. Hoping to prompt the master into a discussion, Anton said "Master, I have heard that objects are a very good thing - is this true?" Qc Na looked pityingly at his student and replied, "Foolish pupil - objects are merely a poor man's closures."

Chastised, Anton took his leave from his master and returned to his cell, intent on studying closures. He carefully read the entire "Lambda: The Ultimate..." series of papers and its cousins, and implemented a small Scheme interpreter with a closure-based object system. He learned much, and looked forward to informing his master of his progress.

On his next walk with Qc Na, Anton attempted to impress his master by saying "Master, I have diligently studied the matter, and now understand that objects are truly a poor man's closures." Qc Na responded by hitting Anton with his stick, saying "When will you learn? Closures are a poor man's object." At that moment, Anton became enlightened.

[–] bleistift2@sopuli.xyz 12 points 3 days ago (1 children)

Should’ve listed the source. Bad commenter.

[–] kibiz0r@midwest.social 21 points 3 days ago

Source: https://wiki.c2.com/?ClosuresAndObjectsAreEquivalent

(Sorry dude, my time was limited by how long I could spare poopin in-between meetings.)

[–] tatterdemalion@programming.dev 77 points 4 days ago (13 children)

In over ten years of professional programming, I have never used inheritance without regretting it.

When it's the right tool, it's incredibly useful. When it's the wrong tool, and it often is, it racks up tech debt at an incredible rate.

[–] kalpol@lemmy.ca 3 points 2 days ago

This applies to firewall rules too

[–] AudaciousArmadillo@piefed.blahaj.zone 21 points 4 days ago (1 children)

It works great for technical constructs. E.g. A Button is a UI element. But for anything business logic related, yeah it'll suck.

[–] FooBarrington@lemmy.world 6 points 3 days ago

Even then there's rarely a good reason to use inheritance instead of composition.

[–] red_tomato@lemmy.world 19 points 4 days ago

And not once have I regretted removing inheritance.

load more comments (9 replies)
[–] RustyNova@lemmy.world 60 points 4 days ago* (last edited 4 days ago) (3 children)

I LOVE TRAITS. YOU'LL HAVE TO TAKE THEM FROM MY COLD DEAD HANDS

[Insert SpongeBob screaming meme]

load more comments (3 replies)
[–] jenesaisquoi@feddit.org 62 points 4 days ago

Composition over inheritance every day, all day

[–] Flipper@feddit.org 41 points 4 days ago (3 children)

Deref is for smart pointers and not for inheritance.

[–] Phoenix3875@lemmy.world 22 points 4 days ago

Let me introduce you to this horror story: Deref Polymorphism https://rust-unofficial.github.io/patterns/anti_patterns/deref.html

load more comments (2 replies)
[–] NigelFrobisher@aussie.zone 15 points 3 days ago* (last edited 3 days ago) (2 children)

Examples of inheritance hierarchies are always totally useless shit like this - what if a cow is an animal; What if a cow is a mammal, all mammals are animals and all mammals have a lactate() method?

[–] jason@discuss.online 11 points 3 days ago (1 children)

Yeah... Wheres the AbstactAnimalFactoryManager?

load more comments (1 replies)
[–] ulterno@programming.dev 10 points 3 days ago

Because any real life use that might come to mind would probably be related to some NDA protected database in a company.
And it is otherwise hard to think of anything at the spot, so just go with what the first example on the web-search came up with.

load more comments
view more: next ›