| 
	
	
	Posted by Sam on Mar 03, 2008 at 12:00 AM UTC - 5 hrs
 
		I don't like to have too many microposts on this blog, so I've decided to save them up and start
a Programming Quotables series .  The idea is that I'll post quotes about programming that have one or more of the 
following attributes:
 
I find funnyI find asinineI find insightfully trueAnd stand on their own, with little to no comment needed 
Here's the third in that series.  I hope you enjoy them as much as I did: 
And launch as soon as you can, so you start learning from users what you should have been making.
...
 So when you look at something like Reddit and think "I wish I could think of an idea like that," remember: ideas like that are all around you. But you ignore them because they look wrong.
 ...
 Here it is: I like to find (a) simple solutions (b) to overlooked problems (c) that actually need to be solved, and (d) deliver them as informally as possible, (e) starting with a very crude version 1, then (f) iterating rapidly.
 
I've learned that developers who spend most of their time thinking about their project, rather than grueling over mundane tasks and busy work, do better. Their projects are stronger, easier to develop, and organized beautifully. These developers spend much of their free time doing things like evangelizing the MVC paradigm, reading non-fiction, and dining out. Their counterparts - those who fear the rush of extra web traffic, faulty error handling, and accidently falling into while() loops that never end - live in fear of their creation, dreading the day when it will turn on the parent.
Hey! Why don't you make your life easier and subscribe to the full post
		or short blurb RSS feed?  I'm so confident you'll love my smelly pasta plate 
		wisdom that I'm offering a no-strings-attached, lifetime money back guarantee!
 
 
	Posted by Sam on Apr 16, 2008 at 12:00 AM UTC - 5 hrs
 
		I don't like to have too many microposts on this blog, so I've decided to save them up and start
a Programming Quotables series .  The idea is that I'll post quotes about programming that have one or more of the 
following attributes:
 
I find funnyI find asinineI find insightfully trueAnd stand on their own, with little to no comment needed 
Here's the fifth in that series.  I hope you enjoy them as much as I did: 
At this stage, if you've heard of Rails and you haven't converted, it's entirely possible that you never will. It's also entirely possible that anybody who still isn't even taking Rails seriously by this point might just be some kind of idiot....
 Every programmer should also read Chad Fowler's "My Job Went To India" book, where he explains that as larger and larger numbers of programmers adopt a particular skill, that skill becomes more and more a commodity. Rails development becoming a commodity is really not in the economic interest of any Rails developer. This is especially the case because programming skill is very difficult to measure, which - according to the same economics which govern lemons and used-car markets - means that the average price of programmers in any given market is more a reflection of the worst programmers in that market than the best. An influx of programmers drives your rates down, and an influx of incompetent programmers drives your rates way the fuck down.
 
Instead, I want to talk about my first attempt at solving the puzzle, which was an utter failure. A glorious, spectacular failure. Perhaps the single most impressive failure of my career. Failures are often much more interesting than successes, but for some unfathomable reason, people are often reluctant to discuss them.
 
And this is just the beginning of the ceremony:
 
Me: read file blah.txt and display it on system outputJava: How should I name the class?
 Me: Test
 Java: How should I handle errors?
 Me: I don't care right now, I just need to display that data to system output
 Java: But I need to know this, what if something unexpected happens?!
 Me: I just want to make a prototype damn it!
 Java: Sorry, can't do it.
 Me: Ok, do nothing on error.
 Java: And which implementation of Stream class should I use for reading?
 
 
Everyone knows that diversification is the key to managing financial risk, but few people seem to apply this principal to their professional careers. Most developer shops are relatively limited when it comes to the number of technologies and problem domains they deal with. If you want to diversify your resume without job hopping every year, then it makes sense to actively seek out technology experiences that are different from the ones you use in your day job.
 
Neal Ford and others have been talking about the distinction between dynamic and static typing as being incorrect. The real question is between essence and ceremony. Java is a ceremonious language because it needs you to do several dances to the rain gods to declare even the simplest form of method. In an essential language you will say what you need to say, but nothing else. This is one of the reasons dynamic languages and type inferenced static languages sometimes look quite alike - it's the absence of ceremony that people react to.
 
	Posted by Sam on Jun 26, 2008 at 12:00 AM UTC - 5 hrs
 
		I don't like to have too many microposts on this blog, so I've decided to save them up and start
a Programming Quotables series .  The idea is that I'll post quotes about programming that have one or more of the 
following attributes:
 
