TE
TechEcho
Home24h TopNewestBestAskShowJobs
GitHubTwitter
Home

TechEcho

A tech news platform built with Next.js, providing global tech news and discussions.

GitHubTwitter

Home

HomeNewestBestAskShowJobs

Resources

HackerNews APIOriginal HackerNewsNext.js

© 2025 TechEcho. All rights reserved.

Yes, But What Have You Done?

105 pointsby mshafrirabout 15 years ago

11 comments

gfodorabout 15 years ago
For years, over-thinking, over-engineering, and over-planning struck me as a problem in software engineering. Agile and iterative development sprung up in reaction to this.<p>However, I think the programming world has now oscillated to far in the other direction. There seems to be a widespread perception that having a 5 minute discussion, hacking some shit out, and releasing it is the best way to do things.<p>The "fuck planning, just ship it" dogma is just as perilous as the "don't ship it until it's ready, even if that means it will take years" dogma.<p>Instead, try to ask yourself the following questions before you hit the "deploy" button:<p>- Will I be embarrassed by the quality of this software?<p>- In user tests, has it shown itself to be useful enough?<p>- In user tests, has it shown itself to be confusing?<p>- Will future features be undermined by releasing this version? (For example, will the UI have to change dramatically to add certain must-have features I have yet to implement?)<p>As is the case in most things, the best advice can be summed up in one word: think.
评论 #1335078 未加载
评论 #1335796 未加载
j_bakerabout 15 years ago
I agree with this part:<p>"I believe there's a healthy balance all programmers need to establish, somewhere between...<p>1. Locking yourself away in a private office and having an intimate dialog with a compiler about your program.<p>2. Getting out in public and having an open dialog with other human beings about your program."<p>...but I'm not really sure I see the point of the rest of it. Jeff points out that most programmers are introverts (which I have my doubts about, but that's a different matter) and that #1 is no problem. So then why is he spending most of his time talking about upping the amount of time we spend on #1?<p>Personally, I'm of the opinion that we as programmers <i>do</i> too much. It's fashionable to complain about people who talk and think more than they do, but we forget that it's also important to take time to reflect on what we've done so we can learn to do it better. Whether that be in the form of group discussion or introspection is another matter, but the moral of the story is not to <i>do</i> too much.
agentultraabout 15 years ago
... but if you do it right now without thinking about it, you might just run into one of many hazards:<p>1. someone else has already done it. 2. you end up doing it poorly. 3. you end up wasting time on something nobody cares about. 4. you could have been doing something else.
yasonabout 15 years ago
Designing is aiming, not locking down on a target.<p>In comparison to shooting at random, when designing you still don't know if you're going to hit the target but you've at least made it clear what and where you think the target is.<p>Further, design and planning is a courtesy to the users. If you're churning out prototypes and basically shooting at random then you have effectively demoted your potential users into mere filters to help you see what will hit the wall and what will not.<p>I don't mean to defend waterfall design or any of that ancient crap. You can't design software like that but <i>you must design it somehow</i>.<p>Prototyping—seeing yourself what works and thinking about what would Joe or Jane want to use the software for—is a great way to design. But prototypes aren't real products. They're not even eggs of real products: prototypes are really meant to be thrown away.<p>It is not imperative to spend years with design committees just as you don't have to "do it fucking now" either. Release something small but make sure it's something you've truly designed. If you just throw <i>anything</i> that merely compiles or runs onto the market then "I'll fucking leave now" (and won't come back).
mshafrirabout 15 years ago
Note: Forgot to include in the title that this post is from 2007.
评论 #1334925 未加载
iccoabout 15 years ago
I think this is more useful for people trying to enter the industry. Startups looking to hire generally look more at what you have done, what code have you written. My last job interview asked to see my github / or any code examples. So this article to me just says "hey, you claim to be a coder. Let me see code that you took to write. I don't care if it's perfect, just let me see that you are constantly trying to solve problems and are interested in coding."
jisterabout 15 years ago
I very much agree with this line in the first comment:<p>"3. Getting out in public and having an open dialog with other human beings about something that does <i>NOT</i> involve programming."<p>To avoid burnt out that is.
jonpaulabout 15 years ago
An oldie but a goodie none the less. This kind of reminds me of Jason Fried's quote "inspiration is perishable"... which I interpret to mean: act now. Also, I'm also reminded of that Youtube video of the lady with cancer... "don't waste f*cking time..." she says. Very inspirational. <a href="http://www.youtube.com/watch?v=gePQuE-7s8c" rel="nofollow">http://www.youtube.com/watch?v=gePQuE-7s8c</a>
评论 #1335650 未加载
erikstarckabout 15 years ago
Always Be Coding?
BrandonMabout 15 years ago
Thank you Thank you Thank you. I think it's time for another break from Hacker News :)
PG-13about 15 years ago
<i>The last thing the world needs is more pundits. Pundits only add ephemeral commentary to the world instead of anything concrete and real. They don't materially participate in the construction of any lasting artifacts; instead, they passively observe other people's work and offer a neverending babbling brook of opinions, criticism, and witty turns of phrase. It's pathetic.</i><p>Take heed of this, Hacker News. Nothing annoys a real entrepreneur more than a wantrepreneur pundit.