際際滷

際際滷Share a Scribd company logo
LESSONS LEARNED ABOUT SOFTWARE DEVELOPMENT

Hello, my name is Jeff Thalhammer. I've been a software developer for a few years. I still have
a lot to learn about my profession, but I would like to think I have acquired a few bits of wisdom
over the years. So in the next 鍖ve minutes, I'm going to share with you the most important
lessons that I have learned about software development...

                          Lesson 1: The best code is no code at all.

The moment you begin writing code, you start creating bugs. Every line of code is a future
liability. So the less code you have, the less risk you take on. This may sound counter-intuitive,
but good software development is all about avoiding writing code.

Code-avoidance happens in a lot of ways. For example, you might be tasked with writing code
to add up the sales 鍖gures on the quarterly TPS reports. But if you do a bit of digging, you'll 鍖nd
that you can just get the total by calling Mary over in the accounting department. Bam! Problem
solved with no code.

Open source and commercial products are another good way to avoid code. Despite what you
might like to think, you are not special. A lot of problems have already been solved by people a
lot smarter than you or I. And if their solutions don't seem to 鍖t, then you really need to think
hard and justify why your needs are so different.

Software itself is actually full of code-avoidance mechanisms: subroutines, libraries, object
orientation, web services, virtualization, cloud computing. These all exist for the purpose of not
writing code. Use them.

As developers, it is hard to resist the temptation to write code. That's what we are here for after
all. But that isn't really your job. Your job is to help solve problems in the most effective and
prudent way that you know how. Code is just *one* of the weapons in your problem-solving
arsenal. So think about that before you write your next line of code.

                Lesson 2: Code is for humans 鍖rst, and computers second.

Once you've concluded that you actually must write some code, you need to remember who you
are writing it for. And no, you are not writing code for the computer.

Like all languages, programming languages are just a way for us humans to communicate with
each other and ourselves. We typically think that code is the "solution". But it's not. Code is
actually how we express the *problem*. Once you've fully expressed the problem, then a
computer will dutifully execute the solution. But -- this is key -- the problem is ours, not the
computer's.

Unfortunately, computers aren't very smart. So we have to invent these awkward little
languages they can understand. But we get so caught up in those little languages that we let
them constrain our own ability to express ourselves clearly, often to the point that we don't even
understand it.

So when you write code, remember that you are actually trying to express a real human problem
in an arti鍖cial language. So the more your code resembles a human language, the more likely it
is to be an accurate de鍖nition of the problem. And if the problem is de鍖ned well, then the
computer will probably give you the right solution.

                   Lesson 3: You Are Not As Smart As You Think You Are.

In many professions, you can at least identify the entire body of knowledge that you'll ever need
in that career. But the software industry is constantly evolving. Most of the things you learned
鍖ve years ago are no longer relevant, or may be down right incorrect. True, some changes are
just fads and some learning is inevitably wasted on dead-end ideas. But how will you know
which are which?

The only way for a person or an organization to succeed in this business is to constantly keep
learning. More importantly, you must learn how to learn effectively. You must question your old
habits, seek alternative perspectives, and acquire knew knowledge. And just as important, you
must act on that knowledge. Otherwise, it is just trivia.

So the challenge is to cultivate an organization that promotes effective learning. The good news
is that learning opportunities are everywhere. Every line of code, every presentation, every
meeting is an opportunity. But 鍖rst, you must instill people (or yourself) with traditions and values
that enable them to recognize and exploit those opportunities.

             Lesson 4: Software development is 80% social and 20% technical.

Writing code is the easy part. Anyone can do it. There are millions of developers in China and
India who are willing and able to write code for you. And when technical questions arise, most of
the answers are freely available. Just ask Google. The really hard part is 鍖guring out *what*
code to write.

Figuring out what to write requires asking a lot of questions: What is the real problem we are
trying to solve? Which parts of the problem are constant? Which parts are subject to change?
How likely is it to change? Which are the critical features? Which features are 鍖uff? What kind
of resources to we have available? The answers to these questions require conversations with
actual human beings.

