Hacker Newsnew | past | comments | ask | show | jobs | submitlogin

Just a note : I've noticed that when working with management, they often have issues "grokking" the issues they are asking for you to solve.

By offering an imprefect, quick solution, it lets them understand the issue and readjust their needs in consequence - and often, the quick imprefect solution is good enough/enough work to show it's a bad idea and to move on.

When starting project I have 2 steps : vomitting and touching up. You puke out a solution(minimum viable product), without thought about optimisation. When that exists, you change hats and optimise. Works wonders.



Except the reality often looks like:

> You puke out a solution(minimum viable product), without thought about optimisation.

And that's where it ends, because unless your employer vastly overhired, there's already a dozen (or more...) of tasks in the backlog just waiting for you to vomit them out as well.

After a year or two of working like this, you have a mountain of technical debt and no time work on it all. The entire system slowly disintegrates under its own weight.

There needs to be a balance between fast and correct, and it is only up to the developer to resist the pressure from management to work fast (at the expense of correctness). I would go as far as to say that it is one of your main non-technical duties as a developer to resist and manage this pressure as best as you can.

Maybe you're a genius who can analyze problems and implement solutions both fast AND correctly, but that is very rare.

The truth is that complex problem solutions can have complex, messy implementations. They can also have simple, beautiful implementations. Or anything in between. But what they almost invariably require is complex investigations... which take time to conduct properly.

Most (not all!) "fast" programmers I've worked with over the last 15 years produced output of questionable quality, often stemming from the "what you don't know you don't know" part of the knowledge pie chart, instead of some deeply thought out cost/benefit calculation.


IMO if the code sticks around long enough to disintegrate under its own weight, than that code was a rousing success!

"Resisting management" is almost always a horrible idea. Code is only useful when it provides a solution at the right time for the right price. If not, it is no longer useful and the world moves on.

Overall quality is nothing more than a reflection of business maturity. Like a mighty old tree with a great big trunk. It has had time to grow strong and majestic.

Most businesses don't live longer than 5 years. Most products and solutions are temporary fixes or ideas that don't last longer than a few months. Investing huge amounts of time and resources into those things is a recipe for disaster.


I think this depends strongly on your companies bussines area. If you have BB with companies really relying on your product and long running contracts, the customer wants what he paid for. Including support for the heap of defects. Worse if you got a reputation to uphold and also want to keep your BB costumers. You can quickly become deadlocked in maintaining your old quick shots, unable to move anywhere. I think it is hard to make general rules without specific market context.


Agreed. It's worth noting in the context you describe, you have valuable customers who have paid for long-running contracts. This warrants the ongoing time and investment in quality.

Most of the time, this is not the case.

My experience is of course mainly at startups, so I am most familiar with the shorter time-horizon, lower-cost initiatives.


> After a year or two of working like this, you have a mountain of technical debt

What's the reason to stay longer than 2 years? From what I see it's x10 times harder to get raise inside an organisation vs when changing it.

Probably, the reason is that companies adapted to employees getting rise and leaving soon. So a raise inside org is more a calibration for those highly underrated on entry ones than some real compensation for any experience.


IME fast programmers are great at externalizing their QA


And in mine, slow ones are often even better.

As much as we want to pretend that slowness correlates with attention to detail and quality of code, this is often only rationalization. Some people are perfectionists (in a bad way) and overcomplicate things that don't really matter to the end result, others have analysis paralysis and take too long to make decisions, making the code suffer, and others are just not that great and generate the same result as a faster developer at best. There are surely good but slow developers, but it's not as common as "internet common sense" paints it.


And disavowing their role in cause and effect. They play chicken with other developers, who end I sacrificing their own productivity to fix the issues. Bad managers see this productivity gap and reward the hack instead of punishing him.


The customer is always right about what they want.


But not necessarily about the solution they envision. Case in point: I worked with one customer who wanted to add a search box at the top of a list to search through ~50 elements. I showed him the standard browser search with ^F and he was delighted. Saved us a day of work.

They know their problem, you should figure out a solution.


> You puke out a solution(minimum viable product), without thought about optimisation. When that exists, you change hats and optimise.

So, you first implement bubble sort, and when that exists you scrap everything and implement quick sort.

Not sure if that'd be my preferred way of doing it.


I'm not a programmer. Could you estimate how much more comple/ how much longer it takes to implement quicksort?

Otherwise, my point is that this is often good because, when begining projects, management can lack perspective of how the project will actually get done. Having a "draft" version that is planned to be scrapped lets you decide where optimisation is necessary, see future bottlenecks more clearly, and thus you can set a better foundation for the actual project.

And if it's possible to make that version say 20x or 100x faster than a V1 of the final project, I think the insight gained is worth it.

Edit0: Sometimes you even learn that it's a bad idea at all - better to learn that quickly and start over.

Edit1: After a cursory read, it seems quicksort it as simple as it gets in execution, being very few lines of code. But I'm also reading that in production code, quicksort is just part of the custom sorting algorithm that should be written for the specific database it's being applied to. If that's the case - using quicksort is the vomitting. i get what you mean "without thought about optimization"...some optimization expected, but heavily weighted towards rapid execution and low complexity.


Sorry, I'll try to elaborate. What you described can work _sometimes_. If a particular feature is isolated from everything else, and if the optimization step is a couple of tweaks that can be done later on, sure.

However, the dangers of applying this tactic indiscriminately are:

1. Version 2 is postponed, and a lot of dependencies on Version 1 appear. After a while, moving from V1 to V2 becomes a herculean effort, you have to do heart surgery while the heart is beating.

2. There may be nothing in common between V1 and V2. Implementing bubble sort gives you no insight into quick sort; you literally have to start from scratch. This may be acceptable if there's urgency in delivering a solution as fast as possible, but in my experience most companies have the time to do it right but choose not to (or don't know any better). Also from experience, it would be nice if people understood that it may not be so simple to "just optimize it later", and that it would be better to spend a little bit more time in the beginning of a project to consider how to foundation of the project will scale in the future.




Consider applying for YC's Winter 2026 batch! Applications are open till Nov 10

Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: