青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-341  評論-2670  文章-0  trackbacks-0
Tuesday, May 02, 2006
  How to make programming hard for yourself
原文地址:http://weblog.raganwald.com/2006/05/how-to-make-programming-hard-for.html
I posed a simple question: why do we have trouble admitting that programming is hard?

This generated a tempest in a teapot of comments. Most focused on the red herring of whether programming is an innate talent. That's actually irrelevant to the fundamental question.

Is programming actually hard?

The evidence is in that software development as an engineering practice is very hard. One person on reddit commented that he had worked for three successive game companies that shipped working software on time. Other than that comment, my own experience, the experience of everyone I've ever talked to, and the industry folklore is that software projects are almost always late, short of promised functionality, buggy, or all three.

Peek-a-boo!

Now I admit that lots of people think that this is a management problem. Their view is that the actual programming is quite tractable, it's just that getting people to work on the right things at the right time is the hard part of software development. This argument takes the same world view that the Egyptian engineers had about building pyramids: the labour is so easy that ignorant slaves can do it.

My view is that this is true for a certain class of programs. Most of these can be found in current business contexts. Quite honestly, most business applications are what I would call wide and shallow. There's a lot of work to be done, but little of it requires deep thinking. The challenges are around managing requirements and user expectations. These are hard problems, but they are not in the same class as, say, figuring out how to implement a fast join on two distributed hash tables.

I think that easy programming problems drive a lot of decisions about people and tools. If you perceive that a problem isn't very hard, why hire the 'cream' of the programming crop to solve it? And if you eschew the cream for a plain glass of 1% milk, won't you insist that the program be written in Blub instead of Python, Ruby, or Lisp?

This becomes a feedback loop. The 'B' players become hiring managers one day and they hire 'C' players. The 'C' players are asked to design applications, and they design things that they know how to build. This second effect is a huge lever pushing programming problems downwards in business.

Programs are written to solve problems posed by people, be they programmers, program managers, business analysts, or what-have-you. The difficulty of writing the programs is driven by the difficulty of the problems. The difficulty of the problems is limited by the imagination of the people posing the problems.

If your feedback loop is pushing difficulty downwards, the only problems you will have are the ones that can be solved by anyone who can pick up a Learn Blub in Twenty-One Days book.

Is this a problem?

Quite honestly, no. If what you want is a steady paycheque, and you can sleep at night knowing that your job might be outsourced one day, there's nothing wrong with chasing the easy work. It's no different than playing saxophone in a dance band at a wedding. Charlie Parker did it, you can do it.

But just because almost everybody does easy work doesn't mean there isn't hard work to be done. Hard problems are their own reward for some people, myself included (in my case I mean "hard for me," I know more than a few people that consider my hard problems to be recreational diversions). And some hard problems have lucrative consequences if you have a taste for starting companies.

Why it's hard to find hard problems

It's hard to find problems that are so challenging that you don't know how to solve them. It's especially hard if you also want a problem that can actually be solved. And it's very, very hard to find a hard problem that makes business sense, even in a startup. Most good startups solved the right problem rather than the hardest problem.

Very few people have the luxury of writing requirements for a program that they have no idea how to write, much less the imagination to see the results. Jump in your time machine and zoom back to 1980. Start asking people do sketch a word processor design on a napkin. How many people specify bit-mapped graphics and mouse-driven selection?

I compared programming to music and athletics. I suggested that programming is hard and the reason we don't see that is because we aren't competitive enough. That may be true, but now I sense a deeper challenge: in programming, we tend to pose questions for which we already know the answer.

In music, most people's reach far exceeds their grasp. It's quite easy to find pieces of music that are difficult or impossible for someone to play but nevertheless pleasing to that same person's ear.

If you are a wanna-be bassist and you listen to Jaco Pastorius' harmonics on "Portrait of Tracy," it is immediately obvious to you that you could be better and that being better is worthwhile. I leave it to your imagination to draw the same parallel to sports and athletics.

But in programming... we have a nasty habit of being very satisfied with the tools we already know. After all, they are good enough for all of the programs we have ever written. And, surprise surprise, they just might be good enough for all of the programs we will ever want to write.