So the message here is that to succeed in this industry, your social skills need be just as good
(or even better) than your technical skills. You need to be able to communicate with people and
鍖nd out what they really need, how they feel, what their history is, what their goals are, what they
are doing.

When working on a team, we all have different roles to play -- we each have our own areas of
strength -- and that's 鍖ne. But as a whole, the team must balance their technical and social
skills. The unfortunate thing is that most organizations don't (or can't) really operate as teams.
Developers end up playing lots of roles, some of which they haven't really mastered. So for
them to succeed as individuals in that kind of environment, developers also need to be mindful of
the balance between their own social and technical skills.

Final thoughts: Quality is not an act, it is a habit. --Aristotle

Thanks for your time.

More Related Content

Similar to Lessons Learned About Software Development (20)

Why learn how to code
Why learn how to codeWhy learn how to code
Why learn how to code
Joey Rigor
The passionate programmer
The passionate programmerThe passionate programmer
The passionate programmer
Mahmoud Tolba
Trends In Technical Communication
Trends In Technical CommunicationTrends In Technical Communication
Trends In Technical Communication
Bogo Vatovec
How To Win At Software - Advice for New Engineers - by Gabe Johnson
How To Win At Software - Advice for New Engineers - by Gabe JohnsonHow To Win At Software - Advice for New Engineers - by Gabe Johnson
How To Win At Software - Advice for New Engineers - by Gabe Johnson
Gabe Johnson
Choose Boring Technology
Choose Boring TechnologyChoose Boring Technology
Choose Boring Technology
Dan McKinley
How to learn coding
How to learn codingHow to learn coding
How to learn coding
HananeMessad1
A Cup of Tea With Michael Larsen
A Cup of Tea With Michael LarsenA Cup of Tea With Michael Larsen
A Cup of Tea With Michael Larsen
Michael Larsen
22 practical skills that everyone should learn in 2021
22 practical skills that everyone should learn in 202122 practical skills that everyone should learn in 2021
22 practical skills that everyone should learn in 2021
Mirza Rihad Ali Sunny
How to tell a better story (in code)(final)
How to tell a better story (in code)(final)How to tell a better story (in code)(final)
How to tell a better story (in code)(final)
Bonnie Pan
Clean Code Software Engineering
Clean Code Software Engineering Clean Code Software Engineering
Clean Code Software Engineering
Inocentshuja Ahmad
How to become a great developer
How to become a great developerHow to become a great developer
How to become a great developer
Netcetera
How to Master AI Prompt Engineering Skills for Future Growth
How to Master AI Prompt Engineering Skills for Future GrowthHow to Master AI Prompt Engineering Skills for Future Growth
How to Master AI Prompt Engineering Skills for Future Growth
SOFTTECHHUB
ERE Job Descriptions Presentation - John Greer
ERE Job Descriptions Presentation - John GreerERE Job Descriptions Presentation - John Greer
ERE Job Descriptions Presentation - John Greer
John Greer
C Programming_ Step By Step Beginner's To Experts _ Nho V挑nh Share
C Programming_ Step By Step Beginner's To Experts _ Nho V挑nh ShareC Programming_ Step By Step Beginner's To Experts _ Nho V挑nh Share
C Programming_ Step By Step Beginner's To Experts _ Nho V挑nh Share
Nho V挑nh
Future of IT preso
Future of IT presoFuture of IT preso
Future of IT preso
Lorna Garey
Software piracy
Software piracySoftware piracy
Software piracy
John Pereless
Community engagement
Community engagementCommunity engagement
Community engagement
Ross Turk
Coding lessons.pdf
Coding lessons.pdfCoding lessons.pdf
Coding lessons.pdf
marinandroic24
UCD / IxD Introduction - User centric design, interaction design
UCD / IxD Introduction - User centric design, interaction designUCD / IxD Introduction - User centric design, interaction design
UCD / IxD Introduction - User centric design, interaction design
sdavis6b
How to Become a Conference Speaker
How to Become a Conference SpeakerHow to Become a Conference Speaker
How to Become a Conference Speaker
Sven Peters
Why learn how to code
Why learn how to codeWhy learn how to code
Why learn how to code
Joey Rigor
The passionate programmer
The passionate programmerThe passionate programmer
The passionate programmer
Mahmoud Tolba
Trends In Technical Communication
Trends In Technical CommunicationTrends In Technical Communication
Trends In Technical Communication
Bogo Vatovec
How To Win At Software - Advice for New Engineers - by Gabe Johnson
How To Win At Software - Advice for New Engineers - by Gabe JohnsonHow To Win At Software - Advice for New Engineers - by Gabe Johnson
How To Win At Software - Advice for New Engineers - by Gabe Johnson
Gabe Johnson
Choose Boring Technology
Choose Boring TechnologyChoose Boring Technology
Choose Boring Technology
Dan McKinley
How to learn coding
How to learn codingHow to learn coding
How to learn coding
HananeMessad1
A Cup of Tea With Michael Larsen
A Cup of Tea With Michael LarsenA Cup of Tea With Michael Larsen
A Cup of Tea With Michael Larsen
Michael Larsen
22 practical skills that everyone should learn in 2021
22 practical skills that everyone should learn in 202122 practical skills that everyone should learn in 2021
22 practical skills that everyone should learn in 2021
Mirza Rihad Ali Sunny
How to tell a better story (in code)(final)
How to tell a better story (in code)(final)How to tell a better story (in code)(final)
How to tell a better story (in code)(final)
Bonnie Pan
Clean Code Software Engineering
Clean Code Software Engineering Clean Code Software Engineering
Clean Code Software Engineering
Inocentshuja Ahmad
How to become a great developer
How to become a great developerHow to become a great developer
How to become a great developer
Netcetera
How to Master AI Prompt Engineering Skills for Future Growth
How to Master AI Prompt Engineering Skills for Future GrowthHow to Master AI Prompt Engineering Skills for Future Growth
How to Master AI Prompt Engineering Skills for Future Growth
SOFTTECHHUB
ERE Job Descriptions Presentation - John Greer
ERE Job Descriptions Presentation - John GreerERE Job Descriptions Presentation - John Greer
ERE Job Descriptions Presentation - John Greer
John Greer
C Programming_ Step By Step Beginner's To Experts _ Nho V挑nh Share
C Programming_ Step By Step Beginner's To Experts _ Nho V挑nh ShareC Programming_ Step By Step Beginner's To Experts _ Nho V挑nh Share
C Programming_ Step By Step Beginner's To Experts _ Nho V挑nh Share
Nho V挑nh
Future of IT preso
Future of IT presoFuture of IT preso
Future of IT preso
Lorna Garey
Community engagement
Community engagementCommunity engagement
Community engagement
Ross Turk
UCD / IxD Introduction - User centric design, interaction design
UCD / IxD Introduction - User centric design, interaction designUCD / IxD Introduction - User centric design, interaction design
UCD / IxD Introduction - User centric design, interaction design
sdavis6b
How to Become a Conference Speaker
How to Become a Conference SpeakerHow to Become a Conference Speaker
How to Become a Conference Speaker
Sven Peters