I find funnyI find asinineI find insightfully trueAnd stand on their own, with little to no comment needed 
Here's the seventh in that series.  I hope you enjoy them as much as I did: 
In the software industry, we've been chasing quality for years.  The interesting thing is there are a number of things that work.  Design by Contract works.  Test Driven Development works.  So do Clean Room, code inspections and the use of higher-level languages. 
 All of these techniques have been shown to increase quality.  And, if we look closely we can see why: all of them force us to reflect on our code.
 
 That's the magic, and it's why unit testing works also.  When you write unit tests, TDD-style or after your development, you scrutinize, you think, and often you prevent problems without even encountering a test failure.
 
Perhaps I've made it seem like I'm on the side of the pirates. Just to make it clear that I'm not sailing under the jolly roger: In my own view, piracy is wrong. It's wrong even when the people making and selling the game are senseless, self-destructive fools. It's wrong even if the game sucks. It's wrong if you're broke. It's wrong even if "you weren't going to buy it anyway." It's wrong and I don't do it, ever.
 It is not my intention to preach at pirates and get them to change their habits. I'm not anyone's mum, and it's not my place to tell people how to act. I actually think that having lots of people repent of piracy right now would be horrible. The managers would conclude their monstrous policies were working, and we'd get a double helping of the same, forever after, in every game they put out.
 
Regardless of the approach taken, I definitely no longer believe that sprocs should play any significant role in any application. The current mandate in the software industry is to strive to lower costs by increasing developer productivity and ORM's clearly help to do this by eliminating the need to write and maintain countless simple CRUD sprocs.
 It's definitely time for all of us .NET developers to abandon our convention sproc wisdom and start playing catch-up with the rest of the industry when it comes to using ORM's.
 
I am not at the mercy of some big up-front UML diagrams or "non-agile" models grounded in getting something wrong in its entirety and very thoroughly before you take measures to fix it (or even begin to detect it).
 
	Posted by Sam on Aug 27, 2008 at 12:00 AM UTC - 5 hrs
 
		This is the "I was so tired this morning I put shaving gel on my toothbrush" edition of Programming Quotables .
  
If you don't know - I don't like to have too many microposts on this blog, so save them up as I run across them, and every once in a while I'll post a few of them.  The idea is to post quotes about programming that have one or more of the 
following attributes:
 
I find funnyI find asinineI find insightfully trueAnd stand on their own, with little to no comment needed 
It's up to you decide which category they fall in, if you care to. Anyway, here we go:
			More... 
		
	
So how do we keep the design from rotting? How do we make sure we can migrate the design as the system changes? Simple. Tests.
 When you have a suite of tests that covers >90% of the code in the system, you are not afraid to make changes. Every time you make a little change you run those tests, and you know that you have not broken anything. This gives you the confidence to make the next change, and the next, and the next. It gives you the confidence to change the design!
 
Software development processes have been undergoing evolution since the beginning and lately the whole agile process seems to be taking over. Whatever the process, many companies are finding more success in breaking down large projects into tiny goal-driven chunks, sometimes lasting as little as a week.
 This same principles can be applied to ourselves at both large and fine-grained levels. It is definitely good and desirable to have the overall vision of our project in mind, but  this doesn't often help us get the work done. Some of my most productive days are when I break down a huge task into tiny subtasks and set a goal for each one ("I will have this done by 11am today, then I will wrap up this other small one by 4pm.")
 
Someone decided to trash the one part of Windows that was usable? The file system is no longer usable. The registry is not usable. This program listing was one sane place but now it is all crapped up.
 But that is just the start of the crap.
 
 
	Posted by Sam on Dec 12, 2008 at 12:00 AM UTC - 5 hrs
 
		This is the "z0mg it's Christmastime and have I really left so many of my goals for the year incomplete?!" edition of Programming Quotables .
  
If you don't know - I don't like to have too many microposts on this blog (me on twitter for that ), so save them up as I run across them, and every once in a while I'll post a few of them.  The idea is to post quotes about programming that have one or more of the 
following attributes:
 
I find funnyI find asinineI find insightfully trueAnd stand on their own, with little to no comment needed 
It's up to you decide which category they fall in, if you care to. Anyway, here we go: 
			More... 
		
	
My first job primarily used Cold Fusion. When I joined AOL Time Warner I gave up Cold Fusion for PHP. When I joined IAG I gave up PHP for C#. And so on. As you can see, I've never been too tied to a language. I've always been most interested in learning and growing. I love jobs that help me improve my skills....
 I prefer jobs that allow me to learn new things. Think of it as job security -- I shouldn't ever be out-of-date when it comes to technology experience. Think of it as an investment -- everything I learn creates a broader range of experience that I can leverage for future projects or jobs. Think of it as experimenting -- by trying many different solutions I may find ways to combine them and innovate.
 
