Loading summary
Steve McConnell
I thought this book would already have been written by someone and I wanted to see this book so that I could use it as material for an article. In my mind I was going to write a 250 page book, so for the first time I thought since I'd never published anything, I should probably make it look like I knew what I was doing. And so I created a detailed plan for the book and estimated the page count of the book and it came out to be 900 pages.
Podcast Host
Code complete is a single best book on code construction, which includes coding, debugging, detailed design, testing, and many more topics. It's also the most detailed one with an impressive 900 pages. The second edition of the book was published in 2004 and 20 years later the book remains a best seller in software engineering. I sat down with the author of the book, Steve McConnell in Seattle. In this episode we get the history of writing Code Complete and how the publisher did not expect the book to sell well. The difference between software construction and coding. Steve's mental model of career development for software engineers and why he considers the concept of Lily Padha being harmful. The impact of AI on software engineering topics that Siv left out of Code Complete but now talks about in DEP and many more. Steve rarely gives interviews, so I hope you enjoy this special one. This podcast episode is presented by statsig, the unified platform for flags, analytics, experiments and more. Check out the Show Notes to learn more about them and our other seasoned sponsor. If you enjoy the show, please do subscribe to the podcast on any podcast platform and on YouTube. Steve, welcome to the podcast.
Interviewer
It's so good to meet you in person.
Steve McConnell
Yeah, thanks for having me.
Interviewer
So you wrote this book? Code completed. I'm going to show it here. I was amazed when I first got my hands on the physical version on how long it is, how extensive it is, and how thorough it is. And the other big surprise I had I assumed that whoever wrote this must have been a really seasoned professional working 10, 20, probably 30 or 40 years. But I learned that you wrote this somewhat early career. How did you write it? And why did you even come up with the idea of writing such a massive and extensive book?
Steve McConnell
So I didn't start out to write a book, I started out to write an article and I'd never published anything and so I thought I'd wanted to write and I thought about writing all different kinds of things and I was active as a programmer, so I thought write about what you know. And so I started doing research. I'm a good researcher, which is funny in today's context, but back then that involved going to a research library and looking through a card catalog and requesting materials through interlibrary loan. I mean, it's quite a different process. And so there was actually some skill involved in that. So basically I thought this book would already have been written by someone. And I wanted to see this book so that I could use it as material for an article. And so I basically just started doing research. And after reading about, I think I read about 80 articles and a handful of books, I convinced myself that this book didn't exist. And this was just baffling to me because there were books on requirements, design, testing, project management, but there wasn't a book on the main thing that programmers do, which is software construction. And so I just kind of shifted gears and I didn't set out to write a 900 page book, which was the first edition. I thought, you know, it's funny because in my mind I was going to write a 250 page book because all the other books I'd read in that space had been 250 to 350 pages. And so I did background research, I wrote a couple sample chapters, I got ready to submit my proposal to the publisher. At this point I only had two chapters written. And so for the first time I thought since I'd never published anything, I should probably make it look like I knew what I was doing. And so I created a detailed book plan for the book and for the first time estimated the page count of the book. And it came out to be 900 pages. And I thought, that can't possibly be right. I'm not writing a 900 page book, I'm writing a 250 page book. And so I estimated it a different way and I came up with something like 875 pages. So I thought, okay, I think I'm writing a 900 page book. I think the thing about that is that if I had thought a year earlier that it was going to be 900 pages, it never would have occurred to me to even try. And. But by that time I was too far into it. I was mentally and emotionally committed. And so I decided to just go ahead and do it and just help us.
Interviewer
Imagine what stage of your career were you, you know, like in terms of work experience, college, those kind of things.
Steve McConnell
So I was about five years out, five years out of college at that point. I'd been programming professionally for, you could call it six years, I guess, because I took some time off in the middle of college. I actually think that was the perfect time to write the book because I think it's really important in writing a book to have a really clear sense of the target audience. And for me, my target audience was me five years earlier. And it was recent enough that I could still remember where I was five years earlier and what I didn't know five years earlier. I think for somebody who is 20 or 30 years into their career, it'd be really hard to know. Plus you'd just be out of date in terms of what you needed to know.
Interviewer
After the book came out, what was the impact of it? Do you remember, like initially and then a couple years later?
Steve McConnell
Yeah. So the book came out and it started to get really good reviews. And at that time the reviews, of course were in magazines which people got in the mail on paper.
Interviewer
This was pre Amazon. Right.
Steve McConnell
They trickled in way pre Amazon. And so the reviews were great. And I attended a book signing here in Bellevue and one of the people from Microsoft Press came in and said, oh, this is our sleeper book. And I learned that they never expected it to actually sell very well, that they decided to publish it because they thought it would be good for the catalog to have a more scholarly, in depth book, but they assumed it wouldn't really sell very well. So the sales have been a nice surprise for everybody.
Interviewer
You must have learned about a really interesting inspiration the book had on the block called Coding Horror.
Steve McConnell
I don't remember exactly when it was. It was, I don't remember, 2005, 2007.
Interviewer
Somewhere in there, something like that by Jeff Atwood. He started the blog or he renamed it, I'm not sure.
Steve McConnell
I think he conceived it from the beginning as Coding Horror. And he reached out to me and said, hey, I'm writing this blog. I want to call it Coding Horror. Can I have permission to use the Coding Horror icon from your book? And I was like, yeah, sure. And I think he sent me a T shirt or something with the Coding Horror image on it. And of course his blog did really, really well. And, you know, led. Led to a lot of good things for him and I think had a positive impact on the world too.
Interviewer
I think at some point it might have been the most popular developer blog he published. Stats about something like 100,000 requests per day. Wow. I was reading it. So when I was early career, I read Coding Horror almost like every day or like you know, every other day he published an article. And then of course that led to Stack Overflow or that helped him meet people, Joel and others. And that led to stack overflow. So it's just kind of incredible how indirectly, obviously. But you know, your book inspired someone else to start a blog, which inspired or helped create this very specialized stock overflow, which stock overflow obviously now has helped train some of the AI agents. It's just all trickling all down.
Steve McConnell
Yeah, well, I think, I don't know that I believe in karma, literally, but I definitely believe in the general idea that if you put out good things into the world that there are positive ripple effects and you never know what exactly is going to happen, but probably more good things than bad will happen. And so it sounds like that's part of what happened with that.
Interviewer
And so the book is on the concept called software construction. And you kind of start the book, I'll quote a little bit from it. You say at one time software development and coding were thought to be one and the same. But as distinct activities in the software development lifecycle have been identified, some of the best spines in the field have spent time analyzing and debating methods of project management, requirements, design and testing. They rush to study these identified, but it left code construction as the ignorant cousin of software development.
Podcast Host
I wanted to ask what is code construction?
Interviewer
I mean, the book is about code construction, but I think it helps us recap and how it's different to, let's say, software development or how it's similar to it.
Steve McConnell
Yeah, I was pretty deliberate in the book in trying to capture the space of software construction and a space that's distinct from writing code or not distinct from, but is not the same as writing code. I think that the idea of just jumping in and coding is something that maybe you do when you're first learning how to program. But as you get a little bit more advanced, I think there's a level of intermediate thought that includes thinking about how you're going to test what you're writing, thinking about how you're going to design in the details, what you're writing, actually doing the coding. And in the full set, the universe of topics that come to bear on the actual code itself, the readability and all aspects of readability. I think that much of the literature before I wrote code complete, there were a couple things out there that were decent things on coding style, but that was kind of it. It was coding style. It wasn't really about. We had books on software design, but the software design really stopped short of the level of design thinking that you would get into at what would have been at one time the routine level and then later was really the class level. And it Just seemed to me like there was just a lot of thought that wasn't necessarily guided or necessarily taking place in terms of thinking about the activities that are adjacent to coding, but not quite big enough to qualify for a book or a name of their own.
Interviewer
And then just to be clear, like these thoughts are so clear, like obviously we write the code, but it's everything that encapsulates until I get something that is ready to ship, that is ready, we have the planning or requirements or business requirements. And then it starts from me thinking about how I'm going to structure my code as I build it. I iterate, I debug, I check that it's running, I think about longer term maintain. These are all part of code construction. I'm just double checking that I'm understanding because I feel that code construction in the book you definitely cover it. But since then, I don't think we talk about code construction that much.
Steve McConnell
I would probably make it a little narrower than what you just described. I think that some of what you just described I would probably characterize as a higher level design. And. But on any given project, depending on how the project evolves or how it emerges, the design level of thinking could happen at the beginning, or it could happen incrementally as you go. It could happen by somebody who is good at that kind of thinking, or it could happen by the people who are actually doing the implementation. I think one of my learnings over the years, and I didn't really understand this when I wrote the first edition of Code Complete, is really that different people's brains work differently. And some people really are capable of thinking about design abstractly and then implementing the design. And some people are really good at just writing the code and learning the lessons in the small and then building up from that. And some people are good at both, but I don't think a lot of people are actually good at both. I think much more commonly you find people who are good at one or the other. And then I think there's often a disconnect between the people who have ability in one area and not the other. And I've seen cases where people think that it's just not possible to work the other way because they're not able to do it and they just can't imagine that somebody else could be able to work that way. And yet we've got all kinds of instance proofs of people working in both ways and having it work out fine.
Interviewer
And then the two ways are like, so just, I understand, is one of like, could you spell out again the two different ways of working.
Steve McConnell
You could think of it generally as top down versus bottom up. So you could think of it or inductive versus deductive. I believe that most, most programmers, meaning the majority, not like 99% but you know, 51% or maybe 70%. I believe most programmers are pretty detail oriented. And so I made a conscious design decision as I was writing code complete that I would write the book inductively. I wouldn't start out making a bunch of general statements and then demonstrate the specifics. I would start out talking about a lot of specifics and then build up to the general statements at the end. I just felt like more programmers than not were more oriented that direction. What I didn't appreciate at the time I was writing that was how big the disconnect was and the idea that I think a lot of people just aren't capable of operating the other direction, whichever the other direction has.
Podcast Host
Steve was just talking about how there are different ways to get to a.
Interviewer
Good design of a software system.
Podcast Host
Some developers do a top down, others do a bottoms up.
Interviewer
But how do you know if a.
Podcast Host
Well designed system works as expected in the real world? This is where analytics and experimentation are so important and it's why companies like Meta, Uber and others build complex experimentation systems themselves. These are far more advanced than what engineers at most companies could have access to until recently. That is when statsig became available. Statsig is our presenting partner for the season and they built a complete set of data tools that allow engineering teams to measure the impact of their work, focus on outcomes and create bottoms up products culture. This includes advanced A B testing, product analytics, feature flags, plus tools like session replays, a user store, and more. With statsig, every time you release a new feature, you can see exactly how it moves a product or infometrics that you care about and then you track progress over time using the same datase. This toolkit is so valuable to so many teams that OpenAI, who was a huge user of Static, decided to acquire the company recently.
Interviewer
Talk about validation.
Podcast Host
Static has an incredibly generous free tier, a pro tier for teams starting at $150 per month and scalable enterprise pricing. To learn more go to static.com pragmatic.
Interviewer
Yeah, this is really interesting because for example, these days at a lot of scale ups tech companies, it's becoming increasingly expected of engineers to start with a design document, which is a software design document. And when I work for example at Uber like we kind of operate it like this, but a lot of times it just Feels like a nag, like I know what I want to write. Which kind of makes me realize, I think your point on. Some people operate differently. They're always the same developers or engineers who wrote the code, did the thing and they're like, okay, I'll, I'll write a design document, just like check the box. But the code was already written.
Podcast Host
Right.
Interviewer
And, and at the time I tried to explain these people especially. Eventually I became a manager to some of these people. Like, you need to start, you know, highlight your, your high level thing. And I didn't appreciate at the time, I was like, what? Because I guess maybe I, I am fine operating like this. I'm probably in this, this first group. I didn't appreciate this until. Until now.
Steve McConnell
Yeah. There's a great paper, really old paper by Dave Parnas called A Rational Design Process, how and why to Fake It. And the gist of the paper, so this paper is from I think the mid-70s, I don't remember exactly, it was a really old paper. But the gist of the paper is that design is a sloppy process and nobody gets it right. It's not linear. You don't start out and march your way in a straight line toward getting a good design. And so number one, the paper sort of gave permission to experiment, try stuff, make mistakes, learn from the mistakes, iterate. But then the paper also says the how and why to fake it part was at the end of that, you describe what you did and the description is not necessarily going to show you all of the mistakes and dead ends and so on. So it's going to look like it was a more rational process than it was. But. So I think both halves of that paper are worth keeping in mind. And it sounds like your experience would kind of bear that out, that it's not even really possible to get it right the first time in most cases.
Interviewer
Yeah. And I do sense that in the industry these days, we've kind of forgotten a little bit about the design or the iteration or even things like. I have to remember who said this. I think it was John Osterhout, who in his book on software design, A Philosophical Software Design, his suggestion was design it twice, because the second time you'll get a better design than the first time. These are just things that some people might still do.
Steve McConnell
But I would say three times. But yeah, and I'm serious about that. So when I was at Microsoft, there was a programmer inside Microsoft who was famous at the time, who was well known for rewriting everything three times. And the basic gist of it was he had two weeks to do an assignment. He would spend the first six days coding and making all kinds of mistakes and not doing it very well. And then he'd just throw it out and spend the next three days rewriting it. And by that time he would be applying all the lessons he learned. Then he'd spend the last day or day and a half writing a third version and it would be perfect. And if you think about your own experience, if you've ever, this should never happen in theory, but it still happens where you've done a bunch of work and somehow you lose it, it gets deleted, you have a backup, whatever, right? Should never happen. But sometimes it does. And you think, oh, this is awful, I just spent a whole day working on this, it's going to take me forever. And then you rewrite it in 45 minutes and as you go you remember all the lessons that you learned and all the stuff you wish you'd done the first time. It actually turns out probably better than if you'd never lost it in the first place and had to keep what you wrote initially.
Interviewer
Well, these days I think it happens a bit less thanks to git being everywhere committing. But I've had this earlier in my career and as you said, first of all, you blow up. You're like so mad. Like I think it was a file loss or deleted or something like this. And as you said, you're thinking, oh, it's going to be so much work, I don't even want to do it. But when I now remember the same.
Steve McConnell
Lesson, I spent some time on the school board here in Bellevue and one of the surprising learnings I got from the school board was that one of the best ways to build reading proficiency is to have kids read things they already have read. This repetitive reading builds confidence and builds skill. And so I think you kind of apply the same idea to rewriting the same code you've already written, that maybe there's a lost opportunity there. Because we're always trying to do something new and we don't often get the chance to go back and just redo the thing we just did.
Interviewer
Yeah, and I think this is one of the things where I wonder if we're talking a lot less about software design in the industry because we just ship once, we don't even go back to rewrite the whole thing. Especially with web based software, you know, mobile is becoming that as you can ship it, you can change it anytime. You know, there's startups, lean startups from, from 2010 gave this concept of MVP minimum viable product, you know, it doesn't be good, it just seems to be good enough. And I guess the most mature companies which hit so called product market fit a product that works over time they will do a rewrite or maybe a second rewrite through a series of migration technology choices. So they will get actually a lot better. But that's kind of it. So I think there's a lesson we can probably all just consider. It's not a bad thing to rewrite. So your career path, we know that you wrote this book early career. What was your professional development story up to the book and then after the book, what happened after?
Steve McConnell
Basically up to the book. I had worked for a small insurance consulting company. I'd worked for a large briefly for a large insurance company. I had worked at Boeing on a defense project. I'd worked in a startup mode for company. It was kind of doing just a startup shrink wrap product. And then I was about to start working on the book full time and I got an offer to go to Microsoft just initially for a summer. And I thought at the time Microsoft was the hot tech company. And so I thought, yeah, if I get a chance to see what's going on inside Microsoft, I should do that. It'll make my book better. So I ended up being at Microsoft for a year. That was essentially my background I'd also done. I always had some kind of startup project of my own going throughout that period and I put a lot of time into those as well. I had started out being kind of interested in programming, but not super interested in it, notwithstanding the fact that I seem to spend a lot of my essentially hobby time on it anyway. And so I started out just kind of thinking I wasn't really sure if I wanted to do this as a job. And then I thought, well, but I had a little bit of an entrepreneurial streak. So I kept doing startup stuff in that mode. And at some point in there I kind of switched over from thinking I don't know if I really want to do this as a job to thinking if I'm going to do this as a job, I probably ought to figure out what I'm doing. And I think at the time, for the first couple years I had a little bit of imposter syndrome because I didn't have a degree in computer science. I didn't know at the time that oh really?
Interviewer
Of course, this was. What was your degree in?
Steve McConnell
In philosophy. Yeah, I had minors in math and computer science. But. But at the time less than half the People working in the field had degrees in computer science. That didn't change for a long time. So I, but I didn't realize that I, that that was common. I thought that was unusual. So I, I started trying to develop or acquire some skills so that I could basically be more professional. So I started going to user group meetings. I had one friend who was as interested in the programming stuff as I was. So we go to these things together and talk about them. And then when I got the chance to be, I'd worked at Boeing and I was like, okay, I'm not seeing a whole lot here that really looks like qualitatively different professional programming to me. And then I got inside Microsoft and I thought, okay, I'm finally going to see what real professional programming looks like.
Interviewer
The best of the industry. Right. Like Microsoft back then was a bit like what OpenAI is now or Google in like 2000, I don't know, four.
Steve McConnell
It was just the 800 pound gorilla and there was nothing else even close at the time. And I don't know what percentage of all software share of the all market software share they had, but it had to be a pretty high percentage.
Interviewer
This was around the peak, right around the Windows and DOS and that era. Right.
Steve McConnell
Windows was not really popular yet, although that's what I worked on. But it was sort of the last phase of the DOS era which Windows was dominated. Beginning phase of Windows, yeah. And they weren't super dominant in applications the way they are now. So I got inside Microsoft and what I discovered was number one, the people were really, really smart. So that was a factor. And number two, you have like one person working on the printer device driver for one specific printer. And so the difference between that and my experience was my experience up to that point had been you're working for a company and you've got responsibility for figuring out how to get things to print, figuring out how to load and save files, figuring out how to display stuff on the screen and, and it's like, oh, I've got like a whole person not just on printing, but on printing to one device. So I mean that was a lot of it. It's just the projects were broken down into much, much smaller pieces and so people could put a lot more time into it. And then yeah, they were really, really bright. But qualitatively in terms of programming practices, you know, there wasn't really anything different than what I'd already seen.
Interviewer
So you got into Microsoft, you write the book at this point, how did you think about your career? I think you had a talk earlier, which is not recorded but about the mental model on how you viewed your career at the time, and then figured out what next.
Steve McConnell
At the time I wrote Codecomplete I was still trying to decide if I really wanted to be a programmer at all, if you can believe that. And so I spent a year full time writing code complete. But I'd spent two years doing background research before I spent the year full time.
Interviewer
So you did research on like you had a full time job and on the side you were doing and then you like took off time?
Steve McConnell
I did, I took a year off.
Interviewer
Wow.
Steve McConnell
Yeah.
Interviewer
Did that not look scary? I mean suddenly you were there with no job, just writing this book.
Steve McConnell
Yeah, I really wanted to write the book. That was, that was the main thing I wanted to do by then. And I knew it was a big project because by then I'd figured out it was 900 pages. And with the 250 page that I'd been carrying around in my mind that could have been maybe a part time, but 900 pages. I knew I needed to take some dedicated time to do it and I wanted to do it. I'd save money and I could afford to take some time off. I had basically I was living a very low overhead life at the time. I didn't own a house, I wasn't married, I didn't have a dog. So I could live really cheaply if I needed to, which I did. And so I spent about a year writing full time. And at the end of that number one, it was a terrific experience at the time I felt like I'd gotten three years of experience in one year by writing the book. I would say I learned so much more about what I was doing just through the process of the writing's only not the main part of it, the thinking about what I wanted to write was the main part of it. But then I went back into hands on programming role and I felt like, oh, this is great, I like the writing but I'm so glad I'm doing hands on programming again because I was kind of sick of the writing at that point. By the time I published Code Complete, I was convinced I was never going to write another book. And because the end phase of that was just painful. And so then I worked for a couple years and the memory of the pain faded and I was kind of getting the itch to write something again. So then I wrote my second book, Rapid Development and I kept thinking I was going back and forth, I kept thinking, do I like writing better? Do I like programming better. I kind of liked whatever I was doing at the time better. It took me a while. Eventually I realized I liked the back and forth. I liked the variety, but not the variety on a day to day, week to week, month to month basis. I liked having big blocks of time to concentrate, dive in, go really deep. So before I wrote Rapid Development, at that point I was starting to think, all right, yeah, I think this programming thing might be a good direction for me and maybe I am a little committed to the career. And so I started to think about where do I think my career should go and what do I want to do? And so I have no idea how I came up with the idea, but I created what I thought of as the career pyramid. And I kind of organized the software universe into the base of the pyramid was all programmers, like 100% of the programmers. My focus was on us. And then the second level up was programmers who had maybe actually gotten a degree in programming, which I had not. And then the next level up was maybe advanced degree in programming or maybe written some magazine articles or were in a lead or manager position. And so anyway, the pyramid kind of went up to where there were just a very small number of people at the top who had essentially a lifetime of significant contributions to the field. And so I thought, okay, just in terms of setting a direction, I'll just aim for the top of the pyramid. And it wasn't so much because I thought I wanted to get to the top of the pyramid. It was just more to have a point on the horizon that I could move toward. And so I used that partly to guide what I did on the second book because I had a variety of books I was interested in writing. And the book that would have made the most sense after code complete would have been design complete. I could have written it at the time, but I felt like I would get pigeonholed as just pure tech guy if I did that. The other book I really wanted to write was Performance Optimization in Windows, which was a fun topic, but again, it was a little bit too, a little bit too bits and bytes. And so I decided to hop over and write something that was a little bit more management oriented and because I wanted to kind of triangulate on the.
Interviewer
Top of the pyramid and then in. And by the way, this pyramid you shared with me, so we'll also share. So yes, I thought it was such a good or interesting mental model that I haven't seen many people think. And I really appreciated that you kind of zoomed out and Looked like, all right, where am I? Where would I like to go? How do I go there? Now, as part of this, you mentioned again, in this talk, you mentioned the concept of Lily Pad hopping. What is that and how did you apply it to your career?
Steve McConnell
Well, I think that the pyramid was in essence, the antidote to Lilypad hopping. What I had noticed, I noticed it a lot more later. But even at the time, I'd realized that programming didn't really feel like a career, it felt like a job. And the reason it felt like a job rather than a career was I didn't get the sense that it was going anywhere. I saw people who'd work on one project and they'd work on the next project, and then they'd work on the next project. Then that's the Lily Pad hopping part. But it didn't add up to anything. It was just different. It was kind of like difference for the sake of difference. And, you know, they're probably learning things. They're learning a new business area, they're learning new technology. And, you know, maybe that's interesting and stimulating and there's some, definitely some personal growth that goes on there. But I always felt like if I'm going to put the effort into learning something and growing, I'd like it to add up, I'd like it to accumulate. I don't want it to just be a bunch of different things that are all the same. In a way, I really wanted to be essentially more than the sum of the parts. And so part of the reason for me coming up with the pyramid in the first place was really just trying to think about, okay, how do I get past this idea of, I've worked on this project, I've worked on that project, I know a lot more stuff now than I used to, but I'm no more marketable, I'm really no more valuable. I don't have the ability to really contribute on any individual project or organization more than I used to have. So how do I essentially build my skills in such a way that I become increasingly valuable as time goes by? You know, you're going to put in the same effort either way. And so it's almost back to the design question, where it's like, if I'm going to put in this much effort, I can either have it add up to this or I can have it add up to that. Where that is a lot more than this. If I put some thought into it.
Interviewer
I really like the thinking, especially because as developers, I think we forget, or as software engineers, that we have a lot of freedom on the job. For example, when I was a manager to engineers, if an engineer came to me and sat on my team and said like, hey, I'm really interested in this area. First of all, if they said that, I would be thinking, how can I help them with that? But even more so, but sometimes that would be tricky to do or not as simple. But if you say, like, hey, I'm interested in this other project, I'd love to work on it because I think it would help my skill set. So if they kind of did the work to just look around, understand, you know, the limitations of a team, whatnot, like, my answer was like, amazing. And I also thought, wow, this is a person who's really taking initiative. Let me help them. Because as their manager, I think, you know, I'm not sure if people still have the notion of like the boss who's something negative. Like, as a manager, you really want everyone to thrive. You want people to grow professionally because guess what, they'll have better output, more motivation. It makes your team better. And as a manager, that's your goal. So I think the more people realize that you can think about where you want to go, even at the workplace, you can almost always make some of it happen, if not all of it.
Steve McConnell
I think that's right. I think there's saying that most people live in a box that they build for themselves. And then Larry Constantine is one of the founders of structured design, if that term even means anything. Had a saying that I like, which he says, nobody needs to give you permission to do your job well. And the corollary to that is your managers already think that you're going to do whatever needs to be done to do your job well. They assume that you believe that you have permission to do it. Meanwhile, on the ground, a lot of people live in that box they built for themselves. And they think, oh, I got to do this the same way that they did it last time. There's no reason. They think that it's just, I guess it's human nature for people that just kind of constrain themselves that way. So I think you're absolutely right that in the vast majority of software jobs that I've ever been aware of, people can design a lot of their own job or their own day to day work in such a way that they can learn a lot and grow a lot in a more strategic way.
Interviewer
And I think this is just becoming, it's starting to become more of baseline expectations. The one thing I noticed is when we were Hiring people at Uber. At Uber, we had a culture that was very startupy, experimental. We had the same, be an owner, not a renter. You know, do what needs to be done. And I have people who joined from, like, consultancies, places where it was common for the client or someone to sign tickets to them, for example, Jira tickets, you know, and they would work on it. It got used to. They. They weren't really allowed to go and ask questions. It was kind of like, don't question it. And so when some of those people came over, they found it really hard to adjust because they were like, oh, you know, what tickets should I sell? And I was like, well, like, don't tell me you sell me. But it's interesting how that's the first time I saw that there was a divide where people at some point in their career, they got told like, this is the box. Stay inside the box. And then they found it really hard to, oh, I can actually. Oh, there's nothing here. I can actually go outside.
Steve McConnell
My first summer job that I got paid for programming is an internship. And I basically finished all the work they had for me halfway through the summer. So they had to make up stuff for me to do. And my boss gave me the assignment. He just handed me a box of floppy diskettes, and you have to put up a picture so people know what those are. And he said, I want you to do something useful with this box of diskettes. And my response was, well, what do you want me to do? And he said, I don't know what I want you to do. Part of your job is to figure out what I should want you to do. So you take this away and do something useful with it. At the time, I was incredibly frustrated. I felt like the boss wasn't delegating anything to me, wasn't giving me clear direction. I really felt like he'd sort of abdicated his responsibilities as a boss. But as the years went by, and certainly by the time I started my own company, that was basically the model for 99% of my day, which is nobody, when you're the owner of your company, tells you what the next most useful thing to do is. You got to figure that out. In fact, it's really mainly your job to be the one who's looking at the whole landscape and saying, what do I do next? What's the next most useful thing to do? So, yeah, I completely agree with that and identify with it. And it's funny how, as a junior person, you can feel like the ambiguity in that Assignment is a real liability, but really that's incredibly valuable training for what you deal with as you get into higher positions of responsibility. And when I say responsibility, I'm not just talking about for people, I'm talking about product direction, health of the organization, all kinds of stuff.
Interviewer
Just to see how it, how baseline it is. At Uber, I didn't know if we were exceptional or not, but just a few weeks ago, I talked with someone at OpenAI about. In fact, I talked with the head of engineering at OpenAI and they're now one of the hottest companies right now. A bit like how Microsoft was in the 90s or Google later or maybe Uber even at some point. And I asked the head of engineering, how are you structuring your teams, engineers, et cetera? And he told me something interesting, how they don't really have roles anymore because they actually have some of the designers write code, obviously with the help of AI, some of the engineers do the product requirements or even do design. And it's all becoming really fluid. And he said that the model they follow is everyone should pick up both what they think is the most important thing to do. And so suddenly, what used to be a pretty well defined role of software engineer, product manager, designer, they're all kind of murky. I mean, people still have their expertise and this is one of the most innovative companies right now. I'm seeing servers do more and more of this. They're now calling it actually a product engineer, which means you are a software engineer, but your job is not just to write code. Your job is to understand what we do and then, you know, build solutions for the most pressing problems. And now it is spreading across more and more. Startups are like, only hiring for these folks. And if you're used to, you know, being told what to do or you're looking for it, they'll be like, yeah, sorry, we're not looking for these types of folks.
Podcast Host
Yeah, we just Talked about how OpenAI works differently than many companies, even in the roles they have. One other thing they are different is in the tools engineers at the company.
Interviewer
Use to get things done.
Podcast Host
They use linear, who are the seasoned sponsor of this podcast.
Interviewer
And a big reason for their choice.
Podcast Host
Was the need to harmonize all the different ways their product team was working. Picture this.
Interviewer
You're an engineer working on a critical project.
Podcast Host
You need to coordinate with another engineering team on a shared dependency. But here's the problem. Your team Tracks work in Jira, they use GitHub issues, and the product team writes specs in Google Docs. Every handoff requires you to translate not just the work, but the entire way of thinking about the work. This slows you down massively. One OpenAI engineer described it as an archipelago where each team is on their own island using their own language, which sounds funny, but from my experience at.
Interviewer
Uber, it's super accurate.
Podcast Host
So their switch to linear was driven by the need to establish a shared vocabulary between teams. Every project now follows the same life cycle, uses the same labels, moves through the same state. When an engineer from one team needs to understand what another team is working on, they don't have to learn a new system or decode different workflows. Their usage of Linear in this way is how they can move so fast despite being quite a large company. And to close, linear is just so simple to use. Their team needed no formal training. Try it for yourself by heading to linear app Pragmatic.
Steve McConnell
Well, what comes to my mind when you say that is I think companies go through maturing process. When I say maturing in this case, I'm not even saying more mature is better than less mature. Sometimes less mature is better. But you have certain personalities that work well in startup mode and you have other personalities that work better as you get into slow growth or sustaining mode. And so what you described I think is just is great when you've got most of the staff that's self motivated, self driven and they're part of something exciting and it's growing and they're probably young and they're probably hired directly out of school or a couple years out of school. There's a lot you can do in that mode as the company gets bigger, as it gets installed, client base, as companies start to. Other companies start to do things that rely heavily on the reliability, not just the innovation, but they need different things. They no longer need what's latest and greatest and coolest. They need the thing to work the same way it did yesterday because they've made assumptions that depend on it. Then you get, essentially you're calling for a different kind of staff to work on that. So as time goes by, some of the staff that were the biggest contributors early on get bored and frustrated with all the restrictions and they leave. And then all that ambiguity or flexibility in the roles and stuff, that's no longer a positive. And so my prediction with the scenario you described is that 10 years from now that organization will need what my company called Roles and Responsibilities workshop. Because it's just so common that you start out in a way that, that works, but you get to a point where as Things scale up and as the characteristics of the staff change, it just doesn't work anymore. And so you just need to be a little bit more explicit about it. And I think these, you know, these are all just natural pendulum swings that happen as time goes by. And it's not that one is better or worse than the other, it's really fit for purpose, which in startup mode. Having a lot of bureaucracy in startup mode is a great recipe for never getting started. But adding the right kind of bureaucracy at some point becomes necessary to sustain an organization of a larger size.
Interviewer
I think you're very much right, especially because it is popular now, obviously. I also talk with a lot of basically startups, sometimes their scale ups, they're larger, but they're still very young, growing, especially on AI. It's, it's a, it's a new topic. And if you look at companies, you know, there's this joke that goes in the tech industry that eventually every company becomes IBM.
Steve McConnell
Yeah.
Interviewer
And now like when you look at Google in some ways, well, they're behaving awfully a lot like IBM used to. But if you look at Google is now 30 or. Well, it's going to turn 30 years old. It's a massive business. It has 200,000 people, et cetera. Like as you said, the things don't work. And one model I've heard, which I don't know who to attribute it to, but there's the pioneer settler and city builder, which also is one variation of what you said.
Steve McConnell
And then I'd add age on top of that. When I was at Microsoft in the early 90s, the campus age was aging 0.8 years per calendar year. And so when I was at Microsoft I was 27. Average age on campus was 27, point something or 26, point something. I was about half a year off the average age on campus. And that's average. That's not median, that's average. And so if you've got one guy who's 60, you need a lot of guys who are like 22 to get the average down to 27. And so the average, you know, misrepresented how old the campus was. Really, it was probably younger than the.
Interviewer
Media must have been younger.
Steve McConnell
Yeah. So when I was there there were about 15,000 people total and the dev staff was about 2,000, so. But aging 0.8 demographic years per calendar year. Fast forward 15 years now the campus is 40, not 27. And now people have got houses and they've got kids and they've got spouses and you know, it's just all this other stuff that's more on the kind of technical technology code base, customer base, there's all the business stuff. But I think the demographics of the staff matter and the reality is the people in the company age as the company ages and that has some pretty big impacts.
Interviewer
Yeah. And some of the companies that have been the hottest and fastest growing startups of all time, I'm thinking of Amazon, of Google, of Meta, you know, like their CEOs and their staff is now, you know, they used to be 20 when they started or even I think Facebook 19, something like that. Now they're, you know, 40, 45, 50. As you say, it's all growing with it. Yeah, that's good to keep in mind. Now also, in this kind of career advice talk that you did, you outlined three areas that you've noticed that software developers should become proficient in. Technology knowledge, business domain knowledge, and software best practices knowledge. In your experience, like how important are these and how can you get good at them? And if you had to take a stab at which ones are becoming more important as a developer is getting more experience in your experience, which one was one more important either for you or the people you work with?
Steve McConnell
They all matter to some degree at all times. If you're a junior developer, you're not very good at all of them or any of them, but you're probably the strongest in the technology area. If you're a little bit less junior developer, you know, maybe you've worked for the same company for five years, then you could be pretty strong in the software best practices or pretty strong in the business in addition to being pretty strong on the technology side. I mean, five years is a long time in the software world. At some point, the vast majority of software professionals I've ever met, they end up concentrating in one area or another. And so I think the most career limiting, unless you're in just a super techie organization, is to just go all in on the technology side. There are some places where that's going to work, but that's the exception. Going all in on the business side is a really good background for moving into more of a company level architect role. You understand how the different pieces fit together for both the technology and the business. You're able to make technical decisions on a business basis and not very many people are good at that. And so I think that can be super valuable. Useful Career path the best practices path, which is my path, is actually probably a little bit more limited in the vast majority of companies. It's less limited if you're a consultant or a trainer. But inside a company you can still be valuable, but you're probably going to move into more of a coach role or possibly move into more of a manager role anyway. I think either of those second focus areas can be viable and valuable paths to focus on. And I think one thing I mentioned in that talk was that it's just, it's very useful to think through which one do you want to be? And I don't know that a lot of people actually think about it that much. They kind of, they get an opportunity to be a manager and so they're like, okay, that seems like a step up. And they don't necessarily realize, oh yeah, if I take the manager path, part of what goes with that is I need to get better at the people side of it and then I also need to get better at the business side of it. If I go high enough on the manager path, at some point the business needs come into conflict with the technology needs and my role is going to require me to favor the needs of the business. And a lot of technical people can't make that transition because they're too wedded to the technology and they just can't conceive of the idea that the business would take precedence over the best. You know, that's in quotes, the best technical decision.
Interviewer
Yeah. And it's interesting with a manager path, I think we've had about 10 years where looking back, we had zero interest rates and companies were growing really fast. Investment in technology was huge thanks to the mobile revolution, smartphone revolution, thanks to cloud, thanks to startup returns and IPOs. Just being big and going into manager path used to be seen as a very low risk one, as one where you could go in, you could manage people, maybe make a bit more money, open your options. Because now you could go to found a startup, say I have management experience, you could go back to being an engineer later as well. But what happened now? Well, some of those people who thought, oh, I'll just go into management for a little bit and see how it is and I'll go back, they ended up going higher and higher again with this high growth area, earnings potential was higher. But now the reality is hitting where teams are not growing as fast. In fact, there are some companies are scaling back so managers are finding themselves formerly technical people in this really awkward position where they're not that technical anymore. Their past few years of experience is scaling fast growing teams which is no longer needed. So I've had some friends who saw this coming a little bit earlier, head of engineering or director of engineering. And some of them went back to individual contributor roles or to tech lead roles where technically they took a step down. And some of them are actually happier for it and it just gives a lot more stability. There's still a lot of engineers who need to be hired, but just fewer managers and especially fewer managers without a warm referral.
Steve McConnell
Yeah, I don't have enough knowledge of sales staff or general business staff to know how it looks on that side of the fence. But from the reading I've done, I feel like technical staff have a couple of interesting attributes as they move into management that I don't read about in general management literature. One is that I think a pretty common pattern for technical staff is going into management for a year or two, deciding they don't like it, going back into a technical contributor role, enjoying it. But going back to thinking about, huh, here I could have done the management thing this way, I could have done it that way. And then they make a second attempt at manager and then they actually really like it and they do. Well, I've seen that pattern many times. And so just the idea of kind of bouncing up against the ceiling, coming back, regrouping, and then taking a second run at it a few years later, and some of those people end up being really, really effective managers. Another attribute that I find to be really uncommon is that most technical managers at any level don't have any aspiration to general management positions. If you're at a VP of Technology role, VP of Software role, it's unlikely that you aspire to be the CEO or the coo. What's likely, if you aspire to anything, is you aspire to having the VP technology role at a cooler company. And that's it. And so it's funny because I think for general business people, this doesn't really compute. You know, they like, hey, if I'm a vp, I want to be the CEO, I want to move into the C level. But for whatever reason, I don't think technical people think that way. I don't read about it outside of technology.
Interviewer
Yeah, and there are some really interesting stories as well. The founder and for a long time CEO of HashiCorp, Michael Hashimoto, he was the CEO of the company for a while because he took over from his co founder and then he went back to being an individual contributor at the same company, which is uncommon, but it comes to show. And now he's actually, he went back to writing. He founded Hashicorp by writing software I think Terraform or some of the others. And now he's back to just writing software. It just shows that he just loves building.
Steve McConnell
Yeah, There's a great leadership book called what Got yout Here, Won't get yout There, and it's really aimed at organizational leaders. And the gist of the book is here are all the things you did to kind of get to where you are and they were all great for that role, but you're not in that role anymore. And so to be successful in your new role, you have to operate differently. And some people don't want to operate differently. So the ones that actually have some self awareness, do what you describe, they, they go back into a different role. I think, I think the specific scenario you described of the founder of the company going back into a contributor role, organizationally we've seen that as super messy just because it's hard to disagree with the owner and all that stuff. And it can be incredibly randomizing for the organization. But if that same person instead goes off and starts the next new thing, that can be great. They can take advantage of everything they learn the first time.
Interviewer
I do think that a lot of tech founders don't really think or even talk or consume literature learnings from other companies. You know, there's a lot of like first timers, why not? So, so there, there are some drama and, and conflicts and, and learning. Sometimes this works out, sometimes it doesn't. Yeah, but I, I wonder if this is engineering specific. Whereas, and, and any company has this tendency of like, look, I know what I'm good at, which is just engineering and you assume that you're going to be good at other stuff as well.
Steve McConnell
Which sometimes you are. No, sometimes you are, sometimes you're not. Yeah, yeah. Well, I think, you know, a topic that I don't think I've ever written about, but that I think is worth just throwing on the table is that focused application of personal energy makes up for a lot of other deficiencies. And in startup mode, when you're talking about not having well defined roles and so on, if everybody's actually working in a focused way and they care about getting work done and they're applying a lot of energy, mistakes aren't a big deal. You just go in and you fix it because you've got the energy to do it. If you're working in a super process oriented way and people are kind of thinking half about their home life and they're checked out because now they're 45 instead of 27, not that that's a universal pattern or anything. But if you don't have the same level of personal energy to correct mistakes, the mistakes linger, they affect more people, affect more downstream products, work products, and it just becomes a much bigger deal. And when I was at Microsoft, the core Windows team was under 15 people. Of course this was a much earlier version of Windows, but at the time there was a project going on at IBM. Well, Microsoft and IBM were jointly developing operating system called OS 2 and IBM had something like 10 times the staff, maybe more than that. And Microsoft was really frustrated at how slow IBM was on their side. And the reality is you can get a lot of stuff done with the right 10 people who are all super focused. And even if you just start thinking about it in terms of number of communication paths, how many people do I have to interact with on a day to day, hour to hour basis? If I've got nine or 10 people, how many does it take to make a decision that sticks? How many does it take to fully consider an issue? You know, I hear if I have a decision where on a 10 person team I need four people to weigh in. I've now heard everything with four people. If I've got a hundred people on the team, I've got, you know, 30 that need to weigh in. That's an entirely different proposition. And so yeah, you can get an awful lot done with the right with a high level of energy. And I don't think in the technical space I haven't read much at all on people talking about the role that energy plays. It's all about process and training your different people and technology and so on.
Interviewer
And if I just think back of the past, just 20, 30 years, the ones that I've seen repeatedly, regardless of technology, regardless of right now, we have AI earlier we had code generators in terms of tools or, or intellisense that just auto completes your thing. You know, all these tools that make teams productive. But whatever tools we have, if I think back from the 90s all the way to like today, we always see these things where there's a five, 10 person team, comes out of nowhere, builds this thing. And so you know, we think in the gaming there's the team that built ID software, you know, they built Doom with I think like three core people, nine people. And it was a huge hit than in social media with Instagram which was 10 people. Facebook acquired them because they were growing so fast. They would have been bigger in the face of WhatsApp. Again it was a small team, but I think there were 50 people by the end when they got bought. Right now we have a social media platform called Bluesky, which again, they're with 12 engineers, they're growing really fast. OpenAI when they are small and so on. And it feels that it doesn't really matter what the tech stage is, what connects them is, well, energy, focus. Yeah. And I've not read anything about this. You know, there's always the interview people and like, how did you do it? And they tell you some kind of story and when you ask people about, like. So right now I have been talking with like some people, for example, to OpenAI because right now they're the hottest one. And I asked them like, what is a special, how do you ship so fast? Like OpenAI is still out shipping some smaller startups as a larger organization. And the answer I get sounds cliche, but they're telling the truth. They say, well, it's the people and how everyone's so focused and motivated. They don't say energy, but yeah, that as well.
Steve McConnell
Yeah. And so during the era I was at Microsoft, I think the culture at Microsoft when I was there was if you were awake, you were working. And the thing that it looks from the outside like it's a sweatshop, but from the inside it's just they were doing an incredible job at that time of hiring people who really didn't want to do anything other than work on the next generation of software. And it was a great time to be there because you felt like you were at least a year ahead of the rest of the world because number one, you were developing it at Microsoft. Number two, everybody else who was doing anything interesting wanted to come to Microsoft to show it to you. And so you were constantly in one mode at work where you were seeing the future. And then when you went home or talked to somebody from a different company, they were a year or two behind where you were. So it's incredibly exciting, stimulating place to be. And of course you just naturally wanted to spend all your time working, but you can't replicate that through good management where you're just trying to somehow motivate people to want to work 100% of their waking hours. You really have to just put the pieces in place so that people want to do it. And, and if you're a super high marquee company like Microsoft, I was at that time, then it happens kind of automatically, really. The manager's job is not to mess it up. But if you're a regular just business or a sustaining mode company, I don't think it's possible to replicate it in those companies. Every once in a while you'll see some individual project where somebody does a halfway decent job of replicating it for a short time. But yeah, so all the examples that you gave resonate with me because they're all kind of in this same mold of super exciting time to be there, part of something. You know, you're creating the state of the art, advancing the state of the universe. Unfortunately it doesn't last forever. And so, you know, it's cool to be a part of it while. While, while it lasts.
Interviewer
Yeah. And I think, you know, those of us, for example, I've had opportunities to be part of a team where at the time, I mean, we weren't changing a universe, but we were doing something really exciting and felt we're up against the world. It felt a bit impossible as well. Those are relationships where I still keep in touch with some of the people, you know, like, it's like friendships are, are made through these crazy times and it's, it's weird because I wanted it, it is crunch time, but a little bit is self inflicted. Sometimes it's external pressure, but you know, I would never advocate for that. But I'm also very glad that I did it right, that I had like I do want some times in my life like that, you know, like not all the time because that's burnout, but also like if you have none of it, like it's just a 9 to 5, then like I don't want to.
Steve McConnell
100%. Yeah. And it was funny because we saw the Agile movement go through the same kind of maturing of its view of sustainable pace that my company had gone through. We originally as a company really before Agile existed, had started out thinking 40 hour workweek. But the first guy that I hired who ended up being the CTO for 20 years, eventually he and I realized neither of us had ever worked in a 40 hour work week. We both naturally worked in burst mode and we both did our best work in burst mode. And so it's not about having a steady state, it's about having a sustainable pattern. And what you described resonates with me 100%. And in that you don't want it all the time. But yeah, if you had to go through your whole career and never experience that, I would really feel like I had missed out on something if I couldn't have been in that mode at least some.
Interviewer
I came up with this analogy which is imperfect, but I used to do sports at a competitive level and this involves swimming and Running, and especially with running, because it is something where you can be injured when you're training, you have. When you're actually sprinting or you're doing the competition, but even during training, you're doing that part. You're also doing the kind of endurance part where you're not giving all that. And then you're also, like, resting. And a coach will instruct an athlete to go like, okay, go all out. Give me 70%, give me 50% rest for this much. And if I think about our professional career, if I had a coach who was looking to maximize my impact on the long term. Right. I mean, for athletes, it's only 10 years. For us, we have 40 years. They would actually tell me the same. And yet when we're in a job, we feel that either we feel bad about kind of coasting a little bit after a hard project, but we probably should be doing this. I mean, maybe don't advertise it because there's a bad stigma these days when you say, like, oh, I'm doing, but after you do something really tough, et cetera, I mean, yeah, it's kind of okay. Yeah, as long as that's not your. You're not getting stuck in that. Right?
Steve McConnell
Yeah. You know, I didn't really spend that long at Microsoft, but for some reason, this keeps coming back to that topic. And I think the being part of that is exciting for a while, but as you say, when it becomes a marathon or it becomes multiple marathons back to back, it doesn't really work as well. And you know, Microsoft in that era had a lot of stuff going on that wasn't really that exciting. And so there's this background culture that people have participated in where they're working themselves to death after a couple years. They're like, I don't really want to do this anymore. And so there were cases where as the years went by, they sort of developed an expectation that that was going to be the work mode. We're now in a completely different space when there's an expectation that it's going to occur rather than just the individuals doing it because that's what they want to do. And Microsoft, because they were so successful, got into a mode where they basically had to go to people and key products and say, we need you for one more release, because we've identified that we need to carry forward at least two of the key people from the last release to be successful on the next release. And they were basically saying, look, we'll give you enough stock to make you rich. But we need you one more release on this. And so now that's just a completely different vibe on the project than the one before.
Interviewer
So you mentioned that one topic you didn't write about, but maybe it could have been a good idea in hindsight is Rule of Energy. I wanted to ask you, since the second edition has been published, that must have been 20 something years as well, what are one or two other topics that if you wrote this book today, you might have added into it?
Steve McConnell
Yeah, so I think that really gets into the limitation of where I am professionally now. And I really have not been active in software at the code complete level for several years now. The irony of it is I've spent more time actually doing hands on programming just for my personal use the last five years than I did for probably 15 years before that. But it's really just one person project, me personally doing it. I think we've talked quite a bit in this conversation about design three times and I think one thing that has worked out really well for CodeComplete second edition is, is really that it is the second edition. And then I published it 11 years after the first edition. And so I think that was really kind of an ideal amount of time between the two editions because I had learned a lot in the intervening 10 years. The industry I think had matured quite a lot. And when I went back and started working on the second edition, I had a great vantage point for looking at, okay, what has changed since the first edition and really thinking through, well, what insights does that give me about the kinds of things that are shorter lived? And the whole point of the book was to try to capture the longer lived best practices that would span generations of technology and span programming languages and so on. So the 10 years between those two, there was some stuff in the first edition, it's like, yeah, okay, this really wasn't lasting, this needs to go. There was other stuff. It's like, wow, it's been 10 years, this really hasn't changed much at all. And I think when the second edition came out in 2004, Agile was really, it was beyond infancy. It was kind of at the toddler stage at that point, maybe a little beyond that. But we were still mostly focused on xp. Scrum really hadn't emerged as the dominant practice at that point. And so I think one of the challenges for me in the second edition was trying to figure out, okay, well, how much do I really want to talk about Agile and how much do I really want to talk about xp in particular, I decided really I only used XP in one example in the book, so I'm pretty happy with how that worked out. But in the first edition that consideration had really been about object oriented. Because when I was writing the first edition, object oriented was well established in academic circles, but not well established in practice. And so I made a decision to really not do very much with it. And in the intervening 10 years it became so well established that it wasn't really a separate topic. I originally thought I'd have some separate treatment of it, but really it just ended up weaving its way in really throughout the book and it didn't make sense to try to treat it as a separate topic. So I feel like the first edition had aged more in 10 years then the second edition has aged in 20 years.
Interviewer
Yeah, and I actually like, I just collected a few topics we don't need to go through, but the things that I thought did not age or actually aged well. So it's very applicable the parts of managing complexity you go through how you can use things like abstraction, clear conventions to reduce cognitive load.
Steve McConnell
Our brains have not gotten bigger in the last 20 years.
Interviewer
No cohesion and coupling how cohesion within modules, but also loose coupling between the modules help for more maintainable software also has not changed. I wanted to ask you, like in the book goes into the value of iteration, continuous improvement. Was this because I feel this is like, duh, like this is how we work. But at the time when you wrote it, was this a bit less accepted still or a bit more novel of idea? Because it's interesting to see things that were like today, like, obviously, but these are not how ideas start, right?
Steve McConnell
Yeah, no, it's a really interesting question and it does take me back to kind of the state of the world in 2004. In 2004, the reason we were talking about incrementalism and iteration had nothing to do with product delivery. It really had to do with efficient technical practices and a virtuous learning cycle. But kind of around 2004 we started to go from Internet brochureware to actual meaning meaningful, more rich functionality websites. So the idea of CICD wasn't really a concept in 2004, but we had done work for Amazon in about that same timeframe. And at the time AWS didn't exist, at least not by name. But what we'd observed in the work for Amazon was I thought they were okay at the technical programming level, but I thought they were probably the best in the world at operations, as we called it at the time. And their concept of just if it doesn't work, we'll roll it back. There just weren't a lot of organizations back then that could do that. And so, yeah, in the last 20 years, with mobile, well, Internet at first and then mobile and just functionality getting rolled out continuously, these two what's good for the learning cycle and for containing errors at the development level has merged very nicely with how you deliver functionality. Yeah, the product.
Interviewer
Yeah. And so today, like when I was writing my book, the Software Engineer's Guidebook that was published two years ago, one topic I was really unsure of, should I include or not a little bit to your agile thing was genai, because ChatGPT had come out about a year before, like before when I, when I finished my manuscript, like six months before and you could already see that it was big, it was great for learning, it was good at generating code. So I figured, should I add this or not? Because, and I, in the end I added it because it felt to me already all developers I knew were already using it, even if just to explain things. And since then, one of the biggest changes, how Genai is becoming. I'm not going to talk about the generic stuff, but for coding, it turns out it is very good at generating code. And for example, in the book, one technique that you encourage and what I've used before is the pseudocode programming process where you come up with pseudocode and for example, when you do that, it's great at giving it the more detailed pseudocode the better. And you can tell it generate Java, Kotlin, Rust, whatever. It does a great job of doing so. So I just wanted to get your thoughts in terms of first principles now that I know you've not been as embedded in software in the past few years, but knowing that there's this tool which is very good at generating code, it's a weird intelligence, it's not intelligent per se, it generates the next token, but it does it really well. And what we're seeing is it spits out code really, really quickly, oftentimes good, sometimes not. I think some people, I compare it when I talk with John Osterhart with the tactical tornado of doing so. And there is some scare with some developers of like, wow, it's actually coding better than I do. If you were like an early career professional in this industry, seeing that there's this tool that is actually good at spitting out code, not perfect code, but pretty good code, how would you think of making the most out of it for your career to understand how to tame this and how this might even change Software development. If it will, maybe it won't.
Steve McConnell
Yeah, well, I think it's pretty clear it will. I think it's totally unclear how it will. In my mind, we're still in the pretty early stages of how we would use any kind of AI for help with software development or really for help with anything. I think at this point in time, the lessons I feel like I've learned are the more guardrails you put in place, the better result you're going to get. There was a funny LinkedIn post yesterday from somebody who said the learnings about using AI and software are you've got to be really clear about your requirements. You've got to really define your test cases. Well, you've got to define all the exception cases really well. And the gist of it was, huh, this just sounds like good software development fundamentals. And only we are now. You know, AI is the thing that's finally, after 75 years forcing us to do this. And maybe it hasn't been 75 years.
Interviewer
That it's been, it has been 60 plus.
Steve McConnell
Yeah. So I mean, I think that that's funny, but it's also true. You know, one of the things that I think is true of software developers is developers are so tech oriented if you give them a tool to do something that works a lot better than giving them some rules or guidelines. And so if AI is a tool and now to get the tool to work, you've got to go through these software fundamentals. Yeah, maybe that is the thing that finally makes that happen. My other feeling about it, and I would love it if you correct me, if you feel like I'm off base on this, my other feeling is that I think writing the gold path or the happy path through the code has always been the easy part of coding and understanding which exception cases did I forget about or was I unaware of or did the requirements never capture in the first place? Fred Brooks published a paper called no Silver Bullets and he talks about the difference between accidental complexity and essential complexity. And a lot of the essential complexity comes from the real world because the real world is messy and to the degree that AI isn't 100% lined up with the messiness of the real world, then the programmer job of being the party that fully vets all of the exception cases and the corner cases and the off by ones and so on. That's the other thing that's concerning is I still think AI can't count and so off by 1 errors seem like they're just probably so I have to Agree.
Interviewer
Because I think we should not forget like obviously the interesting thing with AI, I talked with a really experienced engineer, Simon Willis, and he created the Django framework. He is a very productive Engineer for about 20 or 25 years, just like codes of a lot and writes really good code. And he's been using ChatGPT and all the other tools since they've come out. So coming up three years now. And he told me, because I asked like, hey Simon, is it worth understanding a theory? Because I took time to understand how this thing works. It's just matrixes everywhere, which is why GPUs work so well with them. Because it turns out 3D operations are also just matrix multiplications. So it's a huge matrixes that are hard for us to understand and they predict the next token.
Podcast Host
And.
Interviewer
And he said actually it might be a little bit harmful in his experience because you need to get a feel for how this works because now it does work. And he says that it just takes a lot of time to figure out where it works and where it doesn't. Now in his case, and I think for a lot of us more experienced engineers, it can be super helpful because as it works, I will call bs. I'll be like, this is bad and it often gets things really bad. So as long as I just use it as like this people think about it. I think Ken Beck said he thinks of it as his genie where it grants your wish, but sometimes in really funny ways, in really unexpected. For example, you tell like, oh, make this work and it does, or make it work and the test should not fail. And sometimes it will just go and delete the test when it cannot.
Steve McConnell
Early in my career, when I was at Boeing, we had a CDC cyber supercomputer. And the way the cyber supercomputer was explained to me is it's a very powerful, very literal giant that will do exactly what you tell it to do, but it's so literal that it has no ability to do anything other than exactly its interpretation of what you tell it to do. And I kind of feel like AI is in that same space. It's incredibly powerful. And you know, your comment about sometimes it's glaringly off. I don't worry about that case. I worry about it being subtly off.
Podcast Host
Yes.
Interviewer
And it is off subtly a lot. So there are some already some small stories that are going viral which are it could have happened to human. But a good example is startup. You know, they use one of these, one of the many agent which does stuff. It created a pr, it Looked good. And you know, it's after a while when it generates good stuff, you're like, looks good to me. You committed. So it just made a small change that added an observability logging to one of their things that was unnecessary. And this agent costs $500 a month and in a month it generated an extra $800 for nothing. And the guy was like, oh, okay. And I think we're gonna see a lot of these things. I think we'll have to ask ourselves again, like, what is software engineering? Because now what I'm hearing for teams that are using more of those AI is reviewing code is super important. But of course it is hard to. I remember when I again I worked at Uber is like, the more you got to know an engineer, sometimes you realize they're really reliable. So eventually in code review we needed two thumbs up or two people to accept. And when that person came and wrote their stuff and it was a long pull request, you tended to say, lgtm looks good to me without reading it. And of course, the shorter it is, we also started to have this rule. I don't have long poll requests because for a 500 line change most people were like, looks good to me because I just don't have the mentel capacity. For five lines you get like 50 comments saying, hey, what about this, what about that, et cetera. So it feels like we. I don't know when, but I think we're going to come back to some of the earlier learnings on Software Engine because this thing will not change whether it's a machine doing it or whether it's a human doing it, or whether a machine that is acting up, able to take on some things that a human can do, won't go anywhere.
Steve McConnell
Yeah. So sometimes programmers have difficulty just getting started. You mentioned the pseudocode programming process. I think that's something where AI can be pretty helpful. Your style says, hey, look, what are the steps I should. What are the different topics I should consider when I'm designing this? Okay, what sequence would make sense? You can basically dialog and say, give me a breakdown of this space and show me what the class design would look like. Okay, I don't like that. Give me a different breakdown. Show me what that would look like. The ability to iterate super quickly and insert your own brain into those iterations I think is incredibly valuable. And for that matter, it's incredibly stimulating to be the human in that loop. And then of course you can also say, what test cases should I consider? You can kind of pit it against itself. And I think at least my own experience with that is I haven't tried it on anything super complicated, but I think the general concept seems to work.
Interviewer
Yeah, these are definitely also one other thing that seems to be very useful is explaining things. May that be a language, a framework technology? Obviously you always need to double check, but some of them are already giving you references so it can speed you up a lot and help you. One thing I'm seeing seems to be happening across the industry is engineers are going to be more full stack in the sense of you might remember the time where there was Java Engineer and Net Engineer and they didn't mix. And then later at my time when I started to where we now had backend engineers work across languages. You could do multiple and that was kind of expected. But still backend and front end and mobile were separate. And now with the help of these things, you know, like a backend engineer can generate a mobile pull request and so on. Yeah.
Steve McConnell
And you know, one of your questions or one of the threads has been kind of what's changed over the years. I think what you just described is a huge change where first edition of code complete. A lot of readers would have learned one programming language when they read the book. By the second edition, maybe it was more common or more universal for people to have learned two or three. But the idea that it's just assumed that you're going to learn a few because you need to be using a few on a day to day basis in your job as a full stack engineer, that's just a complete change. And I think the mental development that goes along with that of understanding what's common and what's different across languages, I mean that's just really valuable.
Interviewer
Yeah. And I also wonder if it will be really valuable now because I feel the breadth keeps increasing. But don't Forget back in 30 or 40 years ago, the people who learned one language, they were just as smart as the people now. I guess the difference is and they probably store equal knowledge, they need to know way more details. There are a lot more this and that. So I wonder if it'll be more really valuable. We now have a lot more breadth for sure, but you cannot have as much depth. So the people who are able to balance this and even though you have access to this genie that can explain everything, actually taking the time to understand and have that mental model, you'll probably go further.
Steve McConnell
Yeah. I think in thinking about the Fred Brooks no Silver Bullets paper, which is pretty interesting to think about in terms of AI because the whole premise, the whole concept of a silver bullet is any single innovation technology development method that by itself is capable of producing an order of magnitude improvement over a 10 year period. You know, AI might very well be the thing that is the exception to the rule in that paper. But you know, the basic argument is that the real world messiness and other sources of essential complexity aren't going away. And unless you find a tool that can deal effectively and utterly reliably with all those details, the corner cases, the off by one cases, all that stuff, you know, programming, we don't get to be approximately right, we have to be exactly right. And so, you know, that's really, I think to me the gist of it, if AI can get to the point where it's exactly right, then you know, maybe we really do start to replace programming jobs with AI. But the whole history of programming as languages have gotten more powerful and more expressive, tools have gotten more powerful and more expressive. I think that the defining characteristic of a programmer is being the person whose job it is to figure out what is exactly right. And if AI just basically changes the playing field. So now you're trying to identify what's exactly right with AI generated output, to me it's almost the same job it always was.
Interviewer
Yeah. And don't forget that AI generates code and that code at some point needs to be understood, especially because they can get into loops, you know, again they can, they can get confused because again, just how it works. Well, once we understand that. So there is value both in that, but also I feel like there's this thinking as well. I'm not sure I subscribe full of, but how. We used to have assembly as the programming language, machine code. Then there was C or C, then we had compiled languages. We have some visual languages or Visual Basic. And this can be seen as like yet another layer where English translates to this. Except it's not a one on one mapping like all the other ones. So it's a lot more stink. We'll see where it goes. It's changing things, but I think the history of programming has been layers upon layers of you added abstraction, more people can get started. I mean COBOL apparently was invented to make it a lot easier for developers to get started.
Steve McConnell
Everything was invented to eliminate programming. All the programming was invented to eliminate programming. And yet here we are, including fortran. Yeah, so I would take what you say and I would look at it from a slightly different angle, which is I think the history of programming is a history of increasing levels of aggregation so you started out with assembly or machine language, and then you had aggregation into assembly, and that was one level of aggregation. Then you had aggregation into macro assembly. So as a second level of aggregation, then you had this amazing invention called the subroutine, which was an aggregation of callable functionality. And then you had an aggregation into classes where you had a combination of data and functionality. And then, I don't know, it kind of, at least that's kind of where my knowledge of it, my direct involvement of it kind of started off.
Interviewer
And now I think you have a combination of these reusable functionality or things that, you know, like some, some of the, the AI can definitely spit out things that it's seen a lot.
Steve McConnell
Yeah.
Interviewer
And, and actually we even had like, you know, some, some templates. So, you know, we'll, we'll see how it goes. But I, I like this idea. I think it makes sense, you know.
Steve McConnell
And maybe it is truly that above. And you know, there were lots of attempts to have the next level of aggregation way back when ADA had notion of packages and C had notion namespaces. And you know, there have been other attempts and maybe there's a, an environment out there that I don't know about, which is entirely possible that has done a great job of aggregating packages with their own interface and their own behavioral rules and so on. But if AI ends up being the way to achieve the next level of aggregation, that would kind of make sense.
Interviewer
Well, maybe. But don't forget one thing that I think we just didn't. Neither of us mentioned a huge difference with AI and everything else that came before it is, it's non deterministic. And in programming we have been used to, and I think we've gotten really good at making the most of deterministic and non determinism always has its dangers, its flaws. It's harder to work with. And often, especially when you have a non deterministic system and you want a deterministic outcome, you need to do a bunch of work around that. So maybe that'll keep us busy for a while. And sometimes it's not possible. By the way, as closing, you've had a long and successful career. You've written a book that actually kickstarted a lot of people's careers. I had one of my colleagues from one of my companies tell me that in their first few years as a developer actually served as the military. And they read the book and it really helped them. What suggestions would you have for an engineer to have a durable career? Principles that worked for you probably independent of technology.
Steve McConnell
When I was writing the first edition of the book, one of the things I tried to keep firmly in mind was that the guiding principle for writing the book and the principle that answered every question was, does this make the book more valuable for the reader? And so there were some things that I kind of liked but maybe were idiosyncratic to me. I ultimately decided that doesn't make it more valuable for the reader. So I left them out. Design elements of the book, content of the book, everything was about what makes this more valuable for the reader. And as I iterated on that over the course of writing the book, I think that iteration with that in mind just added up to something. And I think the same thing would. My career advice would be exactly the same. What makes you more valuable to your organization or to the world at large? And, you know, it's not like anybody. I would think someone's a bad person if they don't think that way. But if everything you're doing is just to scratch some personal itch, it's idiosyncratic. You're interested in it, but it doesn't add up to something. Just be aware, that's a lost opportunity. And if, on the other hand, every time you think about, well, what project should I do next, what do I want to do next in the organization, Sometimes you don't get a choice. Sometimes you do get a choice between option A and option B. Does option B open up more doors possibly than option A? Well, maybe you should choose option B for that reason. Does one of them make you more valuable? Choose it for that reason. And I don't think this is just about personal development or personal success. I think it's about making the world better. If you're making yourself more valuable, you're increasing your ability to contribute to the world. And I think that's a virtuous thing.
Interviewer
And you close the book with how you emphasize how craftsmanship is important for professional growth. And you write how curiosity, continuous learning are essential traits of great software engineers. And to me, it feels this is just as relevant as ever.
Steve McConnell
I just think it's part of the human experience. And I think that programmers, probably more than average, are curious people who like to learn, who are attracted to novelty, who want to learn what's new and what's cool, and who want to explore what's possible with what's new and cool. A lot of our conversation today about AI has been all about exploring what's possible with what's new and cool. I think this is just the way programmers are and I wouldn't change that.
Interviewer
Steve, it's been both a really good conversation and a privilege. Thank you so much.
Steve McConnell
Thanks so much for having me.
Podcast Host
It was such a blast to interview Steve. After the interview we grabbed dinner at one of his favorite local restaurants and he told me more about why he decided to make a shift and leave the software industry after a successful 30 plus year career to try something different. Steve's energy levels, positivity and thoughtfulness run deep and I hope this came across through the podcast as well. For more observations on how the software engineering industry has changed the last few decades, check out related Deep Dives into Pragmatic Engineer which are linked in the show notes below. If you enjoy this podcast, please do subscribe on our favorite podcast player and on YouTube. This helps more people discover the podcast and a special thank you if you leave a rating. Thanks and see you in the next one.
Host: Gergely Orosz | Guest: Steve McConnell | Date: September 10, 2025
In this episode, Gergely Orosz sits down with Steve McConnell, celebrated author of the seminal software engineering book Code Complete. The conversation journeys through the history of writing the book, its unexpected impact, McConnell’s foundational concepts on software construction, key lessons for software engineers’ careers, and the evolving landscape brought by AI and changing workplace cultures. With his trademark clarity, McConnell shares deep insights on sustainable craftsmanship, iteration, and the mental frameworks that helped shape both his authorship and professional trajectory.
From Article to Tome:
Early Career Perspective:
Unexpected Success:
Inspiring Coding Horror & Stack Overflow:
Software Construction as a Discipline:
Top-Down vs. Bottom-Up Thinking:
Embrace Iteration:
Practice Makes Proficient:
The Career Pyramid:
The Danger of Lily Pad Hopping:
Empowerment and Initiative:
Adaptability as Industry Evolves:
The Power of Team Energy:
Sustainable Pace vs. Crunch:
Skills Triad:
Manager vs. IC:
AI as a Disruptive Force:
Guardrails and Fundamentals:
Breadth, Abstraction, and the “Next Layer”:
Non-Determinism:
| Timestamp | Speaker | Quote | |------------|--------------------|-------------------------------------------------------------------------------------------------| | 02:01 | Steve McConnell | “I convinced myself that this book didn’t exist. And this was just baffling... there wasn’t a book on the main thing that programmers do, which is software construction.” | | 07:45 | Steve McConnell | “If you put out good things into the world... there are positive ripple effects.” | | 12:35 | Steve McConnell | “I would write the book inductively... start out talking about specifics and build up… more programmers are oriented that direction.” | | 17:15 | Steve McConnell | “...you rewrite it in 45 minutes and as you go you remember all the lessons that you learned... It actually turns out probably better than if you’d never lost it in the first place.” | | 30:07 | Steve McConnell | “I wanted to be essentially more than the sum of the parts.” | | 33:10 | Steve McConnell | “Nobody needs to give you permission to do your job well.” | | 53:25 | Steve McConnell | “Focused application of personal energy makes up for a lot of other deficiencies.” | | 73:09 | Steve McConnell | “The more guardrails you put in place, the better result you get... this just sounds like good software development fundamentals.” | | 83:14 | Steve McConnell | “Programming, we don’t get to be approximately right, we have to be exactly right... If AI just changes the playing field... it’s almost the same job it always was.” | | 86:54 | Steve McConnell | “What makes you more valuable to your organization or to the world at large?... that’s a lost opportunity [if you ignore it].” | | 89:03 | Steve McConnell | “Programmers are curious people who like to learn, who are attracted to novelty... I wouldn’t change that.” |
The discussion is collegial, direct, and thoughtful—blending Steve McConnell’s pragmatic, experience-driven takeaways with Gergely Orosz’s incisive, contemporary perspective. The episode is rich in wisdom for hands-on engineers, managers, and anyone seeking to craft a meaningful, lasting technology career.
For more deep-dives and discussions on building great software and durable engineering cultures, visit newsletter.pragmaticengineer.com.