Skip to content

ABC Tool

  • Home
  • About / Contect
    • PRIVACY POLICY
You should read Programming as Theory Building

You should read Programming as Theory Building

Posted on May 9, 2026 By safdargal12 No Comments on You should read Programming as Theory Building
Blog


When I finished reading Peter Naur’s Programming as Theory Building my first thought was “How come nobody ever told me to read this?” I ended up reading it multiple times, as I attempted to collect my thoughts on why it makes so much sense.

Have you ever had a situation where you’re trying to explain something or say something, and you’re looking for a suitable word or term, but no matter how much you look for it, you can’t find it? I think Naur’s “theory” is that term when it comes to writing good code and creating maintainable software. I’ve had many ideas and thoughts on those topics, but they were all disparate concepts, which even when grouped together didn’t really answer the question “why is writing good software hard?” Viewing programming as “theory building”, as Naur puts it, is the missing piece that pulls all of it together and answers the question.

In summary, Programming as Theory Building suggests that the program code, documentation and other products are secondary to what programming really is about: Building an understanding, or a mental model, of the program, its requirements, and how they relate to everything around it. That is, your primary goal as a programmer is to learn, understand, retain, improve and share this “theory” of the program.

I cheated and used the text tool in this drawing

If you think of things like “good code” or “maintainable code”, what is it that comes to mind? It’s probably things that make code easier to understand, like following good conventions, writing “clean” code, having a good architecture, and so on. You might also think of documentation and diagrams. Perhaps automated tests.

If you think about it, the goal with everything that relates to writing maintainable code is actually about communicating the design intention of the code. You write clean code because it’s easy to understand what it does, you architect code so it’s easy to understand its structure and purpose of the structure, you add documentation to help explain what the code does, and draw diagrams for similar purposes as well. But at least in my experience, developers treat the different aspects of this as separate activities – eg. writing tests is its own activity with its own goals, writing documentation is its own activity, and so forth.

If you look at programming as theory building in the way Naur suggests, you can see these activities as part of a larger whole: Communicating the theory of the program. When seen as part of a larger whole, you can start using the separate activities to achieve the shared goal better. And communicating the theory of the program is important: If you try to modify a program without having an understanding of the theory, you won’t be able to do it in a way that isn’t hacky. Similarly, if you need to evaluate the feasibility of some change to the code, such as a new feature, you cannot do this unless you have an understanding of the theory.

In this sense, programming is theory building.

If you think of it in this way, suddenly many more things connect together. For example, what do design patterns and Domain-Driven Design have in common? They help you communicate ideas and mental models used in your code – that is, they help communicate the theory of the program. Similarly, others have suggested concepts like Intellectual Control – having a mental model of the program, allowing you to confirm it works correctly, and reason about changes to it and so forth – which could also be seen as a form of “theory building”.

Hopefully I’ve managed to convey at least some of the value of reading Peter Naur’s essay. There’s more to it, so I highly recommend reading the original “Programming as Theory Building” text. It isn’t too long, and you can find it pretty easily on Google – I would link it, but it’s a bit of a gray area copyright-wise, and I’d have to deep link it from someone’s website. If you have read it, I’d love to hear your thoughts on it.



Source link

Post Views: 9

Post navigation

❮ Previous Post: As a Pixel Watch 4 owner, I really love (and hate) the new Fitbit Air
Next Post: The new Wild West of AI kids’ toys ❯

You may also like

‘The Boys’ Just Sorta Dropped a ‘Supernatural’ Reunion Episode, and It Was Super Messy
Blog
‘The Boys’ Just Sorta Dropped a ‘Supernatural’ Reunion Episode, and It Was Super Messy
April 29, 2026
Tabloid reports linking 10 missing and dead scientists spur FBI probe
Blog
Tabloid reports linking 10 missing and dead scientists spur FBI probe
April 22, 2026
A fresh Xbox 360 emulator for Android just broke cover in a new demo
Blog
A fresh Xbox 360 emulator for Android just broke cover in a new demo
April 28, 2026
One of the best handheld Zelda games now has an unofficial PC port
Blog
One of the best handheld Zelda games now has an unofficial PC port
May 5, 2026

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

Recent Posts

  • T-Mobile MVNO lets an AI clone your voice, handle some of the calls for you
  • Ring’s new Spotlight and Floodlight cameras level up with 2K resolution
  • Digg Is Back Again, but With a New Format and Focus on AI
  • NASA provides some details about Artemis III, but hard decisions remain
  • Launch HN: Ardent (YC P26) – Postgres sandboxes in seconds with zero migration

Recent Comments

No comments to show.

Archives

  • May 2026
  • April 2026

Categories

  • Blog

Copyright © 2026 ABC Tool.

Theme: Oceanly News by ScriptsTown