More from Jeffrey Ryan Thalhammer (6)

I Got 99 Problems But CPAN Ain't One
I Got 99 Problems But CPAN Ain't OneI Got 99 Problems But CPAN Ain't One
I Got 99 Problems But CPAN Ain't One
Jeffrey Ryan Thalhammer
Pinto+Stratopan+Love
Pinto+Stratopan+LovePinto+Stratopan+Love
Pinto+Stratopan+Love
Jeffrey Ryan Thalhammer
Dependency Management With Pinto
Dependency Management With PintoDependency Management With Pinto
Dependency Management With Pinto
Jeffrey Ryan Thalhammer
Perl Critic In Depth
Perl Critic In DepthPerl Critic In Depth
Perl Critic In Depth
Jeffrey Ryan Thalhammer
CPAN For Private Code
CPAN For Private CodeCPAN For Private Code
CPAN For Private Code
Jeffrey Ryan Thalhammer
Evolving Tests
Evolving TestsEvolving Tests
Evolving Tests
Jeffrey Ryan Thalhammer

Recently uploaded (20)

Windows Client Privilege Escalation-Shared.pptx
Windows Client Privilege Escalation-Shared.pptxWindows Client Privilege Escalation-Shared.pptx
Windows Client Privilege Escalation-Shared.pptx
Oddvar Moe
I am afraid of no test! The power of BDD
I am afraid of no test! The power of BDDI am afraid of no test! The power of BDD
I am afraid of no test! The power of BDD
Ortus Solutions, Corp
The Future of Materials: Transitioning from Silicon to Alternative Metals
The Future of Materials: Transitioning from Silicon to Alternative MetalsThe Future of Materials: Transitioning from Silicon to Alternative Metals
The Future of Materials: Transitioning from Silicon to Alternative Metals
anupriti
SAP Automation with UiPath: SAP Test Automation - Part 5 of 8
SAP Automation with UiPath: SAP Test Automation - Part 5 of 8SAP Automation with UiPath: SAP Test Automation - Part 5 of 8
SAP Automation with UiPath: SAP Test Automation - Part 5 of 8
DianaGray10
際際滷s from Perth MuleSoft Meetup March 2025
際際滷s from Perth MuleSoft Meetup March 2025際際滷s from Perth MuleSoft Meetup March 2025
際際滷s from Perth MuleSoft Meetup March 2025
Michael Price
UiPath Automation Developer Associate Training Series 2025 - Session 8
UiPath Automation Developer Associate Training Series 2025 - Session 8UiPath Automation Developer Associate Training Series 2025 - Session 8
UiPath Automation Developer Associate Training Series 2025 - Session 8
DianaGray10
A General introduction to Ad ranking algorithms
A General introduction to Ad ranking algorithmsA General introduction to Ad ranking algorithms
A General introduction to Ad ranking algorithms
Buhwan Jeong
The Rise of AI Agents-From Automation to Autonomous Technology
The Rise of AI Agents-From Automation to Autonomous TechnologyThe Rise of AI Agents-From Automation to Autonomous Technology
The Rise of AI Agents-From Automation to Autonomous Technology
Impelsys Inc.
Harnessing the Power of AI in Salesforce.pdf
Harnessing the Power of AI in Salesforce.pdfHarnessing the Power of AI in Salesforce.pdf
Harnessing the Power of AI in Salesforce.pdf
rabiabajaj1
STRING FUNCTIONS IN JAVA BY N SARATH KUMAR
STRING FUNCTIONS IN JAVA BY N SARATH KUMARSTRING FUNCTIONS IN JAVA BY N SARATH KUMAR
STRING FUNCTIONS IN JAVA BY N SARATH KUMAR
Sarathkumar Narsupalli
Benefits of Moving Ellucian Banner to Oracle Cloud
Benefits of Moving Ellucian Banner to Oracle CloudBenefits of Moving Ellucian Banner to Oracle Cloud
Benefits of Moving Ellucian Banner to Oracle Cloud
AstuteBusiness
Recruiting Tech: A Look at Why AI is Actually OG
Recruiting Tech: A Look at Why AI is Actually OGRecruiting Tech: A Look at Why AI is Actually OG
Recruiting Tech: A Look at Why AI is Actually OG
Matt Charney
Fast Screen Recorder v2.1.0.11 Crack Updated [April-2025]
Fast Screen Recorder v2.1.0.11 Crack Updated [April-2025]Fast Screen Recorder v2.1.0.11 Crack Updated [April-2025]
Fast Screen Recorder v2.1.0.11 Crack Updated [April-2025]
jackalen173
Presentation Session 2 -Context Grounding.pdf
Presentation Session 2 -Context Grounding.pdfPresentation Session 2 -Context Grounding.pdf
Presentation Session 2 -Context Grounding.pdf
Mukesh Kala
How AWS Encryption Key Options Impact Your Security and Compliance
How AWS Encryption Key Options Impact Your Security and ComplianceHow AWS Encryption Key Options Impact Your Security and Compliance
How AWS Encryption Key Options Impact Your Security and Compliance
Chris Bingham
How to manage technology risk and corporate growth
How to manage technology risk and corporate growthHow to manage technology risk and corporate growth
How to manage technology risk and corporate growth
Arlen Meyers, MD, MBA
UiPath NY AI Series: Session 4: UiPath AutoPilot for Developers using Studio Web
UiPath NY AI Series: Session 4: UiPath AutoPilot for Developers using Studio WebUiPath NY AI Series: Session 4: UiPath AutoPilot for Developers using Studio Web
UiPath NY AI Series: Session 4: UiPath AutoPilot for Developers using Studio Web
DianaGray10
Making GenAI Work: A structured approach to implementation
Making GenAI Work: A structured approach to implementationMaking GenAI Work: A structured approach to implementation
Making GenAI Work: A structured approach to implementation
Jeffrey Funk
Scalable Multi-Agent AI with AutoGen by Udai
Scalable Multi-Agent AI with AutoGen by UdaiScalable Multi-Agent AI with AutoGen by Udai
Scalable Multi-Agent AI with AutoGen by Udai
Udaiappa Ramachandran
Graphs & GraphRAG - Essential Ingredients for GenAI
Graphs & GraphRAG - Essential Ingredients for GenAIGraphs & GraphRAG - Essential Ingredients for GenAI
Graphs & GraphRAG - Essential Ingredients for GenAI
Neo4j
Windows Client Privilege Escalation-Shared.pptx
Windows Client Privilege Escalation-Shared.pptxWindows Client Privilege Escalation-Shared.pptx
Windows Client Privilege Escalation-Shared.pptx
Oddvar Moe
I am afraid of no test! The power of BDD
I am afraid of no test! The power of BDDI am afraid of no test! The power of BDD
I am afraid of no test! The power of BDD
Ortus Solutions, Corp
The Future of Materials: Transitioning from Silicon to Alternative Metals
The Future of Materials: Transitioning from Silicon to Alternative MetalsThe Future of Materials: Transitioning from Silicon to Alternative Metals
The Future of Materials: Transitioning from Silicon to Alternative Metals
anupriti
SAP Automation with UiPath: SAP Test Automation - Part 5 of 8
SAP Automation with UiPath: SAP Test Automation - Part 5 of 8SAP Automation with UiPath: SAP Test Automation - Part 5 of 8
SAP Automation with UiPath: SAP Test Automation - Part 5 of 8
DianaGray10
際際滷s from Perth MuleSoft Meetup March 2025
際際滷s from Perth MuleSoft Meetup March 2025際際滷s from Perth MuleSoft Meetup March 2025
際際滷s from Perth MuleSoft Meetup March 2025
Michael Price
UiPath Automation Developer Associate Training Series 2025 - Session 8
UiPath Automation Developer Associate Training Series 2025 - Session 8UiPath Automation Developer Associate Training Series 2025 - Session 8
UiPath Automation Developer Associate Training Series 2025 - Session 8
DianaGray10
A General introduction to Ad ranking algorithms
A General introduction to Ad ranking algorithmsA General introduction to Ad ranking algorithms
A General introduction to Ad ranking algorithms
Buhwan Jeong
The Rise of AI Agents-From Automation to Autonomous Technology
The Rise of AI Agents-From Automation to Autonomous TechnologyThe Rise of AI Agents-From Automation to Autonomous Technology
The Rise of AI Agents-From Automation to Autonomous Technology
Impelsys Inc.
Harnessing the Power of AI in Salesforce.pdf
Harnessing the Power of AI in Salesforce.pdfHarnessing the Power of AI in Salesforce.pdf
Harnessing the Power of AI in Salesforce.pdf
rabiabajaj1
STRING FUNCTIONS IN JAVA BY N SARATH KUMAR
STRING FUNCTIONS IN JAVA BY N SARATH KUMARSTRING FUNCTIONS IN JAVA BY N SARATH KUMAR
STRING FUNCTIONS IN JAVA BY N SARATH KUMAR
Sarathkumar Narsupalli
Benefits of Moving Ellucian Banner to Oracle Cloud
Benefits of Moving Ellucian Banner to Oracle CloudBenefits of Moving Ellucian Banner to Oracle Cloud
Benefits of Moving Ellucian Banner to Oracle Cloud
AstuteBusiness
Recruiting Tech: A Look at Why AI is Actually OG
Recruiting Tech: A Look at Why AI is Actually OGRecruiting Tech: A Look at Why AI is Actually OG
Recruiting Tech: A Look at Why AI is Actually OG
Matt Charney
Fast Screen Recorder v2.1.0.11 Crack Updated [April-2025]
Fast Screen Recorder v2.1.0.11 Crack Updated [April-2025]Fast Screen Recorder v2.1.0.11 Crack Updated [April-2025]
Fast Screen Recorder v2.1.0.11 Crack Updated [April-2025]
jackalen173
Presentation Session 2 -Context Grounding.pdf
Presentation Session 2 -Context Grounding.pdfPresentation Session 2 -Context Grounding.pdf
Presentation Session 2 -Context Grounding.pdf
Mukesh Kala
How AWS Encryption Key Options Impact Your Security and Compliance
How AWS Encryption Key Options Impact Your Security and ComplianceHow AWS Encryption Key Options Impact Your Security and Compliance
How AWS Encryption Key Options Impact Your Security and Compliance
Chris Bingham
How to manage technology risk and corporate growth
How to manage technology risk and corporate growthHow to manage technology risk and corporate growth
How to manage technology risk and corporate growth
Arlen Meyers, MD, MBA
UiPath NY AI Series: Session 4: UiPath AutoPilot for Developers using Studio Web
UiPath NY AI Series: Session 4: UiPath AutoPilot for Developers using Studio WebUiPath NY AI Series: Session 4: UiPath AutoPilot for Developers using Studio Web
UiPath NY AI Series: Session 4: UiPath AutoPilot for Developers using Studio Web
DianaGray10
Making GenAI Work: A structured approach to implementation
Making GenAI Work: A structured approach to implementationMaking GenAI Work: A structured approach to implementation
Making GenAI Work: A structured approach to implementation
Jeffrey Funk
Scalable Multi-Agent AI with AutoGen by Udai
Scalable Multi-Agent AI with AutoGen by UdaiScalable Multi-Agent AI with AutoGen by Udai
Scalable Multi-Agent AI with AutoGen by Udai
Udaiappa Ramachandran
Graphs & GraphRAG - Essential Ingredients for GenAI
Graphs & GraphRAG - Essential Ingredients for GenAIGraphs & GraphRAG - Essential Ingredients for GenAI
Graphs & GraphRAG - Essential Ingredients for GenAI
Neo4j

