Please create an account to participate in the Slashdot moderation system

 



Forgot your password?
typodupeerror
×
Software

How to Keep Your Job 59

An anonymous reader submits: "Dave Thomas of "Pragmmatic Programer" fame presents the first in a series of slides based on presentations about how programmers can maintain job security in this time of increased competition, cost cutting, outsourcing, etc. He makes several excellent points about things many programmer may not think about such as the dangers of over-reliance on one company or sector, the importance of diversity of knowledge, the fact that foreign programmers CAN produce quality code, and the fact that time does NOT necesserily equal value (the Everquest Syndrome) when it comes to software engineering. There is a lecture that goes along with the slides, but a great deal can be learned from the slides alone. Worth the read..."
This discussion has been archived. No new comments can be posted.

How to Keep Your Job

Comments Filter:
  • by Kalak ( 260968 ) on Monday March 24, 2003 @03:37PM (#5585062) Homepage Journal
    Stop hanging out on /. all day! FP != a job.
  • CMM? (Score:5, Insightful)

    by sporty ( 27564 ) on Monday March 24, 2003 @03:40PM (#5585082) Homepage
    CMM is a tool for identifying process ability, not code quality. i.e.

    Someone at CMM 1 would be totally chaotic. Think waterfall on crack, skipping about back and forth randomly, developers coding on the whim of people.

    At CMM5, there's be a strict set of policies (1 or 2, maybe more) that are repeatable, managed and are being optimized.

    To say that developers across seas bring about CMM 3 or 4 is saying nothing. CMM isn't about one type of people, much less any people. It's about process a group uses to deliver. If they mean consultant companies across seas have higher CMM, maybe, but I'd think the language barrier would slow things down.
    • Re:CMM? (Score:3, Insightful)

      by emag ( 4640 )
      Right, this always bugged me when we were getting CMM rammed down our throats. Management kept saying how it would improve the quality of our code and make us competitive. Us grunts pointed out that (aside from wasting quite a bit of time in CMM-related presentations), all it would do is codify the existing process, even if flawed. So if we had a process that produced severely b0rked products currently, getting to CMM level 4 or 5 would just mean we would consistently have b0rked products...
      • No, not really. CMM isn't about coding at all. Hell, it doesn't have to be about technology. It's just about doing N steps, from 1-N, in a fashion.

        If your coding process was at level 4 or 5, that means the segment is going for optimization and is highly repeatable (wrote that backwards).

        Saying any individual coder is at CMM 4 only works if one person is the entire process. This doesn't work in the biz world like that. Great, a person capabale of working at CMM 5 will only be brought down to 1 when pu
        • Re:CMM? (Score:3, Interesting)

          by pmz ( 462998 )
          Saying any individual coder is at CMM 4 only works if one person is the entire process.

          I'm pretty convinced that any project with one or only a few developers is CMM Level 1, regardless of what the CEO brags about. The CMM implies bureaucracy, where there really needs to be additional people on staff to handle all the documentation. Other people are needed to enforce the process. There also needs to be extra managers to handle all the new communication overhead. Don't forget the payroll people to han
          • I'm pretty convinced that any project with one or only a few developers is CMM Level 1, regardless of what the CEO brags about. The CMM implies bureaucracy, where there really needs to be additional people on staff to handle all the documentation. Other people are needed to enforce the process. There also needs to be extra managers to handle all the new communication overhead. Don't forget the payroll people to handle all the new accounting practices. Oh, and there's the system administration overhead of al

            • >If their process is higly repeatable and optimized and are looking to improve, they'd be at 5.

              Erm, do you *want* to work in an environment where your work ("the process") is highly repeatable? Where's the fun in that?

              Seriously tho, these kinds of "process" thingys always give me the impression that they are implemented (and followed) in places where the management hasn't got a clue; in places where management believes that the "workers" don't have a clue; in places where the management believes that a
              • Re:CMM? (Score:3, Insightful)

                by sporty ( 27564 )

                Erm, do you *want* to work in an environment where your work ("the process") is highly repeatable? Where's the fun in that?

                I like having hair colour ;)

                Seriously tho, these kinds of "process" thingys always give me the impression that they are implemented (and followed) in places where the management hasn't got a clue; in places where management believes that the "workers" don't have a clue; in places where the management believes that an employee cannot possibly *want* or *enjoy* his job, and has to be

            • by pmz ( 462998 )
              Your family can be at CMM 5...

              Officially, only the SEI (or people acting on its behalf, I suppose) can evaluate a company and say they are "CMM Level 5". Getting to this point requires putting forth the proof that a process is repeatable, which for any group of humans, requires bureaucracy to handle the documentation and enforcement of the process. Strong will and discipline is sufficient for organizing a family, but it isn't sufficient for obtaining CMM level 5.

              Also, processes implementing the CMMs
              • Also, processes implementing the CMMs are highly company-specific, which add an even higher learning curve and training burden for developers and managers. Imagine, in the family scenario, having peer reviews and QA meetings for each meal served, the greenness of the yard, why isn't Jimmy doing well in Algebra, etc. while keeping written records of it all for accountability and future analysis. For small teams, it is very possible for this sort of process to interfere with getting real work done.

                Realize,

        • Btw, is "codify" really a word?

          Yes.

          http://dictionary.reference.com/search?q=codify

      • Well, remember that one of the goals of level 5 is the feedback loop, in which you are constantly examing your processes. I agree, though... it's not going to magically fix bad programming procedures.
      • Re:CMM? (Score:3, Interesting)

        So if we had a process that produced severely b0rked products currently, getting to CMM level 4 or 5 would just mean we would consistently have b0rked products...

        [g] Well, not really. This is an interesting statement, though, in light of an e-mail exchange I just had with a colleague whose co. outsourced to an offshore-heavy consulting firm about a year ago. Turning the floor over to her via copy/paste, slighly edited & with names redacted for job-preservation purposes:

        "[Consultant co] claims thei

        • All of these process "things" like CMM are really just about having written policies and following them. They have nothing to do with the quality of anything unless you measure quality as conformance to the process (which would be a circular argument).

          Getting SEI certification is about paying the right consultants and having at least a plausible story about meeting a particular CMM level.

          The biggest problem I have with these things is that there really isn't any proof that a standardized approach is helpf
    • Does CMM take into account support? I've been hearing _many_ horror stories of companies outsourcing code to overseas (mostly Indian) programming firms (accenture comes to mind). If you're at a company and you hear a name like accenture, run like hell or obfuscate your code has quickly as possible!

      More to the point: These companies are providing "cheap programming"; but their customers are realizing very rapidly that "cheap programming" is shoddily documented (if at all), and the likelihood of getting
      • Depends on the account you are talking about. It soundslike you are talking about outsourcing to a vendor. CMM takes into account trends in a company, so if you outsource to a vendor that doesn't know what they are doing and you cancel things /w them due to incompetence, well.. taht's one thing. If you integrate working with them into your process..well.. that's another.
  • by Strange Ranger ( 454494 ) on Monday March 24, 2003 @03:51PM (#5585169)
    I think


    William Shatner...

    Invented,


    Power

    Point
  • Keep your job? (Score:4, Redundant)

    by ptaff ( 165113 ) on Monday March 24, 2003 @03:51PM (#5585176) Homepage
    Focus on cross-platform languages and libraries.
    You may not keep your job anyway, but you'll be flexible.

    The market for programmers slowly moves away from Microsoft. If you code in Visual Basic, you can be sure that only Microsoft-oriented companies will employ you.

    Companies more and more switch to non-Microsoft solutions, meaning that they must switch programmers too. Knowing UNIX is becoming more and more of an asset; you might not know all the intricacies of bash or emacs, but if you code in perl you can be employed by Win/Lin/Mac/UNIX worlds...

    Whenever possible, go for java instead of C#. Go for PHP instead of ASP. Learn to use as little platform-dependant code as possible.

    • Don't forget Delphi instead of VB since it is cross platform now with the release of Kylix.
    • Re:Keep your job? (Score:4, Insightful)

      by pmz ( 462998 ) on Monday March 24, 2003 @04:36PM (#5585521) Homepage
      Focus on cross-platform languages and libraries.
      You may not keep your job anyway, but you'll be flexible.


      An additional benefit is that the concepts behind platform-independent technology are often behind the proprietary stuff as well. For example, if an interviewer asks about ASP, the interviewee can say "well, I'm familiar with JSP and/or PHP, which shares many of the concepts behind ASP, such as session management, ..."
    • Whenever possible, go for java instead of C#. Go for PHP instead of ASP. Learn to use as little platform-dependant code as possible.

      Doing this while employed for a company that is using C# and ASP is a great way to NOT keep your job.
      • Doing this while employed for a company that is using C# and ASP is a great way to NOT keep your job.

        Not if you're doing it on your own time. Though, yeah, a lot of us don't have enough free time to be coding outside of work (too busy getting drunk). But when I looked for jobs, I turned down the companies who were focused on Microsoft-based solutions, and went for the companies that were using cross-platform solutions; and I'm glad I did it; even with lesser pay the experience is so much more valuable.
    • The market for programmers slowly moves away from Microsoft.

      Companies more and more switch to non-Microsoft solutions, meaning that they must switch programmers too. Knowing UNIX is becoming more and more of an asset;

      This is exactly the kind of advice people were giving for job security back in the early to mid 90s -- except reversed.

    • Re:Keep your job? (Score:3, Interesting)

      by thogard ( 43403 )
      Whenever possible, go for java instead of C#. Go for PHP instead of ASP.

      If your at the level where this advice makes sense to you, go the local university and enroll in something that isn't programming realted.

      All the best coders I know started with assembly language and not one of them started in a high level language. Real coders can work in machine code if needed because they understand whats going on at the low level.
      • If your at the level where this advice makes sense to you, go the local university and enroll in something that isn't programming realted ... Real coders can work in machine code if needed because they understand whats going on at the low level.

        If you're at the level where this post makes sense to you, go to the local university and enroll in something that will teach you proper grammar and spelling.
      • The point I was trying to make was that you'd better use a cross-platform language than a proprietary/single platform language.

        There was no question of flaming a language or another. Slashcode shouldn't be written in Logo and kernels shouldn't be written in Fortran. A java programmer is no less a programmer than a hardcore macho coder blaming hexadecimal for oversimplification of binary.

        Know why they invented high-level languages? because maintaining assembly is a time-consuming nightmare. We need it fo
      • Bull. Real "coders" can learn any language because they realize it's not the language that's hard. It's the algorithms, data structures, design trade-offs, etc that are hard.

        Anyone who cannot pick up a new language in a week is a beginner.
      • I'm a "real coder" who started in assembly years ago, and there's no way I would start my son that way now.

        Assembly used to be for general purpose programming. Today it is a small niche tool. Back when it was for general purpose programming, higher-level languages could often reasonably be thought of as shortcuts for writing assembly. The shortcuts weren't as good as the real thing, but they were quicker and often good enough. Still, it made sense to keep in mind the assembly that you were "really writing"
        • While I agree that assembly is very rarely required these days, a programmer who has a strong understanding of assembly language still has an advantage over one who has never been exposed to it. I have been programming for 23 years (20 professionally) and I always find the best HLL coders are the ones who know assembly and understand the strengths and limitations of the underlying machine architecture.
  • Slides 41+42 (Score:5, Insightful)

    by dmorin ( 25609 ) <dmorin@g[ ]l.com ['mai' in gap]> on Monday March 24, 2003 @04:13PM (#5585353) Homepage Journal
    Pretty much sum up a huge portion of the slashdot audience, I think. I consider myself a good programmer who loves a challenge and wants to stay technical. Therefore I should look for technologies that will not be outsourced, teach myself those technologies via open source, and write articles / speak/ otherwise become recognized expert in that area.

    In general I think the first half of the presentation just says why things are bad and why stuff like "rely on government to fix the h1 problem" won't work, so it's only really the second half that has the advice.

    I think it's a little ambiguous that in the beginning it says the half life for typical technology is 7-2.5 years, but in the end suggests planning for the future 5-10 years out. That's pretty hard.

    Or that specific skills, like "I'm a java programmer", are bad. Sure, all programmers *want* to use the line "A good programmer can pick up any language easily" but in THIS job market? Are ya kidding? Sure, 3 years ago we were desperate enough that we took C++ or Smalltalk people when we wanted Java. But in today's market do I really expect that people who want C# are going to take me the Java geek and say "Oh, sure, he can pick up C# no sweat?" When there are 500 other guys applying for the same job that already have C# and couldn't hack Java to save their lives?

    I'd like to recommend the "write articles" approach, by the way. Quite a fun way to learn a new technology when you don't have a boss who is making you learn it but still need the motivation. The two problems are that a) there are so many people doing this that many magazines don't pay $$ anymore, just "recognition", and b) I've had recruiters chop the "Publications" section out of my resume because they claim that it's never the thing that gets you the interview (although you can certainly talk about it once you do get the interview).

    Lastly, sometimes bad things happen to companies and a whole geographic region goes away. Don't blame yourself. My boss once told me that I was part of his baseline for the team and I was leaving that meant the team was gone. Well, the team is being dissolved, therefore I'm gone. But I can't have any hard feelings or say "Damnit I wish I'd learned technology X." I can only look forward toward my next job, whatever it may be.

  • Another Slide (Score:2, Insightful)

    by chemstar ( 457943 )
    Build a professional friendship with your boss.
    • Nah... just do what our mentor [ntk.net] does. Snitch a few special emails, maybe plant a few webcams...

      I wonder if there are actually any admins out there who get away for BOFH-like power?
  • If you read the article, ignore the stats. They are over-simplified and there is no text to qualify them. Example:
    CMM level 4
    USA: 41%
    Overseas: 59%

    What does this mean? 41% of all us companies are CMM level 4? level 4 or above? Or does it mean all CMM level 4 companies are in the US and 59% are overseas?

    (These are rhetorical questions - the answer is irrelevant, the point is that it isn't clarified in the paper so don't even pay attention to them)
    • It's 59% of all CCM level 4 compaines are overseas. CCM level 4 is more importaint for overseas companines because they use it to try to win business.

      I work for a company that went through the ISO-9002 process. It was good for the company and the audit showed where some of the processses were weak. It turns out that not one of our customers cared that we were iso-9002 certifed and it costs a fortune for a small company so it dumped.
  • Times Changes (Score:3, Insightful)

    by tds ( 128757 ) on Monday March 24, 2003 @06:15PM (#5586508) Homepage
    It's an interest presentation but it reminds me of one of those self help books! But it raised some very interesting points.

    The discussion points mainly revolve around off-shore development, technology life cycles and bad economic conditions.

    From experience off-shore development is not simple a matter of taking code off shore, it includes other large components of management, processes, extended organizational structures, cultural considerations and creativity. Which are often under estimated or completely misunderstood. In addition some activities are not a good fit for out-sourcing but are out sourced any way, by managers sacrificing long term success against short term needs.

    I would draw the conclusion that there is a real trend out there for out-sourcing but there are real opportunities for people to fill the high value areas that I have out lined above. Most of all I think that creativity and innovation are very important factors and will always be in demand.

    Technology life cycles are a fact of life for everyone involved in technology, the good news is that it creates an even playing field; the bad news is that it drives intense competition and disruptive change. The bottom line is if you want to stay in the business you have to make a commitment to constantly learning and keeping your skills up date.

    The current economic environment may well be driving change in our industry, some of us may view as negative. But looking forward demand will return and we have a stronger base to build on as people and companies that get through this will be stronger and more competitive.

    After all this is what we do...
  • by t482 ( 193197 )
    The main thing to focus on is value added. If most of your code is reused open source stuff you don't need to worry as much.

    From an article I wrote:
    http://xminc.com/linux/hottest_it_skills. h tml

    Focus on Value Add

    Value-add is mostly common sense - but common sense many IT professionals miss as their vision is clouded by technical details. How can you add the most value to your customer ? i.e. " What is my current/future customer/employer's biggest problem - and what can I do to fix it most efficiently and
  • ...Is management not improving. The same things that make my life as a developer in the US lousy - vision/requirements/clue/ (I'll just stop now) - tend to have catastrophic results when shipped overseas. Capable business can actually pull this off, but most of the time the n00bs that (biting tongue again) could not communicate effectively enough to leverage low expense labor.

    Don't train the (deep breath) managers - just encourage their involvement in those 'high profile, cost effective' projects. Hell,

Trying to be happy is like trying to build a machine for which the only specification is that it should run noiselessly.

Working...