this post was submitted on 19 Dec 2024
19 points (100.0% liked)

Programming

13425 readers
1 users here now

All things programming and coding related. Subcommunity of Technology.


This community's icon was made by Aaron Schneider, under the CC-BY-NC-SA 4.0 license.

founded 2 years ago
MODERATORS
 

Refactoring gets really bad reviews, but from where I'm sitting as a hobby programmer in relative ignorance it seems like it should be easier, because you could potentially reuse a lot of code. Can someone break it down for me?

I'm thinking of a situation where the code is ugly but still legible here. I completely understand that actual reverse engineering is harder than coding on a blank slate.

you are viewing a single comment's thread
view the rest of the comments
[–] frezik@midwest.social 29 points 1 month ago (3 children)

Rebuild from scratch gets a bad reputation sometimes because it's the go-to response of a junior programmer with a little experience. They know the system could be done better, and it seems like the fastest way to get there is to throw out everything.

What often happens next is the realization that the existing system was handling far more edge cases than it initially appears. You often discover these edge cases when the new system is deployed and someone complains about their use case breaking. As you fix each one, the new system starts to look worse than the old while supporting half its features.

This often leads people to prefer refactors rather than rewrites. Those can take a lot longer than expected and never quite shed what made the old system bad. Budget cuts can leave the whole project in a halfway state that's worse than if it was left alone.

There are no easy answers, and the industry has not solved this problem.

[–] Max_P@lemmy.max-p.me 8 points 1 month ago (1 children)

What often happens next is the realization that the existing system was handling far more edge cases than it initially appears. You often discover these edge cases when the new system is deployed and someone complains about their use case breaking.

The reverse is also sometimes true and it's when a rewrite is justifyable.

I've worked with many systems that piled up a ton of edge cases handling for things that are no longer possible, it makes the code way harder to follow than it should.

I've had successful rewrites that used 10x+ less the amount of code, for more features and significantly more reliable. And completely eliminated many of the edge cases by design.

[–] CanadaPlus@lemmy.sdf.org 1 points 1 month ago

Yes, there's usually a niche case, right? That's why cargo cult engineering comes nowhere near the real thing.

[–] t3rmit3 5 points 1 month ago (1 children)

My current team has had a great solution to this, which is to re-build in parallel. Build the new system alongside the old one, including the reporting and integrations. You'll find the edge cases pretty quickly.

[–] CanadaPlus@lemmy.sdf.org 2 points 1 month ago

So how is that different from refactoring?

[–] CanadaPlus@lemmy.sdf.org 1 points 1 month ago

My sense from all these answers are that the guys in programmer humour communities that hate refactoring are probably inexperienced junior programmers.