How to make life hard for yourself

Most of us need outside forces to shake us up. Many bassists were shocked in 1976 when they heard Portrait of Tracy. Harmonics were used as accents here and there, but nobody dared to play an entire piece with harmonics as the main technique. This shook things up, and now playing harmonics is considered a basic skill on electric bass (although it's still fiendishly hard to play Portrait of Tracy!)

For all of my professed admiration of Ruby on rails, I personally don't think that easier and more productive CRUD application writing will shake things up. I personally care very much about writing applications in a tenth of the time, but using Rails is like listening to Jaco Pastorius. The real learning experience comes when you try to duplicate the feat.

If you want Rails to help you improve as a programmer, you need to look at the source code and figure out how to use Ruby to write Domain Specific Languages. Next, you'll have to write a few DSLs to become immersed in how programming changes when you can write DSLs. Now you're ready to look for a problem that is barely possible if you can solve it with a DSL.

Before you knew how to write your own languages, you probably couldn't design a program that couldn't be written without a DSL. Now you can.

This general template works surprisingly well: Learning things that force you to solve existing problems in new ways will help you find hard problems that can only be solved with the aid of your new techniques.

So when you're done learning how to write DSLs just like Rails, go ahead and write a web application using continuations as the basic metaphor. And don't forget to look under the hood and figure out how the framework makes continuations scale in a web context.

Come to think of it, figure out how to write continuation-based Rails applications that live on a Google-scaled grid and you might be headed towards a place where the inhabitants have no fear of hard.

I'll see you there.

Update: I found an early take of Jaco playing Portrait of Tracy (MP3). Nice.

Labels:

 
posted on 2009-05-09 06:55 陳梓瀚(vczh) 閱讀(3214) 評論(0)  編輯 收藏 引用 所屬分類: 啟示
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲高清自拍| 亚洲影音先锋| 欧美.com| 中日韩在线视频| 99热这里只有成人精品国产| 欧美理论电影在线播放| 一区二区三区**美女毛片| 亚洲美女中出| 国产欧美日韩视频一区二区| 久久综合色一综合色88| 狂野欧美一区| 亚洲一区三区电影在线观看| 亚洲一级黄色片| 一区二区亚洲精品| 亚洲欧洲日本国产| 国产精品网站在线| 免费一区二区三区| 欧美日韩1区| 久久久久久久网| 欧美好骚综合网| 欧美在线国产| 女女同性精品视频| 欧美一区二区三区播放老司机| 久久久久欧美| 亚洲在线一区二区三区| 久久国产毛片| 宅男噜噜噜66一区二区| 久久久久天天天天| 亚洲欧美久久| 欧美激情片在线观看| 欧美在线国产精品| 欧美理论电影在线播放| 久久综合网色—综合色88| 欧美视频日韩| 欧美福利视频网站| 国产亚洲电影| 亚洲另类视频| 亚洲国产成人久久| 香蕉久久精品日日躁夜夜躁| 亚洲人成免费| 久久久久久久久综合| 亚洲欧美国产日韩天堂区| 欧美成人按摩| 美日韩丰满少妇在线观看| 国产精品人成在线观看免费| 亚洲精品视频在线观看免费| 在线精品国精品国产尤物884a| 亚洲一区国产视频| 亚洲图片欧洲图片av| 欧美顶级大胆免费视频| 久久亚洲影院| 国产一级久久| 午夜日韩av| 欧美一区2区三区4区公司二百| 欧美日韩国产色站一区二区三区| 欧美激情国产日韩| 伊人成人开心激情综合网| 亚洲欧美综合v| 欧美一区日本一区韩国一区| 欧美午夜在线| 一本综合久久| 午夜精品一区二区三区在线| 国产精品盗摄久久久| 亚洲精品专区| 亚洲一区二区高清视频| 欧美日韩中文字幕在线视频| 99精品视频免费观看视频| 99香蕉国产精品偷在线观看| 欧美激情一区二区久久久| 亚洲黄色三级| 亚洲深夜福利网站| 国产精品成人观看视频国产奇米| 99综合精品| 亚洲欧美伊人| 国产一区二区三区在线免费观看| 午夜一区二区三区在线观看 | 美女尤物久久精品| 免费短视频成人日韩| 亚洲激情在线观看| 欧美日韩高清在线播放| 亚洲最新在线| 久久精品一区蜜桃臀影院| 影音先锋一区| 欧美不卡视频一区发布| 亚洲乱码视频| 欧美一区二区三区久久精品| 狠狠色综合播放一区二区| 免费欧美日韩| 正在播放亚洲| 美国成人毛片| 中文亚洲字幕| 黄色日韩网站| 欧美日韩成人在线| 亚洲欧美制服另类日韩| 欧美国产欧美亚洲国产日韩mv天天看完整| 亚洲精品乱码久久久久久日本蜜臀 | 久久米奇亚洲| 亚洲精品一区二区三区福利| 香蕉精品999视频一区二区| 在线欧美三区| 国产精品分类| 欧美高清在线一区二区| 亚洲无毛电影| 亚洲国产人成综合网站| 香蕉尹人综合在线观看| 亚洲国产精品久久久| 欧美天堂亚洲电影院在线观看| 欧美主播一区二区三区美女 久久精品人| 欧美激情一区二区三区不卡| 欧美在线观看视频一区二区| 亚洲人成在线播放| 韩国一区电影| 国产精品毛片大码女人| 欧美www在线| 欧美一区精品| 亚洲特黄一级片| 亚洲精品资源| 亚洲国产导航| 欧美jizz19hd性欧美| 久久久久.com| 欧美在线网址| 亚洲手机成人高清视频| 亚洲日本国产| 在线观看中文字幕不卡| 国产欧美日韩视频在线观看| 欧美日韩一区二区视频在线观看| 久久全球大尺度高清视频| 香蕉乱码成人久久天堂爱免费| 99精品热视频| 99热免费精品| 亚洲美女尤物影院| 亚洲精品一区二区在线观看| 亚洲国产一区二区三区高清| 欧美1级日本1级| 欧美高清在线视频观看不卡| 久久综合久久久久88| 久久久久久一区二区| 久久久高清一区二区三区| 欧美亚洲免费| 欧美在线观看视频一区二区| 午夜一级久久| 欧美一区二区三区四区在线观看地址 | 亚洲综合大片69999| 中文在线资源观看视频网站免费不卡| 91久久精品视频| 亚洲激情第一区| 日韩一二在线观看| 日韩亚洲欧美中文三级| 99pao成人国产永久免费视频| 亚洲精品午夜精品| 亚洲视频在线观看| 亚洲一区二区三区欧美| 午夜精品www| 久久日韩粉嫩一区二区三区 | 亚洲人成网站精品片在线观看| 亚洲丰满在线| 99re在线精品| 午夜视频在线观看一区二区| 午夜日本精品| 久久综合中文色婷婷| 欧美va亚洲va香蕉在线| 亚洲精品国产精品乱码不99 | 久久久综合免费视频| 麻豆9191精品国产| 亚洲国产精品精华液2区45| 亚洲乱亚洲高清| 亚洲综合清纯丝袜自拍| 久久久久久伊人| 欧美日韩你懂的| 国产一区二区久久精品| 亚洲精品乱码| 欧美一级专区| 欧美电影免费| 亚洲一区国产一区| 免费观看欧美在线视频的网站| 欧美理论片在线观看| 国产精品主播| 亚洲欧洲日本mm| 午夜精品福利一区二区蜜股av| 久久午夜精品一区二区| 亚洲精品乱码久久久久| 欧美一区二区精美| 欧美日韩1区| 国产综合第一页| 亚洲一区二区三区777| 榴莲视频成人在线观看| 一卡二卡3卡四卡高清精品视频| 欧美中文在线免费| 欧美另类视频在线| 黄色成人在线| 午夜天堂精品久久久久| 亚洲国产小视频在线观看| 欧美在线视频二区| 欧美日韩亚洲三区| 亚洲黄色天堂| 免费在线亚洲欧美| 欧美一级视频精品观看| 国产精品成人aaaaa网站| 亚洲激情网址| 麻豆成人综合网|