For further actions, you may consider blocking this person and/or reporting abuse
See why 4M developers consider Sentry, “not bad.”
Fixing code doesn’t have to be the worst part of your day. Learn how Sentry can help.
Read next
data:image/s3,"s3://crabby-images/09688/0968838ae7ac0aeef7dd645192fedac276bd2599" alt="mikeyoung44 profile image"
Small AI Models Can Now Reason Like Big Ones: New Training Method Breakthrough
Mike Young -
data:image/s3,"s3://crabby-images/09688/0968838ae7ac0aeef7dd645192fedac276bd2599" alt="mikeyoung44 profile image"
AI Breakthrough: New Multi-Scale Model Identifies Object Parts with Unprecedented Accuracy
Mike Young -
data:image/s3,"s3://crabby-images/3c6c0/3c6c04480875000558fccf225a5cd6341908fcc7" alt="ashucommits profile image"
The Crucial Role of Funding in Open Source Development
ashu-commits -
data:image/s3,"s3://crabby-images/e9342/e9342e03243eea086dee2f67b4868e9870f7dd17" alt="godofgeeks profile image"
OOP in Python
Aviral Srivastava -
Top comments (5)
If there is little evidence that it is the correct abstraction.
Sometimes two similar things are more similar now than they logically will be in the future. Creating an abstraction from the pair of similar pieces of code can get you headed down the wrong path.
BUT YOU CAN MAKE EVERYTHING A FACTORY! /java
The moment you use a framework and create a "Base" anything. For instance, with Spring why would you need a BaseController...it comes out of the box! If it's so you can implement cross cutting concerns, like logging and analytics...try AOP instead.
Almost immediately.
You should only introduce abstractions if you are absolutely sure they are the right ones. Otherwise you are better off writing the code twice.
Its a good idea to discuss abstractions with your teammates before Introducing them to the codebase.
Uncle Bob has put this into a nice perspective, even if in a different context: when two things evolve at a different pace.
If you have two things that look quite similar, but might change at different speed into different directions, it will be harder to take the step back in future and see, that these two need to be separated again. It is more likely that you will add complexity to handle this instead.
This is rather about estimating and evaluating what might happen in the future and to be prepared for that, as in most architectural decisions, where there is less right and wrong and more compromise between goals that can't be achieved at the same time (easy understanding, simplicity, speed, ability to change, reuse etc.)