SlideShare a Scribd company logo
1 of 91
How to Keep
 Your Job
         Dave Thomas
The Pragmatic Programmers, LLC
www.pragmaticprogrammer.com
“For people who view this as a
 career, engineering is in worse
shape now than it’s been in years”

              LeEarl Bryant
          President, IEEE 2002
Our Future is at Stake


•   Look at threats to our livelihood

•   See why large-scale solutions won’t help us

•   Look at a local solution that will
The
Threats
at
 hre e
T n
   O      Things Move Too Fast
at
 hre e
T n
   O      Things Move Too Fast

“The half-life of engineering
knowledge, the time it takes
  for something to become
  obsolete, is from 7 to 2.5
            years”
              William Wulf, President,
          National Academy of Engineering
The Graying Developer
• Younger folks:
  – grow up with the new technologies
  – are cheaper
  – say “no” less often
  – don’t have as many other commitments

•
The Graying Developer
•   Younger folks:

    •   are often more attractive to employers
at
Thre o
   TwReliance on a Sector
at
  Thre o
     TwReliance on a Sector


• I’m an XYZ programmer.
at
  Thre o
     TwReliance on a Sector


• I’m an XYZ programmer.
• Or, the special case:
  • I’m a Java programmer.
  • Start depending on technologies and the
    companies that back them
Reliance on a Company

•   Companies such as:

    •   Digital Equipment

    •   Tandem

    •   Honeywell

    •   and Sun...
Reliance on a Sector
Two Year Historical - Sun Microsystems. 01/06/03
Reliance on a Sector
Two Year Historical - Sun Microsystems. 01/06/03
Reliance on a Sector
Two Year Historical - Sun Microsystems. 01/06/03
Reliance on a Sector
Two Year Historical - Sun Microsystems. 01/06/03
Reliance on a Sector
Two Year Historical - Sun vs. Microsoft
at
 hre e
T re
  Th      The Market
at
               hre e
              T re
                Th      The Market
(CNN) -- Just as Friday's new Labor Department
report shows the United States unemployment rate
soaring in August to 4.9 percent from 4.6 percent, a
newly released, federally funded study reveals that
a significant number of production jobs are shifting
from the American workplace to China.
at
               hre e
              T re
                Th      The Market
(CNN) -- Just as Friday's new Labor Department
report shows the United States unemployment rate
soaring in August to 4.9 percent from 4.6 percent, a
newly released, federally funded study reveals that
a significant number of production jobs are shifting
from the American workplace to China.


             "What makes it worse," she says, "is that some of
           these are higher-wage jobs, the type jobs that U.S.
            cities have been fighting to win. And now they're
             leaving. Many of those jobs were held by people
            who'd been working in them for many years, and
                         in some cases their whole lifetimes."
Nearly 1 million IT-related jobs
will move offshore over the course
of the next 15 years, according to
a new report released by Forrester
          Research, Inc.


             Source: http://itmanagement.earthweb.com/career/article.php/1503461
WHY?
Reasons to Move
Reasons to Move
•   Sometimes political
Reasons to Move
•   Sometimes political

•   Sometimes cost

    •   same as “young developers are cheaper”
Reasons to Move
•   Sometimes political

•   Sometimes cost

    •   same as “young developers are cheaper”

•   Often quality…
Overseas developers
can write good code
Capability Maturity Model
Capability Maturity Model
•   Measures sophistication of software
    development organizations
Capability Maturity Model
•   Measures sophistication of software
    development organizations

•   Acts as a set of targets, each better than the
    last
Capability Maturity Model
•   Measures sophistication of software
    development organizations

•   Acts as a set of targets, each better than the
    last

•   Five “CMM Levels”
CMM Levels
CMM Levels
• Level 1 (initial): little or no rules. Heroic effort
CMM Levels
• Level 1 (initial): little or no rules. Heroic effort

• Level 2 (repeatable): Basic project
  management, differs between projects.
CMM Levels
• Level 1 (initial): little or no rules. Heroic effort

• Level 2 (repeatable): Basic project
  management, differs between projects.

• Level 3 (defined): Development across the
  organization follows same rules
CMM Levels
CMM Levels
• Level 4 (managed): Management use precise
  measurements for effective control of
  development.
CMM Levels
• Level 4 (managed): Management use precise
  measurements for effective control of
  development.
• Level 5 (optimizing): Quantitative feedback
  from previous projects used to improve next
  generation of projects,
CMM Level 4



             USA
             41%
Overseas
 59%




                 Source: http://www.sei.cmu.edu/sema/profile.html
CMM Level 5

           USA
           17%




Overseas
 83%

                 Source: http://www.sei.cmu.edu/sema/profile.html
This is the new world, and failing to
recognize it is no different than IBM failing to
recognize in the 80’s how important PCs and
commodity hardware were going to be…or
failing to recognize for some time that they
had “lost” the PC market and forging ahead
with OS/2 and the PowerPC chip.
            -- a senior manager...
I think it's largely an arrogance problem:


“They” can't be better than “us”.


We're too smart.
Threat Summary


  The gravy train is
running out of steam.
Solutions
tion
  olu :
     ne Rely   on Government
S
   O
tion
  olu :
     ne Rely   on Government
S
   O

• Legislate against outsourcing
   – e.g. NJ Senate bill 1349
tion
  olu :
     ne Rely   on Government
S
   O

• Legislate against outsourcing
   – e.g. NJ Senate bill 1349
• Reduce H1B cap
tion
  olu :
     ne Rely   on Government
S
   O

• Legislate against outsourcing
   – e.g. NJ Senate bill 1349
• Reduce H1B cap
• Perhaps…
   • Tariffs on imported software
   • Legislate randomly
Protectionism
Protectionism
• Doesn’t work!
Protectionism
• Doesn’t work!
• Economic reasons: protectionism hurts us as
  a country
Protectionism
• Doesn’t work!
• Economic reasons: protectionism hurts us as
  a country
• Practical reasons:
   – companies such as GE, EDS, IBM have
     offices around the world
   – how could it be enforced anyway?
H1B Quotas
• 195,000 H1B’s in 2003

• 65,000 thereafter

• Failed to reach cap this year

•
H1B Quotas
• What happens if we dramatically cut the
  quota?
   – jobs move abroad
   – we lose access to experience
•
tion
  olu :
S
    Two Rely   on our Companies
tion
  olu :
S
    Two Rely   on our Companies
  • What is their motivation?
    – new graduates are cheaper, and will work
      longer hours
    – offshore programmers are cheaper, and
      offer good quality
    – tools are more reliable than those funky
      people anyway
• Our government isn’t going to do it
• Our government isn’t going to do it

• Our companies aren’t going to do it
• Our government isn’t going to do it

• Our companies aren’t going to do it

• It’s up to each of us
tion
  olu :     Rely on Ourselves
S
   Three




 • Our government isn’t going to do it

 • Our companies aren’t going to do it

 • It’s up to each of us
Invest
   in
Yourself
Lessons from
          Personal Finance

• Good investors:
   – have a plan
   – diversify
   – look for value
   – are active, not passive
   – do it regularly
Knowledge Portfolio


•   Value comes from:

    •   what we know

    •   knowing how to apply it
Have a Plan
• Consider pace of change

• Look beyond current fads



•


                             !   √!   have a plan
                                      diversify
                                      look for value
                                      active, not passive
                                      do it regularly
Have a Plan: Example 1
• You believe:
  – outsourcing will increase over time
  – your technical skills may become eclipsed
Have a Plan: Example 1
• You plan:
  – Now: to become familiar with distributed
    project implementation tools
  – Next Year: to look at becoming involved
    with outsourced project management
  – Coming Years: learn a foreign language
Have a Plan: Example 2
• You believe:
  – coding will be gradually eclipsed by
    modeling
  – you have better than average
    communications skills
  – you like a varied job
Have a Plan: Example 2
• You plan:
  – Now: start learning about MDA. Read
    books, subscribe to ML
  – Next Year: find an angle. Start
    contributing articles to management press.
    Implement a simple trial project.
  – Coming Years: speak at management
    conferences on MDA. Become high-paid
    international consultant on MDA
    application
