Home > Uncategorized > Recommendations for teachers of programming

Recommendations for teachers of programming

December 29th, 2008 Derek-Jones

The software developers I deal with usually have at least 3 or more years professional experience in industry (I have not taught a beginners programming class in over 25 years) and these recommendations are based on what I tell these people. I like to think that they are applicable to teaching the3ose with a lot less experience.

First. Application domain expertise generally has greater value than programming expertise. That is, an investment of time in learning the application domain will yield a greater return on investment that learning more programming techniques.

Implications:

  • Minimize the amount of programming knowledge that your students need to know. For instance, there is little to be gained by teaching them the umpteen possible combination of looping constructs that can be written; in practice one or two account for 90% of all usage in industry. Teach the common cases and keep hammering on them until people use them without thought.
  • Criticize students for their failure to understand the application domain not coding constructs they use. For instance, use of loops when other techniques are available is not inefficient coding it is a failure to understand the application domain, anyway (if the application domain involves strings they should think string manipulation not looping over individual characters, if a domain uses vectors use vector arithmetic not loops over individual values, if a domain uses sets think sets manipulation), why are you even thinking about coding efficiency?
  • Set problems that enable students to build on previously learned programming skills to solve different application domain problems.
  • Second. Computer time is cheap, people time is expensive.

    Implications:

  • Code optimization is invariably an inefficient redistribution of time from computers to people. Writing efficient code is an advanced topic best left until after graduation and a year or two in industry. If performance is an issue concentrate on the algorithms.
  • Programming by fitting together chunks of code having a well understood (to the author) behavior can be a fast way of getting programs written (once students have a repertoire of the necessary chunks) and the fact that the code is not the most computer efficient is irrelevant.
  • Developers trying to optimize every bit of code they write is the single biggest cause of poor coding habits that I encounter and these habits tend to be so ingrained that it requires a huge effort to change them. Don’t warp peoples minds when they are at their most impressionable at the start learning to program, just because you were abused is not a reason for you to abuse others.
  • Third. Most software is written to solve an immediate problem, used a few times, and then forgotten about (I know of software projects costing in the millions where the code was never used; my own contribution to never used code is somewhat smaller, but still much larger than I would have liked). The point is that writing software involves a cost/benefit trade-off, how much should I invest in making code maintainable given the risk that the benefits from this investment may not be recouped.

    Implications:

  • If a program is only run a few time it does not really matter how fast it runs, ie, optimization at the code level is pointless and in many cases the algorithm used will not make a lot of difference.
  • A few brief comments specifying input/output, any assumptions made and revision dates (a few seconds typing can save an hour later trying to figure out which is the ‘latest’ version). Anything more is bureaucratic dead weight, usually inserted to keep management happy, rarely correct and a general time sink. Don’t put people off commenting because of the memories they have of the pointless comments their instructor made them write.
  • Fourth. Don’t fool yourself that you are teaching programming; you probably simply give a lecture or two and expect students to pick up the details from one of the assigned course books.

    Implications:

  • Students pick up lots of folklore that gets them through the course; work with this not against it. You are the chief wizard, give them a few powerful principles spells that can be applied to solve the problems they are likely to encounter. Understanding takes more time than is available, accept this fact.
  • Fifth. Coding style does exist and can have an effect on the cost of writing and maintaining code as well as how well a compiler can optimize it. These costs and benefits vary with the context in which the code was created and used. A good programmer will adopt a coding style appropriate to the context, just like an actor plays a role with the appropriate characterization (eg, comedy, thriller, suspense). It takes more experience than most undergraduate have to be able to properly discern what style is being used, let alone be capable of changing their own style.

    Implications:

  • Encouraging students to adopt some coding style is at best a waste of time and often causes people to thoughtlessly adopt inappropriate practices and becoming inflexible in their habits (to the point of ignoring further learning opportunities). Let students experiment and find a method of writing that works for them no matter how much it offends your sense of taste (they probably think the same about your dress sense as you do about their coding style and both issues are equally irrelevant).
  • Warn students that they are likely to encounter people proclaiming the one true way to writing great code and recommend that they ask these self proclaimed gurus for proof (ie, experimental studies published in peer reviewed journals) that using the proffered techniques will result in the claimed outcome.
  • Comments are closed.
    FireStats icon Powered by FireStatsgeneric cialis from india
    how does viagra work
    generic propecia cheap
    female viagra
    levitra 20mg
    how strong is 5 mg of cialis
    cialis brand name
    online cialis
    levitra best price
    buying generic cialis mexico rx
    discount canadian cialis
    generic viagra canadian
    viagra generic canada
    viagra online deals
    viagra propranodol
    cheap cialis
    cialis once daily
    viagra prescriptions
    where to buy propecia
    cialis 20 mg
    cialis soft canada
    soft viagra
    best prices for propecia
    viagra buy now
    similar cialis
    canadian pharmacy discount code viagra
    cialis soft canada
    cialis by mail
    brand viagra over the net
    about cialis
    buy discount viagra
    viagra available in india
    buy discount viagra
    cialis to buy
    buying viagra without prescription
    herbal viagra
    levitra online pharmacy
    viagra generic canada
    cost of daily cialis
    cialis uk
    generic online propecia
    overnight viagra
    prices cheapest levitra
    canadian viagra
    cialis samples
    brand name cialis overnight
    use levitra
    natural viagra
    lowest price propecia best
    viagra discount
    buy prescription propecia
    spain female viagra
    purchase cialis
    buy viagra in canada no prescription
    best price levitra
    cialis price 100 mg
    online viagra
    cialis no rx
    buy daily cialis
    cialis kanada
    viagra dose
    original levitra
    which is better viagra cialis
    viagra india
    buy real viagra online without prescription
    viagra in canada pfizer
    canada viagra
    ordering viagra
    5 mg cialis canada
    when will viagra be generic
    viagra online without a prescription
    canadian pharmacy
    purchasing cialis
    viagra canada
    cialis for less 20 mg
    generic cialis next day shipping
    online generic cialis 100 mg
    cialis at real low prices
    cialis philippines
    how to buy cialis in canada
    cheap generic levitra
    levitra sale
    buy pfizer viagra
    low cost canadian viagra
    viagra online 50mgs
    us cialis
    name brand cialis
    buy levitra in europe
    canadian viagra
    cialis and diarrhea
    levitra from canada
    viagra doses
    viagra soft
    viagra order
    canadian viagra and healthcare
    cheap order prescription propecia
    canadian viagra india
    lowest price for levitra
    cheap viagra from uk
    best way to take cialis
    viagra professional
    what is cialis
    cialis profesional
    cialis daily
    cialis low price
    viagra tabs
    real viagra online
    pfizer viagra canada
    cialis and ketoconazole
    cialis on line pricing in canada
    viagra tablet
    buy cialis in canada
    name brand cialis
    canadian healthcare viagra
    viagra canada
    cialis arterial fibrillation
    buying viagra with no prescription
    non pescription cialis
    women viagra
    generic cialis
    lowest price propecia
    how to get viagra
    viagra brand
    viagra in australia for sale
    viagra fast delivery
    viagra label
    buying cialis soft tabs 100 mg
    cialis medication
    healthcare of canada pharmacy
    soft cialis
    overnight delivery cialis
    viagra made in india
    viagra canadian scam
    cialis price
    viagra for cheap
    cheap discount levitra
    canada meds viagra
    cialis brand
    generic viagra canada
    5mg propecia
    where can i buy real viagra
    buy viagra online canada
    gele viagra
    canada viagra generic
    indian generic levitra
    canadian generic viagra online
    cialis daily canada
    viagra buy
    cialis dosage
    viagra levitra
    buying viagra in the us
    prices levitra
    discount cialis india
    cialis profesional
    ordering cialis gel
    viagra canadian pharmacy dosage
    ordering viagra overnight delivery
    how to get cialis
    cialis soft tablets
    cialis overnight
    should i chew cialis
    woman testimonial of cialis
    canadian propecia cheap
    levitra vs viagra
    low cost viagra
    cialis india
    obtain viagra without prescription
    viagra 100 mg
    cialis woman
    buy branded viagra
    viagra pills
    cialis for women
    cialis levitra sales
    viagra how much
    viagra no prescription
    viagra through canada
    viagra fast delivery
    viagra for cheap
    original levitra
    bying viagra online cheap us
    online generic cialis 100 mg
    online order viagra overnight delivery
    canadian pharmacy
    cialis transdermal
    healthcare canadian pharmacy
    buy viagra pills
    cialis on sale
    cialis trazodone
    usa cialis
    no prescription propecia
    cialis low price
    low cost canadian viagra
    viagra canadian scam
    viagra sales canada
    cialis india
    cialis india pharmacy
    female viagra pills
    buying real viagra without prescription
    what is cialis professional
    cialis prices
    online cialis
    viagra purchase
    china viagra
    viagra femele
    cialis soft
    cialis iop
    viagra tablets sale
    rx generic viagra
    cialis next day
    cialis quick shipment
    cheepest cialis
    viagra cheap
    viagra prescription label
    generic cialis next day delivery
    usa cialis
    cheapest propecia prescription
    viagra cost
    canadian generic cialis
    cialis generic
    viagra without prescription
    viagra oral gel
    viagra in spain
    how much cialis
    levitra online us
    levitra online sales
    viagra purchase
    canadian women viagra
    pfizer mexico viagra
    cheap viagra from uk
    overnight viagra generic
    purchasing cialis
    viagra doses
    brand viagra professional
    women viagra
    real cialis
    cialis for woman
    viagra next day delivery
    next day viagra
    buy propecia online from usa pharmacy
    pfizer viagra 50 mg online
    viagra 50 mg
    cheap propecia 5mg
    viagra 100mg england
    canada viagra generic
    viagra soft tabs 100 mg
    viagra sales in canada
    viagra rx in canada
    online order viagra overnight delivery
    cialis
    no prescription viagra