Lessons Learned About Software Development

  • 1. LESSONS LEARNED ABOUT SOFTWARE DEVELOPMENT Hello, my name is Jeff Thalhammer. I've been a software developer for a few years. I still have a lot to learn about my profession, but I would like to think I have acquired a few bits of wisdom over the years. So in the next 鍖ve minutes, I'm going to share with you the most important lessons that I have learned about software development... Lesson 1: The best code is no code at all. The moment you begin writing code, you start creating bugs. Every line of code is a future liability. So the less code you have, the less risk you take on. This may sound counter-intuitive, but good software development is all about avoiding writing code. Code-avoidance happens in a lot of ways. For example, you might be tasked with writing code to add up the sales 鍖gures on the quarterly TPS reports. But if you do a bit of digging, you'll 鍖nd that you can just get the total by calling Mary over in the accounting department. Bam! Problem solved with no code. Open source and commercial products are another good way to avoid code. Despite what you might like to think, you are not special. A lot of problems have already been solved by people a lot smarter than you or I. And if their solutions don't seem to 鍖t, then you really need to think hard and justify why your needs are so different. Software itself is actually full of code-avoidance mechanisms: subroutines, libraries, object orientation, web services, virtualization, cloud computing. These all exist for the purpose of not writing code. Use them. As developers, it is hard to resist the temptation to write code. That's what we are here for after all. But that isn't really your job. Your job is to help solve problems in the most effective and prudent way that you know how. Code is just *one* of the weapons in your problem-solving arsenal. So think about that before you write your next line of code. Lesson 2: Code is for humans 鍖rst, and computers second. Once you've concluded that you actually must write some code, you need to remember who you are writing it for. And no, you are not writing code for the computer. Like all languages, programming languages are just a way for us humans to communicate with each other and ourselves. We typically think that code is the "solution". But it's not. Code is actually how we express the *problem*. Once you've fully expressed the problem, then a computer will dutifully execute the solution. But -- this is key -- the problem is ours, not the computer's. Unfortunately, computers aren't very smart. So we have to invent these awkward little languages they can understand. But we get so caught up in those little languages that we let them constrain our own ability to express ourselves clearly, often to the point that we don't even understand it. So when you write code, remember that you are actually trying to express a real human problem in an arti鍖cial language. So the more your code resembles a human language, the more likely it
  • 2. is to be an accurate de鍖nition of the problem. And if the problem is de鍖ned well, then the computer will probably give you the right solution. Lesson 3: You Are Not As Smart As You Think You Are. In many professions, you can at least identify the entire body of knowledge that you'll ever need in that career. But the software industry is constantly evolving. Most of the things you learned 鍖ve years ago are no longer relevant, or may be down right incorrect. True, some changes are just fads and some learning is inevitably wasted on dead-end ideas. But how will you know which are which? The only way for a person or an organization to succeed in this business is to constantly keep learning. More importantly, you must learn how to learn effectively. You must question your old habits, seek alternative perspectives, and acquire knew knowledge. And just as important, you must act on that knowledge. Otherwise, it is just trivia. So the challenge is to cultivate an organization that promotes effective learning. The good news is that learning opportunities are everywhere. Every line of code, every presentation, every meeting is an opportunity. But 鍖rst, you must instill people (or yourself) with traditions and values that enable them to recognize and exploit those opportunities. Lesson 4: Software development is 80% social and 20% technical. Writing code is the easy part. Anyone can do it. There are millions of developers in China and India who are willing and able to write code for you. And when technical questions arise, most of the answers are freely available. Just ask Google. The really hard part is 鍖guring out *what* code to write. Figuring out what to write requires asking a lot of questions: What is the real problem we are trying to solve? Which parts of the problem are constant? Which parts are subject to change? How likely is it to change? Which are the critical features? Which features are 鍖uff? What kind of resources to we have available? The answers to these questions require conversations with actual human beings. So the message here is that to succeed in this industry, your social skills need be just as good (or even better) than your technical skills. You need to be able to communicate with people and 鍖nd out what they really need, how they feel, what their history is, what their goals are, what they are doing. When working on a team, we all have different roles to play -- we each have our own areas of strength -- and that's 鍖ne. But as a whole, the team must balance their technical and social skills. The unfortunate thing is that most organizations don't (or can't) really operate as teams. Developers end up playing lots of roles, some of which they haven't really mastered. So for them to succeed as individuals in that kind of environment, developers also need to be mindful of the balance between their own social and technical skills. Final thoughts: Quality is not an act, it is a habit. --Aristotle Thanks for your time.