Have a Plan: Example 3
• You believe:
  – you are an great, intuitive, developer
  – you enjoy coding challenges
  – you want to stay technical
Have a Plan: Example 3
• You plan:
  – Now: identify areas that will not be
    outsourced (core business, emerging
    technologies, defense, embedded,
    infrastructure). Research technologies and
    players.
  – Next Year: start developing code in these
    areas (open source if no jobs available).
  – Coming Years: write articles, speak at
    conferences, become recognized expert
Diversify
• Don’t have all your eggs in one technology
  basket
• Across multiple dimensions
   – languages
   – techniques
   – industries
   – non-technical

                                       !   !   have a plan
                                           √   diversify
                                               look for value
                                               active, not passive
                                               do it regularly
Diversify
• Mixture of risk/return profiles
   – have some low risk, low return
      • e.g.: .NET, Web Services, mobile
        devices, MDA
   – have some high risk, high return
      • e.g.. Aspects/Intentional programming,
        functional programming
      • spend time identifying (and join the
        effort early)
Diversify
• Remember:
   – almost all investments have some return
   – learning AOP, Haskell, … will always
     make you a better developer
   – don’t forget the non-technical axis
Look for Value
• Value is long term
• Time ≠ value
  – the EverQuest syndrome
• Applicability
  – but don’t forget diversity
• Not just theoretical
  – look for opportunities to apply and get
    feedback                           !   !   have a plan
                                               diversify
                                           √   look for value
                                               active, not passive
                                               do it regularly
Active Investor
• Periodically evaluate your (knowledge)
  portfolio
   – performing as you’d planned?
   – have external circumstances changed?
   – is it time to rebalance?




                                     !   !   have a plan
                                             diversify
                                             look for value
                                         √   active, not passive
                                             do it regularly
Invest Regularly
• Invest a minimum amount of time each
  month
• Helps to have a ritual
  – whatever works for you
• Plan time in advance
  – don’t just sit down and wonder
    what to do

                                     !   !   have a plan
                                             diversify
                                             look for value
                                             active, not passive
                                         √   do it regularly
Pragmatic Investment Plan

   • Invest minimum two hours each week
       – good times and bad
   • Combines individual and group work
   • Growing national community
             R
  CEM BE
DE •


       8
PIP: Possible Schedule
• One week/month:
   – spend the time in a user group meeting
   – plan to give talk every two years
      • set aside 6-8 weeks of PIP time to
        prepare
