Archive

Posts Tagged ‘expertise’

Measuring developer coding expertise

February 4th, 2009 Derek-Jones No comments

A common measure of developer experience is the number of years worked. The only good that can be said about this measure is that it is easy to calculate. Studies of experts in various fields have found that acquiring expertise requires a great deal of deliberate practice (10,000 hours is often quoted at the amount of practice put in by world class experts).

I think that coding expertise is acquired by reading and writing code, but I have little idea of the relative contributions made by reading and writing and whether reading the same code twice count twice or is there a law of diminishing returns on rereading code?

So how much code have developers read and written during their professional lives? Some projects have collected information on the number of ‘delivered’ lines of code written by developers over some time period. How many lines does a developer actually write for every line delivered (some functions may be rewritten several times while others may be deleted without every being making it into a final delivery)? Nobody knows. As for lines of code read, nobody has previously expressed an interest in collecting this kind of information.

Some experiments, involving professional developers, I have run take as their starting point that developer performance improves with practice. Needing some idea of the amount of practice my subjects have had reading and writing code I asked them to tell me how much code they think they have read and written, as well as the number of years they have worked professionally in software development.

The answers given by my subjects were not very convincing:

Amount of code read/written

Estimates of the ratio code read/written varied by more than five to one (the above graph suffers from a saturation problem for lines of code read, I had not provided a tick box that was greater than 250,000). I cannot complain, my subjects volunteered part of their lunch time to take part in an experiment and were asked to answer these questions while being given instructions on what they were being asked to do during the experiment.

I have asked this read/written question a number of times and received answers that exhibit similar amounts of uncertainty and unlikeliness. Thinking about it I’m not sure that giving subjects more time to answer this question would improve the accuracy of the answers. Very few developers monitor their own performance. The only reliable way of answering this question is by monitoring developer’s eye movements as they interact with code for some significant duration of time (preferably weeks).

