Programming is hard by Stephan Schmidt

Ever more complex software stacks

In the last 30 years the software stack has grown from year to year. When I started coding in Z80 machine code, there was no software stack. Just the programmer and some hardware registers. No other software involved. Direct access to the machine. From there software stacks grew, to compilers and libraries. With Java the stack grew to JIT compilers, virtual machines, garbage collectors, byte code compilers and plattforms. To close the gap between the machine and the customers requirements one solution for many seems to be to grow the software stack even further. With MDA and containers the software stack grows to unprecented complexity. From PIM with transformations to PSM to a Java EE container, with AOP and compilers to Java, with byte code compilers to the VM with GCs. Then with JIT compilers to machine code (and from mc to microcode). Where will the stack move next?

Customer and Machine Gap

If you liked this post, subscribe to my free full RSS feed.
Filed under: Java, Software development

You can share this post!
Do you want to tell others about this article? Use the social bookmark icons to submit this artice to the service of your choice. Thanks.

Get free updates by email

If you did like this article you can get free updates with your RSS reader, you can follow me on Twitter or get free update to new posts by email. Enter your email:

 
About the author: Stephan has been working as a head of development and CTO. He has experiences in different technologies since 20 years including Java, Rails and Python. Stephans main field of interest is maintainablity and productivity in software development. Want to know more? All views are only his own.

Comments

You are absolutely right about the increment in complexity of software development. And this is although current approaches try to abstract things away. It seems to me that coding is an activity that should be abolished in the opinion of many methologists.
To make things better a bit, I claim that MDD or even MDA is not present in most of the commercial software projects happening today (MDA unequal UML of course).

BTW, I also began programming Z80. It was about 1989 on a Schneider CPC 6182 (later on Amstrad CPC). It should be valid to conclude that with Z80-assembler it was a lot harder achieving a goal than it is nowadays with higher languages such as Java. And even former Pascal compared to Java loses any competition, IMO.

Klaus

PS: Maybe you fix the word “Maschine” in your picture ;-)

stephan

Starting with a VC20 and some computers later a CPC 464, I think the requirements and goals were easier/simplier back than, so the goals could be accomplished with Z80 machine code without libraries. But as the software stack grows, the expectations of customers grow too. So yes of course, with the current requirements and goals, you can’t use older stacks to achieve them. Just compare a J2EE replicated server with something handwritten in C .

PS: I saw it the moment I finished the post, but didn’t know how to overwrite the image in wordpress, so I thought what the hell, noone will notice ;-)

Leave a Reply