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 FireStatslevitra online us

    online levitra

    discount levitra purchase

    canada cheap propecia

    cialis cost canada

    drug hair loss propecia

    cialis in mexico

    cialis 50 mg dose

    canadian generic cialis

    no prescription propecia

    cialis canadian cost

    cheapest prices on propecia

    canadian healthcare viagra sales

    brand viagra

    buy real viagra online without prescription

    buy cheap levitra

    buying online propecia

    indian cialis canada

    cialis from mexico

    order propecia prescriptions

    buy generic cialis

    how much does cialis cost

    discount levitra online us

    buy generic levitra online

    cheapest price propecia cheap

    buy cialis on line

    canadian viagra

    cheap propecia uk

    cialis generic 100 mg

    buy propecia where

    cialis women

    overnight delivery viagra

    canadian levitra

    cheap propecia canada

    bestellen levitra online

    how much is viagra

    buy cheap propecia

    cheepest cialis

    cheap propecia online prescription

    cheap viagra canada or india

    buy propecia uk

    buy online propecia

    cheap canadian viagra

    buy cheap levitra

    cialis daily availability

    internet pharmacy propecia

    china viagra

    order levitra

    5mg propecia

    online generic cialis 100 mg

    best price levitra online

    online prescription propecia

    buy levitra lowest prices

    cheapest prices on viagra

    buy propecia on line

    cialis express delivery

    buy propecia generic

    canadian propecia rx

    cheapest propecia pharmacy online

    canadian healthcare pharmacy

    5 mg cialis

    buy viagra on line

    buying cialis online

    buy canada levitra

    cheapest price propecia cheap

    levitra sales uk

    canadian pharmacy viagra legal

    next day viagra

    cialis low price

    buy cialis online canada

    cheap viagra canada or india

    levitra without prescriptions

    cialis prescription

    buy online prescription propecia

    generic cialis soft tabs

    levitra cheap canadian pharmacy

    drug propecia

    levitra viagra online

    buy propecia now

    is pfizer viagra available in india

    canada generic propecia

    cialis discounts

    buy levitra lowest prices

    buy cheap generic levitra

    buy drug propecia

    cheap viagra from uk

    order cheapest propecia online

    cheap viagra on line

    canadian drugs propecia

    best deal for propecia

    discount cialis

    cheapest online propecia

    buy cialis cannada

    canada online pharmacy propecia

    generic propecia cheap

    cialis germany

    buying viagra

    levitra online

    cialis from mexico

    levitra from canada

    cialis 5 mg

    online ordering propecia

    levitra in uk

    bestellen levitra

    canadian drug viagra soft

    online levitra us

    levitra low price

    buy propecia without prescription

    best propecia prices

    generic cialis in india

    canadian generic cialis

    canada viagra generic

    buy viagra in canada no prescription

    cialis kanada

    generic levitra vardenafil

    cialis at real low prices

    cialis price

    buy propecia and proscar

    discount propecia propecia

    cialis 5 mg italia

    buy propecia in canada

    buy propecia online from usa pharmacy

    levitra price

    buy viagra online

    cialis germany

    buying viagra with no prescription

    cialis and ketoconazole

    buy fast propecia

    buy propecia pills

    buy branded viagra online

    cialis alternitives

    buy 5 mg cialis

    levitra online pharmacy

    cialis fast delivery usa

    levitra sex pill

    cost levitra low

    cheap cialis from india

    cialis okay for women

    cialis 20 mg

    buy cialis usa

    generic levitra cheap

    buy prescription propecia

    generic propecia 5mg

    cialis dosagem

    buy daily cialis

    generic cialis canadian

    buy propecia online

    canadian healthcare viagra

    buying cialis online

    best price generic propecia

    indian cialis

    buy online prescription propecia

    cialis refractory

    buy propecia in the uk

    canadian viagra and healthcare

    cheapest propecia sale uk

    order propecia propecia

    cheapest propecia in uk

    buy viagra in canada

    cialis daily in canada

    cheap price propecia

    cialis delivered overnight

    cialis 50 mg

    ordering propecia

    cialis daily

    buy prescription propecia

    cialis daily dosing cost

    buy branded viagra

    cialis dosage

    cheap price propecia

    cheap cialis soft

    generic levitra india

    cialis from canada

    generic levitra online

    buy propecia without a prescription

    order cheap levitra

    buy branded viagra

    buying real viagra without prescription

    canadian propecia cheap

    best price propecia

    levitra vs viagra

    cheapest cialis

    cialis buy overnight

    cialis soft tabs

    cialis iop

    cialis next day delivery

    buy vardenafil levitra

    buy levitra american pharmacy

    cialis on line

    buying propecia

    buy generic viagra india rx

    buy propecia cheap

    canadian drug viagra soft

    buy cialis canada

    ordering propecia online

    levitra in mexico

    buying cialis without a prescription

    buy pfizer viagra online

    bying viagra online cheap us

    cheap levitra uk

    buying generic propecia

    cheap viagra

    buying cialis

    best price on propecia

    buy generic propecia online

    buy dosages levitra

    levitra 10mg

    canadian viagra generic

    cialis from india

    levitra discount

    cialis canada online pharmacy

    levitra 10 mg

    how does viagra work

    buy real viagra online

    buy now propecia

    buy levitra vardenafil

    buy discount viagra

    canadian healthcare pharmacy

    buy now propecia

    online pharmacy propecia renova

    best price cialis

    cheapest propecia online

    levitra canadian pharmacy

    cialis alternitives

    cialis iop

    buy cheapest cialis

    cheap propecia order online

    buy generic propecia

    buying viagra

    canada online pharmacy levitra

    cheap viagra on line

    canadian viagra generic

    generic propecia sale

    best online generic levitra

    best online levitra

    about cialis

    cialis 100 mg generic

    buying generic propecia

    how can i get some cialis

    cialis generic

    cialis discount

    buy viagra pills

    buy cheap online propecia

    buy viagra pills

    cheap viagra online

    original brand cialis

    cheap prescription propecia

    buy levitra low price

    cialis buy overnight

    indian generic levitra