Unobtrusive eye trackers may not be sufficiently accurate to provide a line-of-code level of resolution and the more accurate head mounted trackers are a bit intrusive. But given their price more discussion on this topic is currently of little value :-(

Criteria for knowing a language

December 23rd, 2008 Derek-Jones 1 comment

What does it mean for somebody to claim to know a computer language? In the commercial world it means the person is claiming to be capable of fluently (i.e., only using knowledge contained in their head and without having to unduly ponder) reading, and writing code in some generally accepted style applicable to that language. The academic world generally sets a much lower standard of competence (perhaps because most of its inhabitants leave before any significant expertise is acquired). If I had a penny for every recent graduate who claimed to know a language and was incapable of writing a program that read in a list of integers and printed their sum (I know companies that set tougher problems but they do not seem to have higher failure rates), I would be a rich man.

One experiment asked 21 postgraduate and academic staff which of the following individuals they would regard as knowing Java:

  • A cannot program in Java, but knows that Java is a popular programming language.
  • B cannot write a Java program from scratch, but can make very simple changes to an existing Java program (such as changing a string constant that specifies a URL).
  • C can use a tool such as JBuilder to write a very simple Java program, but cannot use control flow constructs such as while loops.
  • D can write Java programs that use while loops, arrays, and the Java class libraries, but only within one class; she cannot write a program that consists of several classes.
  • E can create complex Java programs and classes, but needs to occasionally refer to documentation for details of the Java language and class libraries
  • The results were:

    _ NO YES
    A 21  0
    B 18  3
    C 16  5
    D  8 13
    E  0 21

    These answers reflect the environment from which the subjects were drawn. When I wrote compilers for a living I did not consider that anybody knew a language unless they had written a compiler for it, a point of view echoed by other compiler writers I knew.

    I’m not sure that commercial developers would be happy with answer (E), in fact they could probably expand (E) into five separate questions that tested the degree to which a person was able to combine various elements of the language to create a meaningful whole. In the commercial world stage (E) is where people are expected to start.

    The criteria used to decide whether somebody knows a language depends on which group of people you talk to; academics, professional developers and compiler writers each have their own in-group standards. In a sense the question is irrelevant, a small amount of language knowledge applied well can be used to do a reasonable job of creating a program for most applications.

    FireStats icon Powered by FireStatsbest cialis price

    buy daily cialis

    generic cialis canada

    generic cialis sale

    canadian viagra india

    canadian pharmacy viagra legal

    mail order propecia

    cheapest viagra online

    cialis daily availability

    discount brand name cialis

    lowest price propecia costs us

    brand name cialis

    cialis from mexico

    how can i get some cialis

    canada viagra

    buy branded viagra

    cheap propecia online prescription

    how to buy cialis in canada

    buy cheap online propecia

    cialis dosagem

    cialis cost

    generic viagra india

    levitra buy online

    canadian healthcare pharmacy

    cialis in mexico

    5 mg cialis canada

    cheapest propecia pharmacy online

    buy levitra online us

    cheap viagra on line

    cialis cheap

    cialis quick shipment

    buy levitra overnight

    buy viagra in canada

    cheap fast levitra

    cialis alternatives

    buy cialis fedex shipping

    is pfizer viagra available in india

    buy levitra online no prescription

    cost of daily cialis

    cheapest propecia pharmacy online

    generic cialis sale

    buying cialis next day delivery

    levitra 20mg

    cialis 100 mg generic

    buy cialis cannada

    levitra canadian

    discount propecia propecia

    canadian pharmacy cialis pfizer

    order propecia online

    best doses for propecia

    buying real viagra without prescription

    lowest propecia price

    cialis philippines

    canada cheap propecia

    lowest price for levitra

    can i order viagra from the chemist

    buying viagra

    cialis 100 mg

    canadian viagra

    cheap order prescription propecia

    buy propecia generic

    online order viagra overnight delivery

    canada propecia prescription

    cialis one a day

    buy cheap generic levitra

    cialis for woman

    cheapest propecia in uk

    does generic cialis work

    generic propecia cheap

    cheap generic levitra

    buy cialis online canada

    canadian pharmacy discount code viagra

    bio viagra herbal

    cialis daily in canada

    cialis refractory

    buy cialis once daily

    indian generic levitra

    buy cialis on line

    mexico viagra

    for sale levitra

    buy cialis online canada

    mexico pharmacy cialis

    cialis 5 mg

    buy 5 mg cialis

    canadian pharmacy viagra

    chip cialis

    cialis vs levitra

    cheapest priced propecia

    cheap canadian viagra

    liquid propecia

    online viagra gel to buy

    buy mg propecia

    lowest cost propecia uk

    best price levitra

    levitra in india

    online generic cialis 100 mg

    buy generic levitra

    canada levitra

    cialis daily in canada

    cialis soft tabs

    canadian drugs propecia

    ordering viagra

    healthcare canadian pharmacy

    buy cialis online without prescription

    buy levitra with no prescription

    mail order levitra

    cialis strenght mg

    buy propecia without prescription

    cheap levitra uk

    buying generic propecia

    buy fast propecia

    generic cialis professional

    cialis arterial fibrillation

    levitra vs cialis

    brand viagra professional

    buying cialis without a prescription

    levitra online no prescription

    buy viagra online cheap us

    levitra low price

    cialis in canada

    generic form of propecia

    hydrochlorothiazide cialis

    levitra next day delivery

    buy pfizer viagra online

    generic viagra propecia

    buying cialis

    get cialis online

    cialis transdermal

    cialis discount

    one day cialis

    buy fast propecia

    buy propecia online cheap pharmacy

    generic cialis canadian

    discount levitra rx

    generic viagra made in usa

    buy levitra us

    how to get cialis

    canadian healthcare pharmacy

    discount viagra

    best levitra price

    cialis on women

    best price for generic cialis

    levitra vs cialis

    generic propecia viagra

    buy levitra in europe

    buy online prescription propecia

    buy generic propecia

    canada online pharmacy levitra

    bio viagra herbal

    online generic cialis 100 mg

    cheap levitra online

    cheapest propecia online

    buy cialis 5 mg

    next day viagra

    cialis no prescription

    low cost viagra

    cialis endurance

    herbal alternative to cialis

    buy cheap levitra online

    cialis samples in canada

    levitra without prescription

    best way to take cialis

    cialis for less 20 mg

    cialis medication

    cheap viagra no prescription

    cheap propecia uk

    generic levitra mexico

    canadian pharmacy discount code viagra

    natural viagra

    cheap propecia canada

    levitra discount

    brand cialis for sale

    buying cialis in canada

    cialis dosage

    combine cialis and levitra

    50 mg cialis

    cheapest viagra

    cialis low price

    how you get pfizer viagra

    low price levitra

    buy cialis online uk

    levitra now online

    cialis endurance

    buy xenical propecia

    overnight delivery viagra

    cost levitra

    order viagra or levitra

    buy online propecia

    cheapest cialis

    drug hair loss propecia

    cialis professional no prescription

    brand viagra professional

    buying real viagra without prescription

    brand viagra over the net

    cialis india

    indian viagra

    buy real viagra online without prescription

    get propecia cheap

    online order propecia

    cialis en mexico

    buy real viagra online

    cialis by mail

    discount drug propecia

    cialis dosagem

    buy cialis in usa

    cialis brand only

    best price for propecia

    discount us propecia

    cialis no rx

    cialis 30 mg

    non pescription cialis

    buy levitra overnight

    buy propecia prescriptions online

    cialis discounts

    buy propecia online

    cheap canadian viagra

    best prices for propecia

    levitra in uk

    index

    buy propecia in canada

    cheap canadian viagra

    cheap viagra canada or india

    cheap levitra without prescription

    online order viagra overnight delivery

    cheepest cialis

    cialis daily

    levitra tadalafil

    cheap viagra or cialis

    buy propecia and proscar

    cialis uk

    buy generic cialis

    cialis soft tablets

    buy cialis fedex shipping

    brand name cialis

    levitra online pharmacy

    levitra sale

    cialis canadian cost

    brand viagra professional

    canada viagra

    buying cialis online

    buying propecia

    levitra vs viagra

    cialisis in canada

    levitra lowest price

    online cheap viagra

    cialis and canada custom

    cialis brand only

    buy canada levitra

    buy levitra lowest prices

    buy levitra low price