PIP: Possible Schedule
• One week/month:
   – spend the time learning a new language or
     environment
      • make it different (e.g. Java folks could
        learn C# and .NET)
      • free software is available for many
        languages and environments
      • see if you can put together a local study
        group
PIP: Possible Schedule
• One week/month:
   – spend the time reading a high-quality
     book.
   – avoid low-level recipe books
      • look for concept books
      • don’t forget non-technical books
Non-Technical Books
 Gold-mine of applicable information. Eg:

• How to Open Locks with Improvised Tools. Hans
  Conkel.

• From Novice to Expert: Excellence and Power in
  Clinical Nursing Practice. Patricia Benner.

• And the old favorite: Zen and the Art of Motorcycle
  Maintenance. Robert M. Pirsig.
PIP: Possible Schedule
• One week/month:
   – work on your personal plan
Pragmatic Investment Plan

•   Work with others
•   Reflect on your plan every 4-6 months
•   More time is better than less
•   See if you can get your company to agree to
    alternate Friday afternoons as study time:
     – show them a plan
In The Long Term…



• Things will continue to get more complicated
• Competition for work will increase
• Externally imposed constraints won’t help
In the Long Term


• We have to look out for ourselves

• We have to invest in ourselves

• We have to plan 5-10 years out

•
In the Long Term


•   We have the control

•   We have the responsibility

•   We have the opportunity
How to Keep
 Your Job
         Dave Thomas
The Pragmatic Programmers, LLC
www.pragmaticprogrammer.com
Extra
Build a career portfolio

More Related Content

What's hot

Fast fourier transform
Fast fourier transformFast fourier transform
Fast fourier transformchitra raju
 
Design and Simulation WDM
Design and Simulation WDMDesign and Simulation WDM
Design and Simulation WDMMuzahidul Islam
 
Antenna wrt frequency
Antenna wrt frequencyAntenna wrt frequency
Antenna wrt frequencyAJAL A J
 
HL7 Fhir for Developers
HL7 Fhir for DevelopersHL7 Fhir for Developers
HL7 Fhir for DevelopersEwout Kramer
 
satellite-communication
 satellite-communication satellite-communication
satellite-communicationjhcid
 
Communication in space
Communication in spaceCommunication in space
Communication in spaceDennis Paulraj
 
Oral graduate thesis defense (September 14, 2011, Guelph, Ontario).
Oral graduate thesis defense (September 14, 2011, Guelph, Ontario).Oral graduate thesis defense (September 14, 2011, Guelph, Ontario).
Oral graduate thesis defense (September 14, 2011, Guelph, Ontario).Courtney Miller
 
أساسيات تكنولوجيا المعلومات و نظام التشغيل.pdf
أساسيات تكنولوجيا المعلومات و نظام التشغيل.pdfأساسيات تكنولوجيا المعلومات و نظام التشغيل.pdf
أساسيات تكنولوجيا المعلومات و نظام التشغيل.pdfAhmedOthman511332
 
FHIR Documents by Lloyd McKenzie
FHIR Documents by Lloyd McKenzieFHIR Documents by Lloyd McKenzie
FHIR Documents by Lloyd McKenzieFHIR Developer Days
 
chapter 6 Satellite Systems.pptx
chapter 6 Satellite Systems.pptxchapter 6 Satellite Systems.pptx
chapter 6 Satellite Systems.pptxAmanuelZewdie4
 

What's hot (11)

Fast fourier transform
Fast fourier transformFast fourier transform
Fast fourier transform
 
Design and Simulation WDM
Design and Simulation WDMDesign and Simulation WDM
Design and Simulation WDM
 
Antenna wrt frequency
Antenna wrt frequencyAntenna wrt frequency
Antenna wrt frequency
 
HL7 Fhir for Developers
HL7 Fhir for DevelopersHL7 Fhir for Developers
HL7 Fhir for Developers
 
Rhombic antenna
Rhombic antenna Rhombic antenna
Rhombic antenna
 
satellite-communication
 satellite-communication satellite-communication
satellite-communication
 
Communication in space
Communication in spaceCommunication in space
Communication in space
 
Oral graduate thesis defense (September 14, 2011, Guelph, Ontario).
Oral graduate thesis defense (September 14, 2011, Guelph, Ontario).Oral graduate thesis defense (September 14, 2011, Guelph, Ontario).
Oral graduate thesis defense (September 14, 2011, Guelph, Ontario).
 
أساسيات تكنولوجيا المعلومات و نظام التشغيل.pdf
أساسيات تكنولوجيا المعلومات و نظام التشغيل.pdfأساسيات تكنولوجيا المعلومات و نظام التشغيل.pdf
أساسيات تكنولوجيا المعلومات و نظام التشغيل.pdf
 
FHIR Documents by Lloyd McKenzie
FHIR Documents by Lloyd McKenzieFHIR Documents by Lloyd McKenzie
FHIR Documents by Lloyd McKenzie
 
chapter 6 Satellite Systems.pptx
chapter 6 Satellite Systems.pptxchapter 6 Satellite Systems.pptx
chapter 6 Satellite Systems.pptx
 

Similar to How To Keep Your Job

Steve mcconnell
Steve mcconnellSteve mcconnell
Steve mcconnellShiraz316
 
Recruiting Great Engineers in Six Easy Steps
Recruiting Great Engineers in Six Easy StepsRecruiting Great Engineers in Six Easy Steps
Recruiting Great Engineers in Six Easy StepsAleksandr Yampolskiy
 
Trends in Technical Communications in North America
Trends in Technical Communications in North AmericaTrends in Technical Communications in North America
Trends in Technical Communications in North AmericaChris LaRoche
 
“Why Content Projects Fail” by Deane Barker - Now What? Conference 2017
“Why Content Projects Fail” by Deane Barker - Now What? Conference 2017“Why Content Projects Fail” by Deane Barker - Now What? Conference 2017
“Why Content Projects Fail” by Deane Barker - Now What? Conference 2017Blend Interactive
 
Four Laws of Software Economics
Four Laws of Software EconomicsFour Laws of Software Economics
Four Laws of Software EconomicsRich Mironov
 
BoS2015 Rich Mironov - The Four Laws of Software Economics
BoS2015 Rich Mironov - The Four Laws of Software EconomicsBoS2015 Rich Mironov - The Four Laws of Software Economics
BoS2015 Rich Mironov - The Four Laws of Software EconomicsBusiness of Software Conference
 
Software Developer Career Unplugged - GeeCon 2013
Software Developer Career Unplugged - GeeCon 2013Software Developer Career Unplugged - GeeCon 2013
Software Developer Career Unplugged - GeeCon 2013Wojciech Seliga
 
Four Laws of Tech Product Economics - Rich Mironov
Four Laws of Tech Product Economics - Rich MironovFour Laws of Tech Product Economics - Rich Mironov
Four Laws of Tech Product Economics - Rich MironovProductCampPortland
 
Managing the Risks of AI - A Planning Guide for Executives
Managing the Risks of AI - A Planning Guide for ExecutivesManaging the Risks of AI - A Planning Guide for Executives
Managing the Risks of AI - A Planning Guide for ExecutivesDaniel Faggella
 
Андрій Татчин "Software Project Estimation: Theory and Reality"
Андрій Татчин "Software Project Estimation: Theory and Reality" Андрій Татчин "Software Project Estimation: Theory and Reality"
Андрій Татчин "Software Project Estimation: Theory and Reality" Lviv Startup Club
 
Jonathan Strong - Innovator - may 2019
Jonathan Strong - Innovator - may 2019Jonathan Strong - Innovator - may 2019
Jonathan Strong - Innovator - may 2019Jonathan Strong
 
Getting started in tech (4:27)
Getting started in tech (4:27)Getting started in tech (4:27)
Getting started in tech (4:27)Thinkful
 
The Globalization of Technical Writing - Threat or Opportunity
The Globalization of Technical Writing - Threat or OpportunityThe Globalization of Technical Writing - Threat or Opportunity
The Globalization of Technical Writing - Threat or OpportunitySaiff Solutions, Inc.
 
IBM Smarter Business 2012 - Innovation på IBM
IBM Smarter Business 2012 - Innovation på IBMIBM Smarter Business 2012 - Innovation på IBM
IBM Smarter Business 2012 - Innovation på IBMIBM Sverige
 
Getting started in tech (6 21)
Getting started in tech (6 21)Getting started in tech (6 21)
Getting started in tech (6 21)Thinkful
 
The Lean Enterprise
The Lean EnterpriseThe Lean Enterprise
The Lean EnterpriseRyan Dorrell
 
Practical Techniques for early use in BA cycle
Practical Techniques for early use in BA cyclePractical Techniques for early use in BA cycle
Practical Techniques for early use in BA cycleSQALab
 

Similar to How To Keep Your Job (20)

Steve mcconnell
Steve mcconnellSteve mcconnell
Steve mcconnell
 
Recruiting Great Engineers in Six Easy Steps
Recruiting Great Engineers in Six Easy StepsRecruiting Great Engineers in Six Easy Steps
Recruiting Great Engineers in Six Easy Steps
 
Trends in Technical Communications in North America
Trends in Technical Communications in North AmericaTrends in Technical Communications in North America
Trends in Technical Communications in North America
 
Workshop on the Strategic Planning Model
 Workshop on the Strategic Planning Model Workshop on the Strategic Planning Model
Workshop on the Strategic Planning Model
 
Europython how to make it recruiting suck less?
Europython   how to make it recruiting suck less?Europython   how to make it recruiting suck less?
Europython how to make it recruiting suck less?
 
“Why Content Projects Fail” by Deane Barker - Now What? Conference 2017
“Why Content Projects Fail” by Deane Barker - Now What? Conference 2017“Why Content Projects Fail” by Deane Barker - Now What? Conference 2017
“Why Content Projects Fail” by Deane Barker - Now What? Conference 2017
 
Four Laws of Software Economics
Four Laws of Software EconomicsFour Laws of Software Economics
Four Laws of Software Economics
 
BoS2015 Rich Mironov - The Four Laws of Software Economics
BoS2015 Rich Mironov - The Four Laws of Software EconomicsBoS2015 Rich Mironov - The Four Laws of Software Economics
BoS2015 Rich Mironov - The Four Laws of Software Economics
 
Software Developer Career Unplugged - GeeCon 2013
Software Developer Career Unplugged - GeeCon 2013Software Developer Career Unplugged - GeeCon 2013
Software Developer Career Unplugged - GeeCon 2013
 
Four Laws of Tech Product Economics - Rich Mironov
Four Laws of Tech Product Economics - Rich MironovFour Laws of Tech Product Economics - Rich Mironov
Four Laws of Tech Product Economics - Rich Mironov
 
Managing the Risks of AI - A Planning Guide for Executives
Managing the Risks of AI - A Planning Guide for ExecutivesManaging the Risks of AI - A Planning Guide for Executives
Managing the Risks of AI - A Planning Guide for Executives
 
Андрій Татчин "Software Project Estimation: Theory and Reality"
Андрій Татчин "Software Project Estimation: Theory and Reality" Андрій Татчин "Software Project Estimation: Theory and Reality"
Андрій Татчин "Software Project Estimation: Theory and Reality"
 
Jonathan Strong - Innovator - may 2019
Jonathan Strong - Innovator - may 2019Jonathan Strong - Innovator - may 2019
Jonathan Strong - Innovator - may 2019
 
Getting started in tech (4:27)
Getting started in tech (4:27)Getting started in tech (4:27)
Getting started in tech (4:27)
 
Presentation1short
Presentation1shortPresentation1short
Presentation1short
 
The Globalization of Technical Writing - Threat or Opportunity
The Globalization of Technical Writing - Threat or OpportunityThe Globalization of Technical Writing - Threat or Opportunity
The Globalization of Technical Writing - Threat or Opportunity
 
IBM Smarter Business 2012 - Innovation på IBM
IBM Smarter Business 2012 - Innovation på IBMIBM Smarter Business 2012 - Innovation på IBM
IBM Smarter Business 2012 - Innovation på IBM
 
Getting started in tech (6 21)
Getting started in tech (6 21)Getting started in tech (6 21)
Getting started in tech (6 21)
 
The Lean Enterprise
The Lean EnterpriseThe Lean Enterprise
The Lean Enterprise
 
Practical Techniques for early use in BA cycle
Practical Techniques for early use in BA cyclePractical Techniques for early use in BA cycle
Practical Techniques for early use in BA cycle
 

Recently uploaded

Search Engine Optimization SEO PDF for 2024.pdf
Search Engine Optimization SEO PDF for 2024.pdfSearch Engine Optimization SEO PDF for 2024.pdf
Search Engine Optimization SEO PDF for 2024.pdfRankYa
 
Connect Wave/ connectwave Pitch Deck Presentation
Connect Wave/ connectwave Pitch Deck PresentationConnect Wave/ connectwave Pitch Deck Presentation
Connect Wave/ connectwave Pitch Deck PresentationSlibray Presentation
 
"Federated learning: out of reach no matter how close",Oleksandr Lapshyn
"Federated learning: out of reach no matter how close",Oleksandr Lapshyn"Federated learning: out of reach no matter how close",Oleksandr Lapshyn
"Federated learning: out of reach no matter how close",Oleksandr LapshynFwdays
 
Transcript: New from BookNet Canada for 2024: BNC CataList - Tech Forum 2024
Transcript: New from BookNet Canada for 2024: BNC CataList - Tech Forum 2024Transcript: New from BookNet Canada for 2024: BNC CataList - Tech Forum 2024
Transcript: New from BookNet Canada for 2024: BNC CataList - Tech Forum 2024BookNet Canada
 
"Subclassing and Composition – A Pythonic Tour of Trade-Offs", Hynek Schlawack
"Subclassing and Composition – A Pythonic Tour of Trade-Offs", Hynek Schlawack"Subclassing and Composition – A Pythonic Tour of Trade-Offs", Hynek Schlawack
"Subclassing and Composition – A Pythonic Tour of Trade-Offs", Hynek SchlawackFwdays
 
Vertex AI Gemini Prompt Engineering Tips
Vertex AI Gemini Prompt Engineering TipsVertex AI Gemini Prompt Engineering Tips
Vertex AI Gemini Prompt Engineering TipsMiki Katsuragi
 
DevoxxFR 2024 Reproducible Builds with Apache Maven
DevoxxFR 2024 Reproducible Builds with Apache MavenDevoxxFR 2024 Reproducible Builds with Apache Maven
DevoxxFR 2024 Reproducible Builds with Apache MavenHervé Boutemy
 
Designing IA for AI - Information Architecture Conference 2024
Designing IA for AI - Information Architecture Conference 2024Designing IA for AI - Information Architecture Conference 2024
Designing IA for AI - Information Architecture Conference 2024Enterprise Knowledge
 
CloudStudio User manual (basic edition):
CloudStudio User manual (basic edition):CloudStudio User manual (basic edition):
CloudStudio User manual (basic edition):comworks
 
Advanced Test Driven-Development @ php[tek] 2024
Advanced Test Driven-Development @ php[tek] 2024Advanced Test Driven-Development @ php[tek] 2024
Advanced Test Driven-Development @ php[tek] 2024Scott Keck-Warren
 
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...Patryk Bandurski
 
Install Stable Diffusion in windows machine
Install Stable Diffusion in windows machineInstall Stable Diffusion in windows machine
Install Stable Diffusion in windows machinePadma Pradeep
 
My Hashitalk Indonesia April 2024 Presentation
My Hashitalk Indonesia April 2024 PresentationMy Hashitalk Indonesia April 2024 Presentation
My Hashitalk Indonesia April 2024 PresentationRidwan Fadjar
 
Gen AI in Business - Global Trends Report 2024.pdf
Gen AI in Business - Global Trends Report 2024.pdfGen AI in Business - Global Trends Report 2024.pdf
Gen AI in Business - Global Trends Report 2024.pdfAddepto
 
Vector Databases 101 - An introduction to the world of Vector Databases
Vector Databases 101 - An introduction to the world of Vector DatabasesVector Databases 101 - An introduction to the world of Vector Databases
Vector Databases 101 - An introduction to the world of Vector DatabasesZilliz
 
Streamlining Python Development: A Guide to a Modern Project Setup
Streamlining Python Development: A Guide to a Modern Project SetupStreamlining Python Development: A Guide to a Modern Project Setup
Streamlining Python Development: A Guide to a Modern Project SetupFlorian Wilhelm
 
Tampa BSides - Chef's Tour of Microsoft Security Adoption Framework (SAF)
Tampa BSides - Chef's Tour of Microsoft Security Adoption Framework (SAF)Tampa BSides - Chef's Tour of Microsoft Security Adoption Framework (SAF)
Tampa BSides - Chef's Tour of Microsoft Security Adoption Framework (SAF)Mark Simos
 
Human Factors of XR: Using Human Factors to Design XR Systems
Human Factors of XR: Using Human Factors to Design XR SystemsHuman Factors of XR: Using Human Factors to Design XR Systems
Human Factors of XR: Using Human Factors to Design XR SystemsMark Billinghurst
 
Bun (KitWorks Team Study 노별마루 발표 2024.4.22)
Bun (KitWorks Team Study 노별마루 발표 2024.4.22)Bun (KitWorks Team Study 노별마루 발표 2024.4.22)
Bun (KitWorks Team Study 노별마루 발표 2024.4.22)Wonjun Hwang
 
Artificial intelligence in cctv survelliance.pptx
Artificial intelligence in cctv survelliance.pptxArtificial intelligence in cctv survelliance.pptx
Artificial intelligence in cctv survelliance.pptxhariprasad279825
 

Recently uploaded (20)

Search Engine Optimization SEO PDF for 2024.pdf
Search Engine Optimization SEO PDF for 2024.pdfSearch Engine Optimization SEO PDF for 2024.pdf
Search Engine Optimization SEO PDF for 2024.pdf
 
Connect Wave/ connectwave Pitch Deck Presentation
Connect Wave/ connectwave Pitch Deck PresentationConnect Wave/ connectwave Pitch Deck Presentation
Connect Wave/ connectwave Pitch Deck Presentation
 
"Federated learning: out of reach no matter how close",Oleksandr Lapshyn
"Federated learning: out of reach no matter how close",Oleksandr Lapshyn"Federated learning: out of reach no matter how close",Oleksandr Lapshyn
"Federated learning: out of reach no matter how close",Oleksandr Lapshyn
 
Transcript: New from BookNet Canada for 2024: BNC CataList - Tech Forum 2024
Transcript: New from BookNet Canada for 2024: BNC CataList - Tech Forum 2024Transcript: New from BookNet Canada for 2024: BNC CataList - Tech Forum 2024
Transcript: New from BookNet Canada for 2024: BNC CataList - Tech Forum 2024
 
"Subclassing and Composition – A Pythonic Tour of Trade-Offs", Hynek Schlawack
"Subclassing and Composition – A Pythonic Tour of Trade-Offs", Hynek Schlawack"Subclassing and Composition – A Pythonic Tour of Trade-Offs", Hynek Schlawack
"Subclassing and Composition – A Pythonic Tour of Trade-Offs", Hynek Schlawack
 
Vertex AI Gemini Prompt Engineering Tips
Vertex AI Gemini Prompt Engineering TipsVertex AI Gemini Prompt Engineering Tips
Vertex AI Gemini Prompt Engineering Tips
 
DevoxxFR 2024 Reproducible Builds with Apache Maven
DevoxxFR 2024 Reproducible Builds with Apache MavenDevoxxFR 2024 Reproducible Builds with Apache Maven
DevoxxFR 2024 Reproducible Builds with Apache Maven
 
Designing IA for AI - Information Architecture Conference 2024
Designing IA for AI - Information Architecture Conference 2024Designing IA for AI - Information Architecture Conference 2024
Designing IA for AI - Information Architecture Conference 2024
 
CloudStudio User manual (basic edition):
CloudStudio User manual (basic edition):CloudStudio User manual (basic edition):
CloudStudio User manual (basic edition):
 
Advanced Test Driven-Development @ php[tek] 2024
Advanced Test Driven-Development @ php[tek] 2024Advanced Test Driven-Development @ php[tek] 2024
Advanced Test Driven-Development @ php[tek] 2024
 
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
 
Install Stable Diffusion in windows machine
Install Stable Diffusion in windows machineInstall Stable Diffusion in windows machine
Install Stable Diffusion in windows machine
 
My Hashitalk Indonesia April 2024 Presentation
My Hashitalk Indonesia April 2024 PresentationMy Hashitalk Indonesia April 2024 Presentation
My Hashitalk Indonesia April 2024 Presentation
 
Gen AI in Business - Global Trends Report 2024.pdf
Gen AI in Business - Global Trends Report 2024.pdfGen AI in Business - Global Trends Report 2024.pdf
Gen AI in Business - Global Trends Report 2024.pdf
 
Vector Databases 101 - An introduction to the world of Vector Databases
Vector Databases 101 - An introduction to the world of Vector DatabasesVector Databases 101 - An introduction to the world of Vector Databases
Vector Databases 101 - An introduction to the world of Vector Databases
 
Streamlining Python Development: A Guide to a Modern Project Setup
Streamlining Python Development: A Guide to a Modern Project SetupStreamlining Python Development: A Guide to a Modern Project Setup
Streamlining Python Development: A Guide to a Modern Project Setup
 
Tampa BSides - Chef's Tour of Microsoft Security Adoption Framework (SAF)
Tampa BSides - Chef's Tour of Microsoft Security Adoption Framework (SAF)Tampa BSides - Chef's Tour of Microsoft Security Adoption Framework (SAF)
Tampa BSides - Chef's Tour of Microsoft Security Adoption Framework (SAF)
 
Human Factors of XR: Using Human Factors to Design XR Systems
Human Factors of XR: Using Human Factors to Design XR SystemsHuman Factors of XR: Using Human Factors to Design XR Systems
Human Factors of XR: Using Human Factors to Design XR Systems
 
Bun (KitWorks Team Study 노별마루 발표 2024.4.22)
Bun (KitWorks Team Study 노별마루 발표 2024.4.22)Bun (KitWorks Team Study 노별마루 발표 2024.4.22)
Bun (KitWorks Team Study 노별마루 발표 2024.4.22)
 
Artificial intelligence in cctv survelliance.pptx
Artificial intelligence in cctv survelliance.pptxArtificial intelligence in cctv survelliance.pptx
Artificial intelligence in cctv survelliance.pptx
 

How To Keep Your Job

  • 1.
  • 2. How to Keep Your Job Dave Thomas The Pragmatic Programmers, LLC www.pragmaticprogrammer.com
  • 3. “For people who view this as a career, engineering is in worse shape now than it’s been in years” LeEarl Bryant President, IEEE 2002
  • 4. Our Future is at Stake • Look at threats to our livelihood • See why large-scale solutions won’t help us • Look at a local solution that will
  • 6. at hre e T n O Things Move Too Fast
  • 7. at hre e T n O Things Move Too Fast “The half-life of engineering knowledge, the time it takes for something to become obsolete, is from 7 to 2.5 years” William Wulf, President, National Academy of Engineering
  • 8. The Graying Developer • Younger folks: – grow up with the new technologies – are cheaper – say “no” less often – don’t have as many other commitments •
  • 9. The Graying Developer • Younger folks: • are often more attractive to employers
  • 10. at Thre o TwReliance on a Sector
  • 11. at Thre o TwReliance on a Sector • I’m an XYZ programmer.
  • 12. at Thre o TwReliance on a Sector • I’m an XYZ programmer. • Or, the special case: • I’m a Java programmer. • Start depending on technologies and the companies that back them
  • 13. Reliance on a Company • Companies such as: • Digital Equipment • Tandem • Honeywell • and Sun...
  • 14. Reliance on a Sector Two Year Historical - Sun Microsystems. 01/06/03
  • 15. Reliance on a Sector Two Year Historical - Sun Microsystems. 01/06/03
  • 16. Reliance on a Sector Two Year Historical - Sun Microsystems. 01/06/03
  • 17. Reliance on a Sector Two Year Historical - Sun Microsystems. 01/06/03
  • 18. Reliance on a Sector Two Year Historical - Sun vs. Microsoft
  • 19. at hre e T re Th The Market
  • 20. at hre e T re Th The Market (CNN) -- Just as Friday's new Labor Department report shows the United States unemployment rate soaring in August to 4.9 percent from 4.6 percent, a newly released, federally funded study reveals that a significant number of production jobs are shifting from the American workplace to China.
  • 21. at hre e T re Th The Market (CNN) -- Just as Friday's new Labor Department report shows the United States unemployment rate soaring in August to 4.9 percent from 4.6 percent, a newly released, federally funded study reveals that a significant number of production jobs are shifting from the American workplace to China. "What makes it worse," she says, "is that some of these are higher-wage jobs, the type jobs that U.S. cities have been fighting to win. And now they're leaving. Many of those jobs were held by people who'd been working in them for many years, and in some cases their whole lifetimes."
  • 22.
  • 23. Nearly 1 million IT-related jobs will move offshore over the course of the next 15 years, according to a new report released by Forrester Research, Inc. Source: http://itmanagement.earthweb.com/career/article.php/1503461
  • 24. WHY?
  • 26. Reasons to Move • Sometimes political
  • 27. Reasons to Move • Sometimes political • Sometimes cost • same as “young developers are cheaper”
  • 28. Reasons to Move • Sometimes political • Sometimes cost • same as “young developers are cheaper” • Often quality…
  • 31. Capability Maturity Model • Measures sophistication of software development organizations
  • 32. Capability Maturity Model • Measures sophistication of software development organizations • Acts as a set of targets, each better than the last
  • 33. Capability Maturity Model • Measures sophistication of software development organizations • Acts as a set of targets, each better than the last • Five “CMM Levels”
  • 35. CMM Levels • Level 1 (initial): little or no rules. Heroic effort
  • 36. CMM Levels • Level 1 (initial): little or no rules. Heroic effort • Level 2 (repeatable): Basic project management, differs between projects.
  • 37. CMM Levels • Level 1 (initial): little or no rules. Heroic effort • Level 2 (repeatable): Basic project management, differs between projects. • Level 3 (defined): Development across the organization follows same rules
  • 39. CMM Levels • Level 4 (managed): Management use precise measurements for effective control of development.
  • 40. CMM Levels • Level 4 (managed): Management use precise measurements for effective control of development. • Level 5 (optimizing): Quantitative feedback from previous projects used to improve next generation of projects,
  • 41. CMM Level 4 USA 41% Overseas 59% Source: http://www.sei.cmu.edu/sema/profile.html
  • 42. CMM Level 5 USA 17% Overseas 83% Source: http://www.sei.cmu.edu/sema/profile.html
  • 43. This is the new world, and failing to recognize it is no different than IBM failing to recognize in the 80’s how important PCs and commodity hardware were going to be…or failing to recognize for some time that they had “lost” the PC market and forging ahead with OS/2 and the PowerPC chip. -- a senior manager...
  • 44. I think it's largely an arrogance problem: “They” can't be better than “us”. We're too smart.
  • 45. Threat Summary The gravy train is running out of steam.
  • 47. tion olu : ne Rely on Government S O
  • 48. tion olu : ne Rely on Government S O • Legislate against outsourcing – e.g. NJ Senate bill 1349
  • 49. tion olu : ne Rely on Government S O • Legislate against outsourcing – e.g. NJ Senate bill 1349 • Reduce H1B cap
  • 50. tion olu : ne Rely on Government S O • Legislate against outsourcing – e.g. NJ Senate bill 1349 • Reduce H1B cap • Perhaps… • Tariffs on imported software • Legislate randomly
  • 53. Protectionism • Doesn’t work! • Economic reasons: protectionism hurts us as a country
  • 54. Protectionism • Doesn’t work! • Economic reasons: protectionism hurts us as a country • Practical reasons: – companies such as GE, EDS, IBM have offices around the world – how could it be enforced anyway?
  • 55. H1B Quotas • 195,000 H1B’s in 2003 • 65,000 thereafter • Failed to reach cap this year •
  • 56. H1B Quotas • What happens if we dramatically cut the quota? – jobs move abroad – we lose access to experience •
  • 57. tion olu : S Two Rely on our Companies
  • 58. tion olu : S Two Rely on our Companies • What is their motivation? – new graduates are cheaper, and will work longer hours – offshore programmers are cheaper, and offer good quality – tools are more reliable than those funky people anyway
  • 59.
  • 60. • Our government isn’t going to do it
  • 61. • Our government isn’t going to do it • Our companies aren’t going to do it
  • 62. • Our government isn’t going to do it • Our companies aren’t going to do it • It’s up to each of us
  • 63. tion olu : Rely on Ourselves S Three • Our government isn’t going to do it • Our companies aren’t going to do it • It’s up to each of us
  • 64. Invest in Yourself
  • 65. Lessons from Personal Finance • Good investors: – have a plan – diversify – look for value – are active, not passive – do it regularly
  • 66. Knowledge Portfolio • Value comes from: • what we know • knowing how to apply it
  • 67. Have a Plan • Consider pace of change • Look beyond current fads • ! √! have a plan diversify look for value active, not passive do it regularly
  • 68. Have a Plan: Example 1 • You believe: – outsourcing will increase over time – your technical skills may become eclipsed
  • 69. Have a Plan: Example 1 • You plan: – Now: to become familiar with distributed project implementation tools – Next Year: to look at becoming involved with outsourced project management – Coming Years: learn a foreign language
  • 70. Have a Plan: Example 2 • You believe: – coding will be gradually eclipsed by modeling – you have better than average communications skills – you like a varied job
  • 71. Have a Plan: Example 2 • You plan: – Now: start learning about MDA. Read books, subscribe to ML – Next Year: find an angle. Start contributing articles to management press. Implement a simple trial project. – Coming Years: speak at management conferences on MDA. Become high-paid international consultant on MDA application
  • 72. Have a Plan: Example 3 • You believe: – you are an great, intuitive, developer – you enjoy coding challenges – you want to stay technical
  • 73. Have a Plan: Example 3 • You plan: – Now: identify areas that will not be outsourced (core business, emerging technologies, defense, embedded, infrastructure). Research technologies and players. – Next Year: start developing code in these areas (open source if no jobs available). – Coming Years: write articles, speak at conferences, become recognized expert
  • 74. Diversify • Don’t have all your eggs in one technology basket • Across multiple dimensions – languages – techniques – industries – non-technical ! ! have a plan √ diversify look for value active, not passive do it regularly
  • 75. Diversify • Mixture of risk/return profiles – have some low risk, low return • e.g.: .NET, Web Services, mobile devices, MDA – have some high risk, high return • e.g.. Aspects/Intentional programming, functional programming • spend time identifying (and join the effort early)
  • 76. Diversify • Remember: – almost all investments have some return – learning AOP, Haskell, … will always make you a better developer – don’t forget the non-technical axis
  • 77. Look for Value • Value is long term • Time ≠ value – the EverQuest syndrome • Applicability – but don’t forget diversity • Not just theoretical – look for opportunities to apply and get feedback ! ! have a plan diversify √ look for value active, not passive do it regularly
  • 78. Active Investor • Periodically evaluate your (knowledge) portfolio – performing as you’d planned? – have external circumstances changed? – is it time to rebalance? ! ! have a plan diversify look for value √ active, not passive do it regularly
  • 79. Invest Regularly • Invest a minimum amount of time each month • Helps to have a ritual – whatever works for you • Plan time in advance – don’t just sit down and wonder what to do ! ! have a plan diversify look for value active, not passive √ do it regularly
  • 80. Pragmatic Investment Plan • Invest minimum two hours each week – good times and bad • Combines individual and group work • Growing national community R CEM BE DE • 8
  • 81. PIP: Possible Schedule • One week/month: – spend the time in a user group meeting – plan to give talk every two years • set aside 6-8 weeks of PIP time to prepare
  • 82. PIP: Possible Schedule • One week/month: – spend the time learning a new language or environment • make it different (e.g. Java folks could learn C# and .NET) • free software is available for many languages and environments • see if you can put together a local study group
  • 83. PIP: Possible Schedule • One week/month: – spend the time reading a high-quality book. – avoid low-level recipe books • look for concept books • don’t forget non-technical books
  • 84. Non-Technical Books Gold-mine of applicable information. Eg: • How to Open Locks with Improvised Tools. Hans Conkel. • From Novice to Expert: Excellence and Power in Clinical Nursing Practice. Patricia Benner. • And the old favorite: Zen and the Art of Motorcycle Maintenance. Robert M. Pirsig.
  • 85. PIP: Possible Schedule • One week/month: – work on your personal plan
  • 86. Pragmatic Investment Plan • Work with others • Reflect on your plan every 4-6 months • More time is better than less • See if you can get your company to agree to alternate Friday afternoons as study time: – show them a plan
  • 87. In The Long Term… • Things will continue to get more complicated • Competition for work will increase • Externally imposed constraints won’t help
  • 88. In the Long Term • We have to look out for ourselves • We have to invest in ourselves • We have to plan 5-10 years out •
  • 89. In the Long Term • We have the control • We have the responsibility • We have the opportunity
  • 90. How to Keep Your Job Dave Thomas The Pragmatic Programmers, LLC www.pragmaticprogrammer.com
  • 91. Extra Build a career portfolio

Editor's Notes

  1. \n
  2. What’s the difference between a roomful of programmers and a box of last years Christmas lights? Next year some of the lights may still be working.\n\nClearly there’s a current downturn, but all the bad news is helping us to ignore even worse underlying news. \n\nNext slide: talk outline\n
  3. Make no mistake. Our current careers are under threat. There’s a good chance that half the folks in this room won’t be developers in five years, and the ten year outlook is even worse.\n\nAnd yet we still have mortgages to pay, families to support, and shiny new toys to buy. What can we do? That’s what this talk is about.\n\nNext\n
  4. \n
  5. We’ll look at three big threats. There are many, many more. \n\nEg don’t consider the glut of ex dot com developers, the folks with no real development background who got sucked in during the crazed times and now dilute the job pool for the rest of us. \n\nInstead we’ll look at longer term threats: threats that stay with us \n
  6. Ignore the interesting definition of half-life...\n\nWe work hard to learn something, only to have it become obsolete in a handful of years. \n\nShh.. listen to that ticking. That’s the sound of our knowledge becoming less and less valuable.\n\nAnd, to make it worse, there are folks who are cheating...\n
  7. People coming along behind us start further down the curve. They grow up with the new technologies. They don’t carry the baggage of the older stuff. And then to add insult to injury, they don’t expect to be paid as much.\n
  8. At this point some of the younger programmers out there may be feeling pretty smug.\n\nFolks, you’ll be old programmers in five years.\n\nOK, so we’re struggling to keep up with all this new technology. What other threats are we facing?\n\n
  9. Specialization is for insects...\n\n but still we’re forced to specialize. Lazy employers push us to specialize with their ridiculous job ads. The sheer size of the field forces us into obscure corners. \n\nSo after a while we give in and accept it. We no longer say “we’re developers”, but we proudly say\n\n<transition>\n\nWe pin our careers and our futures to technologies and the companies that underly them. \n\nNext slide: list of companies\n
  10. Specialization is for insects...\n\n but still we’re forced to specialize. Lazy employers push us to specialize with their ridiculous job ads. The sheer size of the field forces us into obscure corners. \n\nSo after a while we give in and accept it. We no longer say “we’re developers”, but we proudly say\n\n<transition>\n\nWe pin our careers and our futures to technologies and the companies that underly them. \n\nNext slide: list of companies\n
  11. \n
  12. Magic share price is around $1.75 - that values Sun at its bank balance. Explain...\n\nSuddenly, Java doesn’t seem quite so safe. There are folks who’d step in: IBM, for example.\nBut this of the impact of managers: CTOs and CIOs making the .NET vs. Java decision. How much does Sun going out of business affect their perception of the risk of Java? \n\nSometimes people say “well, Microsoft got hit badly too” <slide>\n\n
  13. Magic share price is around $1.75 - that values Sun at its bank balance. Explain...\n\nSuddenly, Java doesn’t seem quite so safe. There are folks who’d step in: IBM, for example.\nBut this of the impact of managers: CTOs and CIOs making the .NET vs. Java decision. How much does Sun going out of business affect their perception of the risk of Java? \n\nSometimes people say “well, Microsoft got hit badly too” <slide>\n\n
  14. Magic share price is around $1.75 - that values Sun at its bank balance. Explain...\n\nSuddenly, Java doesn’t seem quite so safe. There are folks who’d step in: IBM, for example.\nBut this of the impact of managers: CTOs and CIOs making the .NET vs. Java decision. How much does Sun going out of business affect their perception of the risk of Java? \n\nSometimes people say “well, Microsoft got hit badly too” <slide>\n\n
  15. \nSo, we’ve talked about technical obsolescence, and we’re talked now about the risks of putting all your eggs in one basket (a choice we’re almost forced to make).\n\nThere’s one more threat we’re going to talk about. \n\n\n
  16. We live in a capitalist world. The market is king. Particularly in the US, we leave the market to regulate much of what we do. We vote with our dollars and our feet. If domestic car manufacturers start producing models we don’t like, or that aren’t reliable, some folks shift to buying imports. That gradual pressure forces Ford and Chevrolet to rethink what they do, until they start to recapture market share. The market is a kind of Darwinian pool in which we all float, and in which the customer’s judgment is the determiner of who survives.\n\nThere’s a market in software development. As developers, we’re part of it.\n\nAnd that market is now world-wide.\n<transition>\nNow we’re all used to this trend. As stuff becomes commoditized (shoes, clothing, manufacturing, electronics, ...) it moves to where the labor is cheaper. In general this is a good thing for the economy (although it sucks if you work in that industry): we move on, adding value at a higher and higher level. But now we’re seeing something new.\n<transition>\nRead quote - stress “working in them for many years, an in come cases their whole lifetimes” High tech jobs are moving abroad. Much software development has become a commodity. And we’re the people who whom it sucks. Don’t believe me?\n\n\n
  17. We live in a capitalist world. The market is king. Particularly in the US, we leave the market to regulate much of what we do. We vote with our dollars and our feet. If domestic car manufacturers start producing models we don’t like, or that aren’t reliable, some folks shift to buying imports. That gradual pressure forces Ford and Chevrolet to rethink what they do, until they start to recapture market share. The market is a kind of Darwinian pool in which we all float, and in which the customer’s judgment is the determiner of who survives.\n\nThere’s a market in software development. As developers, we’re part of it.\n\nAnd that market is now world-wide.\n<transition>\nNow we’re all used to this trend. As stuff becomes commoditized (shoes, clothing, manufacturing, electronics, ...) it moves to where the labor is cheaper. In general this is a good thing for the economy (although it sucks if you work in that industry): we move on, adding value at a higher and higher level. But now we’re seeing something new.\n<transition>\nRead quote - stress “working in them for many years, an in come cases their whole lifetimes” High tech jobs are moving abroad. Much software development has become a commodity. And we’re the people who whom it sucks. Don’t believe me?\n\n\n
  18. Electronics/electrical is the faster migrator to all areas: Chin, Mexico, Asia, and Latin America. Jobs we’re used to losing (such as apparel, footwear, and autoparts) have already left the building.\n\nHow big is this problem?\n
  19. This is out of a total of roughly 3 million jobs that will be lost to overseas workers.\n\n\n
  20. \n
  21. Political: if you want to sell in our country, x% of your product must be made here\n\nCost: Foreign companies have lower overhead\n\nBut never make the mistake of assuming that because it’s cheaper, software produced abroad is lower quality. Sometimes companies outsource work because the quality is higher.\n\nLet me emphasize this: <transition>\n
  22. Political: if you want to sell in our country, x% of your product must be made here\n\nCost: Foreign companies have lower overhead\n\nBut never make the mistake of assuming that because it’s cheaper, software produced abroad is lower quality. Sometimes companies outsource work because the quality is higher.\n\nLet me emphasize this: <transition>\n
  23. Political: if you want to sell in our country, x% of your product must be made here\n\nCost: Foreign companies have lower overhead\n\nBut never make the mistake of assuming that because it’s cheaper, software produced abroad is lower quality. Sometimes companies outsource work because the quality is higher.\n\nLet me emphasize this: <transition>\n
  24. They don’t all write good code, but most countries that have been handling outsourcing for 7-10 years are capable of delivering standard commercial applications of high quality. There’s strong evidence for this.\n
  25. Ask audience:\n\nHow many folks have heard of CMM\n\nHow many of your companies participate in the CMM program (keep you hands up)\n\nLower you hand if you company is CMM level 2 or lower\n\n3\n4\n5\n\nWhat’s all this business with levels?\n
  26. Ask audience:\n\nHow many folks have heard of CMM\n\nHow many of your companies participate in the CMM program (keep you hands up)\n\nLower you hand if you company is CMM level 2 or lower\n\n3\n4\n5\n\nWhat’s all this business with levels?\n
  27. Ask audience:\n\nHow many folks have heard of CMM\n\nHow many of your companies participate in the CMM program (keep you hands up)\n\nLower you hand if you company is CMM level 2 or lower\n\n3\n4\n5\n\nWhat’s all this business with levels?\n
  28. “Heroic Effort” means developers constantly stepping in to fight fires and get the job done. CMM is not just concerned with the outcome, but how you got there.\n\nLevel two is “hmm - it’d be a good idea to manage this mess somehow”\n\nLevel three is senior management banging heads together to try to get some consistency.\n
  29. “Heroic Effort” means developers constantly stepping in to fight fires and get the job done. CMM is not just concerned with the outcome, but how you got there.\n\nLevel two is “hmm - it’d be a good idea to manage this mess somehow”\n\nLevel three is senior management banging heads together to try to get some consistency.\n
  30. “Heroic Effort” means developers constantly stepping in to fight fires and get the job done. CMM is not just concerned with the outcome, but how you got there.\n\nLevel two is “hmm - it’d be a good idea to manage this mess somehow”\n\nLevel three is senior management banging heads together to try to get some consistency.\n
  31. Here we start trying to be objective about what we’re doing, measuring so that we can control\n\n<transition>\n\nand finally using this information as feedback to improve the process.\n\nOn average, a company that’s serious about the CMM takes about 2-2.5 years to transition between levels.\n\nSo, how many CMM companies are there out there? Let’s look at the upper levels, starting with level four\n
  32. Here we start trying to be objective about what we’re doing, measuring so that we can control\n\n<transition>\n\nand finally using this information as feedback to improve the process.\n\nOn average, a company that’s serious about the CMM takes about 2-2.5 years to transition between levels.\n\nSo, how many CMM companies are there out there? Let’s look at the upper levels, starting with level four\n
  33. These are the August 2002 numbers, the latest survey from the SEI. There are 82 level 4 companies, 34 in the US and 48 overseas.\n\nNow let’s look at CMM level 5\n
  34. There are 76 CMM level 5 companies in the world. Of them, 13 are US-based. The remaining 63 are overseas, with the majority in India.\n\nCould be argued that this is a marketing ploy by overseas outsourcing companies: they feel they need CMM level 4 or 5 as a way of convincing US buyers of their commitment to quality. Perhaps that’s true. But given the choice between a CMM level 5 company that can work for $40/hour and a domestic one unable to prove any quality standards that charges $200/hr, where will the work flow?\n\nAnd this isn’t a future. This is now. Let’s look at what a senior manager in one of the world’s top-five companies said in a private e-mail.\n
  35. Read..\n\nAnd just to drive the point home, he went on to say\n
  36. Pause...\n\nSo, we’ve looked at three kinds of threat: technical obsolescence, eggs in one basket, and now the commoditization of software development, with the attendant migration to cheaper countries.\n\nLet’s summarize\n
  37. Life is going to change.\n\nWhat can we do about it?\n
  38. Let’s look at some solutions. The first two just plain won’t work (but they are still what people want). The last is our only hope.\n
  39. NJ bill says that money spent on public projects must result in work in the US.\n\nThen there’s the hoary H1B issue. The issue here is that developers from other countries come to the US to fill perceived shortfalls in the availability of US workers.\n\nThen we get to the wilder stuff. Perhaps we slap punitive tariffs on imported software. Or we fall back on the governments favorite strategy and legislate randomly.\n\nEconomists call this protectionism. And there’s bad news...\n
  40. NJ bill says that money spent on public projects must result in work in the US.\n\nThen there’s the hoary H1B issue. The issue here is that developers from other countries come to the US to fill perceived shortfalls in the availability of US workers.\n\nThen we get to the wilder stuff. Perhaps we slap punitive tariffs on imported software. Or we fall back on the governments favorite strategy and legislate randomly.\n\nEconomists call this protectionism. And there’s bad news...\n
  41. NJ bill says that money spent on public projects must result in work in the US.\n\nThen there’s the hoary H1B issue. The issue here is that developers from other countries come to the US to fill perceived shortfalls in the availability of US workers.\n\nThen we get to the wilder stuff. Perhaps we slap punitive tariffs on imported software. Or we fall back on the governments favorite strategy and legislate randomly.\n\nEconomists call this protectionism. And there’s bad news...\n
  42. How can we put tariffs on information when $100M of software development can be sent in an e-mail or carried on DVD? \n\nAnd if we do find a way to make it work, who suffers? We lose access to cheap software while the rest of the world benefits. How long will that last?\n\nThe inconveniences of individual developers who lose their jobs is not as significant as the ongoing competitiveness of the country as a whole. The history of other industries tell us this.\n\nAnd then there’s the H1B issue.\n\nAt this point in the presentation, there are normally some H1B folks in the audience looking very nervous. So far I seem to be blaming foreign workers for many of our woes. So let’s look at H1B’s in more detail.\n\n
  43. How can we put tariffs on information when $100M of software development can be sent in an e-mail or carried on DVD? \n\nAnd if we do find a way to make it work, who suffers? We lose access to cheap software while the rest of the world benefits. How long will that last?\n\nThe inconveniences of individual developers who lose their jobs is not as significant as the ongoing competitiveness of the country as a whole. The history of other industries tell us this.\n\nAnd then there’s the H1B issue.\n\nAt this point in the presentation, there are normally some H1B folks in the audience looking very nervous. So far I seem to be blaming foreign workers for many of our woes. So let’s look at H1B’s in more detail.\n\n
  44. How can we put tariffs on information when $100M of software development can be sent in an e-mail or carried on DVD? \n\nAnd if we do find a way to make it work, who suffers? We lose access to cheap software while the rest of the world benefits. How long will that last?\n\nThe inconveniences of individual developers who lose their jobs is not as significant as the ongoing competitiveness of the country as a whole. The history of other industries tell us this.\n\nAnd then there’s the H1B issue.\n\nAt this point in the presentation, there are normally some H1B folks in the audience looking very nervous. So far I seem to be blaming foreign workers for many of our woes. So let’s look at H1B’s in more detail.\n\n
  45. H1Bs were introduced with the intent of filling an apparent shortage of skilled workers. The majority of H1Bs are in IT. H1Bs can stay in the US for up to six years. They have to have an accredited degree or significant corresponding work experience. They have to be sponsored by a company here, which has to prove a need, and prove that the H1B will be paid a wage comparable to an equivalent US worker. The legislation tries to prevent H1B workers from displacing local workers.\n\nDuring the dotcom boom, the H1B cap was raised to 195k visas pa, but it will drop back to 65k next year. This year it failed to reach the cap.\n\nThe H1B program is deeply flawed. But the problem doesn’t lie with the concept, nor with the programmers we invite to the US. The problem lies with corruption at the corporate level. Some employers misstate salaries, lie about their needs and a particular job’s requirements, and fire local workers 90 days after hiring an H1B. \n\nThese companies should be prosecuted. But the system should not be scrapped.\n\nThe truth is I believe philosophically that work should go abroad, and that we should encourage the best of the world’s programmers to come to the US. We can’t stop the former, and the wealth of this country was built on foreign experts. \n\nBut even if you disagree with this, what would happen if we scrapped the program?\n
  46. We hurt ourselves. If we accept that H1B workers currently offer the US cheap programmers, then eliminating the program will simply accelerate the outsourcing of entire projects overseas. After all, the pressures that lead to the corruption of the H1B program won’t go away.\n\nThere’s a secondary effect: by isolating ourselves from the rest of the world, we stop learning from some truly great programmers.\n\nSo -- end of rant.\n\nIt looks like there’s not much the government can do. Who else could help?\n
  47. Some folks might argue that companies help by providing training: many folks companies will pay for them to come to Jay’s symposium, which is great.\n\nBut ultimately companies train developers to satisfy specific short-term needs. These are for the company’s benefit, and only indirectly benefit the developer. \n\nSo let’s summarize the solutions so far\n
  48. So who’s going to help?\n\nWe can summarize this in three words: <next slide>\n
  49. So who’s going to help?\n\nWe can summarize this in three words: <next slide>\n
  50. So who’s going to help?\n\nWe can summarize this in three words: <next slide>\n
  51. So who’s going to help?\n\nWe can summarize this in three words: <next slide>\n
  52. If you take nothing else away from this talk, please remember these three words.\n\nBut what does it mean to invest in yourself?\n\nCan we learn from other areas that talk about investing?\n\n I believe so...\n
  53. Financial planners keep berating us with tips for handling our investments\n\nHave a plan: am I investing for my retirement, for kid’s college, to buy a new boat.. the objective changes what you do. Classic example is investment term: long term you can afford riskier investments\n\nDiversify: Enron\n\nValue: Look at the fundamentals of your investments. Is there something solid there, or is it just hype?\n\nActive, not passive: keep monitoring your portfolio - rebalance when necessary. NOT THE SAME AS THRASHING\n\nRegular investing: investing has to be a habit, otherwise thing slip.\n\nThis is all sound financial advice. How does it apply to computer programming.\n\n
  54. In finance your portfolio is the basket of stocks, bonds, cash, and other investments you own. Their value comes from how much other people think they’re worth.\n\nIn your career, your portfolio is the stuff you know, and, more importantly, your talent at applying it. Its value comes from how well people think you can do this.\n
  55. Own judgment: where will industry be. Need to do some research: look for trends, talk with people, read papers, magazines, and books. What are emerging trends?\n\nLook for solid trends, not just fads.\n\nSee where you want to fit in to this.\n\nIdentify the gap, and plan to fill it.\n\nFor example...\n
  56. \n
  57. \n
  58. \n
  59. \n
  60. \n
  61. \n
  62. Your don’t want to be left being the expert in an Enron technology\n\nThere are lots of aspects of the stuff we know. Remember them all while diversifying.\n\n\nDon’t talk too much about this one - subsequent slides cover it\n\nDiversification lowers risk by spreading investment.\n\nDiversity also allows you to increase return by including some higher risk/higher reward knowledge in your portfolio. <next slide>\n
  63. If you catch a wave, it can accelerate you dramatically. There are fewer early adopters, so if something becomes hot, you can command more money.\n\nDon’t give up your day job...\n
  64. Unlike financial investing, knowledge portfolios always accumulate some return.\n
  65. In financial investing, so spend money to accumulate more money.\n\nIn your professional portfolio, you expend time to accumulate more wisdom.\n\nIn financial investing, look for investments with strong fundamentals. It’s the same with knowledge investing. Just spending time isn’t the same as building value.\n\nNot just theoretical: how do you know the knowledge you’re accumulating is valuable? LOOK FOR FEEDBACK. Apply it.\n\nAdvice to people just starting out: look for quality of experience, not just salary.\n\n
  66. Feedback is important in everything we do. Don’t forget to gather feedback on your investment plan: \n* how well is it doing\n* is it still applicable\n* is it time to rebalance\n\nAm I doing the right thing\nAm I doing it the right way\nDoes it have to be done at all\n\n
  67. Norm Kerth - ritual helps when we’re doing something that doesn’t come naturally\n\nMake a commitment to spend at least n hours per month.\n\nThen plan that time: set up a schedule for investment\n
  68. Two hours? Where can I find two hours?\n\nInvest it now, or you’ll have all the time in the world to invest it later..\n\nDon’t try to do it alone. Mix group and individual learning opportunities (go into on later slides)\n\nBuild a community.\n\nEmphasis here is on the plan. So what might a typical plan look like\n
  69. Obviously you folks are already doing this.\n\nBut to what extent are you actively participating. If you haven’t yet given a talk, seriously consider giving one. While you’re working, look for technologies you’re using that are not as common, or techniques that others might find interesting. \n\nunit testing\na Java API\na database\na design technique\ndeploying applications\n...\n\n
  70. \n
  71. \n
  72. \n
  73. Work towards the objective in your individual plan\n
  74. \n
  75. \n
  76. \n
  77. \n
  78. \n
  79. \n