Programming in C for the first time seems to be a chore. There are many details about your Code you need to keep track of. And C doesn't even lend you much of a hand when programming. There are no iterators, memory management is done manually, and handling strings correctly is akin to walking through a minefield with a hood over your head. While on fire. And being chased by a pack of wild dogs.
 
But then the question still stays: "what should one learn next?". Algorithms, data structures, complexity, math... Learn the core abstracts, ideas, and skills that are language independent, and that transfer from one syntax to another. Learn the ability to learn. When a new opportunity with new technology comes along, you should be able to get over the learning curve fairly quickly.
...
 So lets drop this obsession with learning to say "hello world" (or some more complicated version of essentially the same) in every programming language one can name. Lets also drop the idea of finding "one language to rule them all; and retire". Once we put the Science back in Computer Science, it wouldn't matter which language you'll end up using.
 
	Posted by Sam on Apr 09, 2009 at 12:00 AM UTC - 5 hrs
 
		This is the "I'm trying my hardest to be late to that meeting that spans lunch where they don't serve anything to tide you over" 
edition of Programming Quotables .
  
If you don't know - I don't like to have too many microposts on this blog (I'm on twitter for that ), so save them up as I run across them, and every once in a while I'll post a few of them.  The idea is to post quotes about programming that have one or more of the 
following attributes:
 
I find funnyI find asinineI find insightfully trueAnd stand on their own, with little to no comment needed 
It's up to you decide which category they fall in, if you care to. Anyway, here we go:
			More... 
		
This is my Quality is Dead hypothesis: a pleasing level of quality for end users has become too hard to achieve while demand for it has simultaneously evaporated and penalties for not achieving it are weak. 
The entropy caused by mindboggling change and innovation in computing has reached a point where it is extremely 
expensive to use traditional development and testing methods to create reasonably good products and get a 
reasonable return on investment. Meanwhile, user expectations of quality have been beaten out of them. 
When I say quality is dead, I don't mean that it's dying, or that it's under threat. 
What I mean is that we have collectively- and rationally- ceased to expect that software normally works 
	well, even under normal conditions. Furthermore, there is very little any one user can do about it.
 
	I haven't figured out yet exactly how I'm going to use this, but it'll probably look like this: one new beat per day, one new track per weekend. One new app per month, one milestone on the app per week. The goal is not to establish a far-off goal and find a way to hit it, but to establish a series of tiny, immediate goals that keep you forever moving forward. Aristotle argued that virtue was mostly a matter of having good habits; Lao-Tzu tells us that the voyage of a million miles starts with a single step. So the key is to get moving and keep moving.
 
	But in computer games, it's impossible to have an equal match. It's humans versus machines. One side has an advantage of being able to perform a billion calculations per second, and the other has the massively parallel human brain.
 Any parity here is an illusion, and it's that illusion that we seek to improve and maintain via the introduction of intelligent mistakes and artificial stupidity.
 
 The computer has to throw the game in order to make it fun. When you beat the computer, it's an illusion. The computer let you win. We just want it to let you win in a way that feels good.
 
 
	Posted by Sam on Jul 02, 2009 at 12:00 AM UTC - 5 hrs
 
		This is the "my lawn needs more water and my wife disagrees" 
edition of Programming Quotables .
  
If you don't know - I don't like to have too many microposts on this blog 
(I'm on twitter for that ), so I save them up as I run across them, 
and every once in a while I'll post a few of them.  The idea is to post quotes about programming that have 
one or more of the following attributes:
 
I find funnyI find asinineI find insightfully trueAnd stand on their own, with little to no comment needed 
It's up to you decide which category they fall in, if you care to. Anyway, here we go: 
			More... 
		
"Is it still Scrum if we use a kanban board instead of a burndown?"
 "Is it still XP if we don't break things down into tasks but just use stories?"
 
 Who the hell cares???
 
	If we hope to excite people with the power of programming, we will do it with big ideas, not the placement of periods, spaces, keywords, and braces. We need to find ways so that students can solve problems and write programs by understanding the ideas behind them, using tools that get in the way as little as possible. No junk allowed. That may be through simpler languages, better libraries, or something else that I haven't learned about yet.
 
It's entirely possible that there's a detente to be reached between the copyists and the copyright holders: a set of rules that only try to encompass "culture" and not "industry." But the only way to bring copyists to the table is to stop insisting that all unauthorized copying is theft and a crime and wrong. People who know that copying is simple, good, and beneficial hear that and assume that you're either talking nonsense or that you're talking about someone else. 
 
Your comments, as always, are welcome.
 
	Posted by Sam on Jan 28, 2008 at 06:46 AM UTC - 5 hrs
 
		I don't like to have too many microposts on this blog, so I've decided to save them up and start
a Programming Quotables series .  The idea is that I'll post quotes about programming that have one or more of the 
following attributes:
 
I find funnyI find asinineI find insightfully trueAnd stand on their own, with little to no comment needed 
Here's the second in that series.  I hope you enjoy them as much as I did:
			More... 
		
Now we can see that although each language provides abstraction mechanisms, and lets you build new abstractions with the mechanism, new kinds of abstractions give us new ways to express relationships. These things can be abused, of course, but nothing can save you from this: If you don't let your Architect play with Domain-Specific Languages, what is to stop them from configuring everything in your application with XML?
  (Note the acronym tag)
 
The earlier Ages were times when people were unsure how best to deliver business value through software development. They piled process on top of process, hoping that by finding and perfecting the right process they could ensure timely delivery of valuable software in a predictable way. When it didn't work, they logically assumed the best approach would be to do even more of the stuff that wasn't working, and to monitor the stuff very tightly with high-ceremony process controls.
 
Then again, all one has to do to out-perform a traditional development team is Not Suck. It doesn't even require agile development methods. Obviously, to Not Suck is a great step forward. But surely it isn't your ultimate professional goal!
 
Language expertise is fine, but it isn't the most valuable thing out there. If someone programs conscientiously, I can work with them. I have a lot of respect for people who write solid code despite not having completely up to date language knowledge. Language knowledge is easy: you read, you think, you try.  And, you can catch up.  Conscientiousness, though, is the thing that really matters.  Next to it, language expertise is easy.
 
It's obvious now, though, isn't it? A design pattern isn't a feature. A Factory isn't a feature, nor is a Delegate nor a Proxy nor a Bridge. They "enable" features in a very loose sense, by providing nice boxes to hold the features in. But boxes and bags and shelves take space. And design patterns - at least most of the patterns in the "Gang of Four" book - make code bases get bigger. Tragically, the only GoF pattern that can help code get smaller (Interpreter) is utterly ignored by programmers who otherwise have the names of Design Patterns tatooed on their various body parts.
 
Steve Yegge, Code's Worst Enemy  (Really, you should read the whole thing.  It's important.)
			Last modified on Feb 10, 2008 at 12:38 PM UTC - 5 hrs
 
 
	Posted by Sam on Dec 19, 2007 at 09:26 AM UTC - 5 hrs
 
		A while back I started a Twitter account with the idea of using it as a tumblelog 
for quotes about software that I wanted to highlight.  Unfortunately, the small limit on the number of 
characters Twitter enforces didn't allow me to post entire quotes, much less attribute them.   
 
Likewise, I don't like to have too many microposts on this blog, so I've decided to save them up and start
a Quotables series.  The idea is that I'll post quotes about programming that have one or more of the 
following attributes:
 
I find funnyI find asinineI find insightfully trueAnd stand on their own, with little to no comment needed 
Here's the first in that series.  I hope you enjoy them as much as I did:
			More... 
		
	The odds of finding truly beautiful code in most production systems seem to be on par with 
	the odds of finding a well-read copy of IEEE Transactions on Software Engineering in Paris Hilton's 
	apartment.
 If you can't make a decent web page in .NET you shouldn't be in the business. 
 -Commenter at Reddit or Digg (I can't seem to find it anymore, and I just copied the quote a couple of months ago)
 You have to take responsibility for teaching yourself, and that is a far greater responsibility than skimming a book and fooling around copying and pasting code from web pages. You can't just take basic or even sketchy knowledge of how to program in one language and "transfer" it to another language. You think you can just "pick it up," but in reality you can't, and neither can I.
 But the fatal flaw in the GoF book was that they included recipes. 
And many people thought they were the best part. Even now, you see books on Java design patterns 
that blindly mimic the structure of the examples in the GoF book (even though Java has some better 
mechanisms, like interfaces vs. pure virtual classes). Recipes bad. Because they suggest more than just a way to name common things. They imply (and put in you face) implementation details.
 Because of meta-programming, many of the design patterns in the GoF book (especially the structural ones) have much simpler, cleaner implementations. Yet if you come from a weaker language, your first impulse is to implement solutions just as you would from the recipe.
 At some point, you have to have the guts to go against the grain. Just because a "best practice" works for someone else at some other company doesn't necessarily make it a "best practice" for you and your company. A "proven methodology" isn't necessarily going to be a "proven methodology" for you. Have the guts to challenge the status quo. If it's not making you more efficient, it's likely hindering you. Refactor it out.
 
 | 
 
				Me	
				
				  
 
 
 
		
		 |