<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Sebastian Baltes</title>
    <description>The latest articles on DEV Community by Sebastian Baltes (@s_baltes).</description>
    <link>https://dev.to/s_baltes</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F33082%2F505bf132-4148-4e79-b9e6-20b29d780ede.jpg</url>
      <title>DEV Community: Sebastian Baltes</title>
      <link>https://dev.to/s_baltes</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/s_baltes"/>
    <language>en</language>
    <item>
      <title>Software Development Expertise</title>
      <dc:creator>Sebastian Baltes</dc:creator>
      <pubDate>Mon, 08 Oct 2018 16:31:55 +0000</pubDate>
      <link>https://dev.to/s_baltes/software-development-expertise-4ffj</link>
      <guid>https://dev.to/s_baltes/software-development-expertise-4ffj</guid>
      <description>&lt;p&gt;
    &lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/http%3A%2F%2Fempirical-software.engineering%2Fassets%2Fimages%2Fdeveloper.png" class="article-body-image-wrapper"&gt;&lt;img alt="Logo Snippets" src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/http%3A%2F%2Fempirical-software.engineering%2Fassets%2Fimages%2Fdeveloper.png"&gt;&lt;/a&gt;
&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;TL;DR:&lt;/strong&gt; &lt;em&gt;Being an expert in software development requires a certain set of skills, knowledge, and experience. We present a first conceptual theory of software development expertise that is grounded in data from a mixed-methods survey with 335 software developers and in literature on expertise and expert performance. The theory describes central properties of software development expertise and which factors foster or hinder its formation, including how developers’ performance may decline over time. Moreover, our quantitative results show that developers' expertise self-assessments are context-dependent and that experience is not necessarily related to expertise.&lt;/em&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Source:&lt;/strong&gt; This &lt;a href="http://empirical-software.engineering/blog/expertise/" rel="noopener noreferrer"&gt;post&lt;/a&gt; on my personal blog. &lt;/p&gt;

&lt;h2&gt;
  
  
  Motivation
&lt;/h2&gt;

&lt;p&gt;An &lt;em&gt;expert&lt;/em&gt; is, according to Merriam-Webster, someone "having, involving, or displaying special skill or knowledge derived from training or experience". For some areas, such as playing chess, there exist representative tasks and objective criteria for identifying experts. In software development, however, it is more difficult to find objective measures for quantifying expert performance. One reason is that software development itself includes diverse tasks such as implementing new features, analyzing requirements, and fixing bugs. In the past, researchers investigated certain aspects of software development expertise such as the influence of programming experience, desired attributes of software engineers, or the time it takes for developers to become "fluent" in software projects. However, there is currently no theory combining those individual aspects. Such a theory could help structuring existing knowledge about software development expertise in a concise and precise way and hence facilitate its communication. With our &lt;a href="http://empirical-software.engineering/publications#fse18-expertise" rel="noopener noreferrer"&gt;paper&lt;/a&gt;, we contribute a first theory that describes &lt;em&gt;central properties&lt;/em&gt; of software development expertise and &lt;em&gt;important factors&lt;/em&gt; influencing its &lt;em&gt;formation&lt;/em&gt;. The theory focuses on individual software developers working on different software development tasks, having the long-term goal of becoming experts in those tasks. It is grounded in data from a mixed-methods survey with 335 participants and in literature on expertise and expert performance. Our expertise model is task-specific and currently focuses on programming-related tasks, but includes the notion of transferable knowledge and experience from related fields or tasks. Our &lt;em&gt;process theory&lt;/em&gt; is a first step towards the long-term goal to build a &lt;em&gt;variance theory&lt;/em&gt; to be able explain and predict why and when a software developer reaches a certain level of expertise.&lt;/p&gt;

&lt;h2&gt;
  
  
  Conceptual Theory
&lt;/h2&gt;

&lt;p&gt;In this blog post, we skip the details of our research design and focus on the resulting conceptual theory, summarzing implications for researchers, developers, and employers.&lt;/p&gt;

&lt;p&gt;
    &lt;a href="/assets/images/conceptual-theory-2.png"&gt;&lt;img alt="Conceptual Theory" src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/http%3A%2F%2Fempirical-software.engineering%2Fassets%2Fimages%2Fconceptual-theory-2.png"&gt;&lt;/a&gt;
    &lt;br&gt;
&lt;/p&gt;

&lt;p&gt;The above figure visualizes the high-level concepts of our conceptual theory together with their relationships. Some relationships are intentionally labeled with rather generic terms such as "affects" or "generates", because more research is needed to investigate them. The theory describes the &lt;em&gt;process&lt;/em&gt; of software development expertise formation, that is the path of an individual software development novice towards becoming an expert. This path &lt;a href="https://www.cambridge.org/core/books/the-cambridge-handbook-of-expertise-and-expert-performance/the-influence-of-experience-and-deliberate-practice-on-the-development-of-superior-expert-performance/C56EDDE9E57B259825916E061B025A72" rel="noopener noreferrer"&gt;consists&lt;/a&gt; of gradual improvements with many corrections and repetitions, therefore we do not describe discrete steps like, for example, the 5-stage Dreyfus model of skill acquisition (see Section "Experience vs. Expertise"). Instead, we focus on the repetition of individual tasks. In the following, we will describe the core of our theory (gray background in the figure). In particular, we will elaborate on the role of &lt;em&gt;monitoring&lt;/em&gt;, &lt;em&gt;feedback&lt;/em&gt;, and &lt;em&gt;self-reflection&lt;/em&gt;, and connect the corresponding feedback cycle with the concept of &lt;em&gt;deliberate practice&lt;/em&gt;. All concepts and relationships of our theory are described in more detail in the &lt;a href="http://empirical-software.engineering/publications#fse18-expertise" rel="noopener noreferrer"&gt;paper&lt;/a&gt;.&lt;/p&gt;

&lt;h3&gt;
  
  
  Knowledge and Experience
&lt;/h3&gt;

&lt;p&gt;&lt;em&gt;Knowledge&lt;/em&gt; can be &lt;a href="https://dl.acm.org/citation.cfm?id=291476" rel="noopener noreferrer"&gt;defined&lt;/a&gt; as a "permanent structure of information stored in memory". Some &lt;a href="https://dl.acm.org/citation.cfm?id=801956" rel="noopener noreferrer"&gt;researchers&lt;/a&gt; consider a developer's knowledge base as the most important aspect affecting their &lt;em&gt;performance&lt;/em&gt;. &lt;a href="https://www.cambridge.org/core/books/the-cambridge-handbook-of-expertise-and-expert-performance/expertise-in-software-design/04E88E182D83E956AB5582CA846AFF73" rel="noopener noreferrer"&gt;Studies&lt;/a&gt; with software developers suggest that "the knowledge base of experts is highly language dependent", but experts also have "abstract, transferable knowledge and skills". We modeled this aspect in our theory by dividing the central concepts &lt;em&gt;knowledge&lt;/em&gt; and &lt;em&gt;experience&lt;/em&gt;, which we derived from a first iteration of our online survey and from related work, into a task-specific and a general part. This is a simplification of our model, because the relevance of knowledge and experience is rather a &lt;a href="https://www.cambridge.org/core/books/cambridge-handbook-of-expertise-and-expert-performance/modes-of-expertise-in-creative-thinking-evidence-from-case-studies/911934EDB1E0479E536A46E646420DE6" rel="noopener noreferrer"&gt;continuum&lt;/a&gt; than dichotomous states. However, &lt;a href="https://www.cs.umd.edu/~ben/papers/Shneiderman1979Syntactica.pdf" rel="noopener noreferrer"&gt;Shneiderman and Mayer&lt;/a&gt;, who developed a behavioral model of software development, used a similar differentiation between general ("semantic") and specific ("syntactical") knowledge. General knowledge and experience does not only refer to technical aspects (e.g., low-level computer architecture) or general concepts (e.g., design patterns), but also to knowledge about and experience with successful strategies.&lt;/p&gt;

&lt;p&gt;Many participants  referred to the importance of the &lt;em&gt;quantity&lt;/em&gt; of software development &lt;em&gt;experience&lt;/em&gt; (e.g., in terms of years), but some also described its &lt;em&gt;quality&lt;/em&gt;. Examples for the latter include having built "everything from small projects to enterprise projects" or "[experience] with many codebases." In particular, participants considered &lt;em&gt;professional experience&lt;/em&gt;, for example having "shipped a significant amount of code to production or to a customer", and working on &lt;em&gt;shared code&lt;/em&gt; to be important factors. Examples for general knowledge include "paradigms [...], data structures, algorithms, computational complexity, and design patterns"—task- or language-specific expertise includes having an "intimate knowledge of the design and philosophy of the language'' and knowing "the shortcomings of the language [...] or the implementation [...]." &lt;/p&gt;

&lt;h3&gt;
  
  
  Tasks
&lt;/h3&gt;

&lt;p&gt;Since our model of software development expertise is task-specific, we asked our participants to name the three most important tasks that a software development expert should be good at. The three most frequently mentioned tasks were &lt;em&gt;designing software architecture&lt;/em&gt;, &lt;em&gt;writing source code&lt;/em&gt;, and &lt;em&gt;analyzing and understanding requirements&lt;/em&gt;. Many participants not only mentioned the tasks, but also certain quality attributes associated with them, for example&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;"architecting the software in a way that allows flexibility in project requirements and future applications of the components"&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;and "writing clean, correct, and understandable code". Other mentioned tasks include &lt;em&gt;testing&lt;/em&gt;, &lt;em&gt;communicating&lt;/em&gt;, &lt;em&gt;staying up-to-date&lt;/em&gt;, and &lt;em&gt;debugging&lt;/em&gt;. Our theory currently focuses on tasks directly related to programming, but our participants' responses show that it is important to broaden this view in the future to include, for example, tasks related to requirements engineering (&lt;em&gt;analyzing and understanding requirements&lt;/em&gt;) or the adaption of new technologies (&lt;em&gt;staying up-to-date&lt;/em&gt;).&lt;/p&gt;

&lt;h3&gt;
  
  
  Motivation
&lt;/h3&gt;

&lt;p&gt;Related work describes certain &lt;em&gt;individual differences&lt;/em&gt; that affect if and how people come closer to their goal of being an expert in a certain domain.&lt;br&gt;
The &lt;em&gt;mental abilities&lt;/em&gt; and &lt;em&gt;personality&lt;/em&gt; are quite stable, but especially the &lt;em&gt;motivation&lt;/em&gt; can change over time and influence the way people approach software development. Many of the participants in our study were intrinsically motivated, stating that &lt;em&gt;problem solving&lt;/em&gt; is their main motivation. One participant wrote that solving problems "makes [him] feel clever, and powerful." Another participant compared problem solving to climbing a mountain:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;"I would equate that feeling [of getting a feature to work correctly after hours and hours of effort] to the feeling a mountain climber gets once they reach the summit of Everest."&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Many developers enjoy seeing the &lt;em&gt;result&lt;/em&gt; of their work. They are particularly satisfied to see a solution which they consider to be of high &lt;em&gt;quality&lt;/em&gt;. One participant wrote that (s)he gets "a feeling of satisfaction from creating an elegant piece of code." Moreover, some participants mentioned refactoring as a rewarding task:  &lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;"The initial design is fun, but what really is more rewarding is refactoring."&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Others stressed the importance of &lt;em&gt;creating something new&lt;/em&gt; or &lt;em&gt;helping others&lt;/em&gt;. Interestingly, &lt;em&gt;money&lt;/em&gt; was only mentioned by few participants as a motivation for their work.&lt;/p&gt;

&lt;h3&gt;
  
  
  Performance
&lt;/h3&gt;

&lt;p&gt;At this point, our goal is not to treat &lt;em&gt;performance&lt;/em&gt; as a dependent variable that we try to explain for individual tasks, we rather consider different &lt;em&gt;performance monitoring&lt;/em&gt; approaches to be a means for &lt;em&gt;feedback&lt;/em&gt; and &lt;em&gt;self-reflection&lt;/em&gt; (see below). For our long-term goal to build a &lt;em&gt;variance theory&lt;/em&gt; for explaining and predicting the development of expertise, it will be more important to be able to accurately measure developers' performance. However, participants' mentioned different properties that source code of experts should possess: It should be &lt;em&gt;well-structured&lt;/em&gt; and &lt;em&gt;readable&lt;/em&gt;, contain "comments when necessary", be "optimized" in terms of "performance" and sustainable in terms of &lt;em&gt;maintainability&lt;/em&gt;. One participant summarized the code that experts write as follows:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;"Everyone can write [...] code which a machine can read and process but the key lies in writing concise and understandable code which [...] people who have never used that piece of code before [can read]."&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;To identify factors hindering expertise development, we asked participants whether they ever observed a significant decline of their own programming performance or the performance of co-workers over time. In our study, &lt;strong&gt;41.5% of the participants who answered that question actually observed a performance decline over time&lt;/strong&gt;. We asked those participants to describe how the decline manifested itself and to suggest possible reasons. The main reasons for performance decline were related &lt;em&gt;demotivation&lt;/em&gt;, changes in the &lt;em&gt;work environment&lt;/em&gt;, &lt;em&gt;age-related decline&lt;/em&gt;, &lt;em&gt;changes in attitude&lt;/em&gt;, and &lt;em&gt;shifting towards other tasks&lt;/em&gt;. Related to &lt;em&gt;problem solving&lt;/em&gt; being one of the main &lt;em&gt;motivations&lt;/em&gt; (see above), the most common reason for &lt;em&gt;demotivation&lt;/em&gt; was &lt;em&gt;non-challenging work&lt;/em&gt;, often caused by tasks becoming routine over time. One participant described this effect as follows:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;"I perceived an increasing procrastination in me and in my colleagues, by working on the same tasks over a relatively long time (let's say, 6 months or more) without innovation and environment changes."&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Other reasons included not seeing a clear &lt;em&gt;vision or direction&lt;/em&gt; in which the project is or should be going and missing &lt;em&gt;reward&lt;/em&gt; for high-quality work, which was described above as one of the main factors motivating developers. Regarding the &lt;em&gt;work environment&lt;/em&gt;, participants named &lt;em&gt;stress&lt;/em&gt; due to tight deadlines or economic pressure ("the company's economic condition deteriorated''). Moreover, bad &lt;em&gt;management&lt;/em&gt; or &lt;em&gt;team structure&lt;/em&gt; were named, for example:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;"[h]aving a supervisor/architect who is very poor at communicating his design goals and ideas, and refuses to accept that this is the case, even when forcibly reminded.''.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;&lt;em&gt;Changes in attitude&lt;/em&gt; may happen due to personal issues (e.g., getting divorced) or due to shifting priorities (e.g., friends and family getting more important). When developers are being promoted to team leader or manager, they "shift towards other tasks", resulting in a declining programming performance. &lt;/p&gt;

&lt;p&gt;Participants also described &lt;em&gt;age-related performance decline&lt;/em&gt;. We consider this phenomenon, and the resulting consequences for individual developers and the organization, to be an important area for future research. To illustrate the effects that age-related decline may have, we provide two verbatim quotes by experienced developers:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;"For myself, it's mostly the effects of aging on the brain. At age 66, I &lt;strong&gt;can't hold as much information short-term memory&lt;/strong&gt;, for example. In general, I am more forgetful. I can compensate for a lot of that by writing simpler functions with clean interfaces. The results are still good, but my productivity is much slower than when I was younger." (software architect, age 66)&lt;/p&gt;

&lt;p&gt;"Programming ability is based on desire to achieve. In the early years, it is a sort of &lt;strong&gt;competition&lt;/strong&gt;. As you age, you begin to realize that outdoing your peers isn't all that rewarding. [...] I found that I lost a significant amount of my focus as I became 40, and started &lt;strong&gt;using drugs such as ritalin&lt;/strong&gt; to enhance my abilities. This is pretty common among older programmers.'' (software developer, age 60)&lt;/p&gt;
&lt;/blockquote&gt;

&lt;h3&gt;
  
  
  Task Context
&lt;/h3&gt;

&lt;p&gt;The &lt;em&gt;task&lt;/em&gt; or &lt;em&gt;work context&lt;/em&gt; can either foster or hinder developers on their way to becoming an expert in certain software development tasks. To investigate its influence on expertise development, we asked what employers should do in order to facilitate a continuous development of their employees' software development skills. We grouped the responses into four main categories: &lt;em&gt;encourage learning&lt;/em&gt;, &lt;em&gt;encourage experimentation&lt;/em&gt;, &lt;em&gt;improve information exchange&lt;/em&gt;, and &lt;em&gt;grant freedom&lt;/em&gt;. To &lt;em&gt;encourage learning&lt;/em&gt;, employers may offer in-house or pay for external &lt;em&gt;training courses&lt;/em&gt;, pay employees to visit &lt;em&gt;conferences&lt;/em&gt;, provide a good analog and/or digital &lt;em&gt;library&lt;/em&gt;, and offer &lt;em&gt;monetary incentives&lt;/em&gt; for self-improvement. The most frequently named means to &lt;em&gt;encourage experimentation&lt;/em&gt; were motivating employees to pursue &lt;em&gt;side projects&lt;/em&gt; and building a work environment that is open for &lt;em&gt;new ideas and technologies&lt;/em&gt;. To &lt;em&gt;improve information exchange&lt;/em&gt; between development teams, between different departments, or even between different companies, participants proposed to &lt;em&gt;facilitate meetings&lt;/em&gt; such as agile retrospectives, "Self-improvement Fridays", "lunch-and-learn sessions", or "Technical Thursday" meetings. Such meetings could explicitly target information exchange or skill development. Beside dedicated meetings, the idea of developers &lt;em&gt;rotating&lt;/em&gt; between teams, projects, departments, or even companies is considered to foster expertise development. To improve the information flow between developers, practices such as &lt;em&gt;mentoring&lt;/em&gt; or &lt;em&gt;code reviews&lt;/em&gt; were mentioned. Finally, &lt;em&gt;granting freedom&lt;/em&gt;, primarily in form of &lt;em&gt;less time-pressure&lt;/em&gt;, would allow developers to invest in learning new technologies or skills.&lt;/p&gt;

&lt;h3&gt;
  
  
  Deliberate Practice
&lt;/h3&gt;

&lt;p&gt;Having more experience with a task does &lt;a href="http://projects.ict.usc.edu/itw/gel/EricssonDeliberatePracticePR93.PDF" rel="noopener noreferrer"&gt;not automatically lead&lt;/a&gt; to better performance. Research has shown that once an acceptable level of performance has been attained, additional "common" experience has only a negligible effect, in many domains the performance even &lt;a href="https://www.cambridge.org/core/books/cambridge-handbook-of-expertise-and-expert-performance/studies-of-expertise-from-psychological-perspectives/3A7FF4C6F3426BE751C71EDF84927741" rel="noopener noreferrer"&gt;decreases&lt;/a&gt; over time. The length of experience has been found to be only a &lt;a href="https://www.cambridge.org/core/books/cambridge-handbook-of-expertise-and-expert-performance/influence-of-experience-and-deliberate-practice-on-the-development-of-superior-expert-performance/C56EDDE9E57B259825916E061B025A72" rel="noopener noreferrer"&gt;weak correlate&lt;/a&gt; of job performance after the first two years—what matters is the &lt;em&gt;quality&lt;/em&gt; of the experience. According to &lt;a href="http://projects.ict.usc.edu/itw/gel/EricssonDeliberatePracticePR93.PDF" rel="noopener noreferrer"&gt;Ericsson et al.&lt;/a&gt;, expert performance can be explained with "prolonged efforts to improve performance while negotiating motivational and external constraints". For them, &lt;em&gt;deliberate practice&lt;/em&gt;, meaning activities and experiences that are targeted at improving the own performance, are needed to become an expert. Traditionally, research on deliberate practice concentrated on acquired knowledge and experience to explain expert performance. However, later studies have shown that deliberate practice is necessary, but &lt;a href="http://journals.sagepub.com/doi/abs/10.1177/0963721411421922" rel="noopener noreferrer"&gt;not sufficient&lt;/a&gt;, to achieve high levels of expert performance—individual differences play an &lt;a href="http://journals.sagepub.com/doi/abs/10.1177/0963721411422061" rel="noopener noreferrer"&gt;important role&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;A central aspect of &lt;em&gt;deliberate practice&lt;/em&gt; is &lt;a href="https://www.cambridge.org/core/books/the-cambridge-handbook-of-expertise-and-expert-performance/the-influence-of-experience-and-deliberate-practice-on-the-development-of-superior-expert-performance/C56EDDE9E57B259825916E061B025A72" rel="noopener noreferrer"&gt;monitoring&lt;/a&gt; one's own &lt;em&gt;performance&lt;/em&gt;, and getting &lt;em&gt;feedback&lt;/em&gt;, for example from a teacher or coach. Generally, such feedback helps individuals to &lt;em&gt;monitor&lt;/em&gt; their progress towards &lt;a href="http://psycnet.apa.org/record/1990-97846-000" rel="noopener noreferrer"&gt;goal achievement&lt;/a&gt;. Moreover, as &lt;a href="https://www.taylorfrancis.com/books/e/9781134508242/chapters/10.4324%2F9780203634394-18" rel="noopener noreferrer"&gt;Tourish and Hargie&lt;/a&gt; note:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;"[T]he more channels of accurate and helpful feedback we have access to, the better we are likely to perform."&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;In areas like chess or physics, studies have &lt;a href="https://www.cambridge.org/core/books/cambridge-handbook-of-expertise-and-expert-performance/two-approaches-to-the-study-of-experts-characteristics/823FCCA5B7E6E0FEDB5A51C042C831C2" rel="noopener noreferrer"&gt;shown&lt;/a&gt; that experts have more accurate self-monitoring skills than novices. In our model, the feedback relation is connected to the concept &lt;em&gt;task context&lt;/em&gt; as we assumed that feedback for a software developer most likely comes from co-workers or supervisors. Moreover, &lt;em&gt;mentoring&lt;/em&gt; provides feedback and was identified in our study as an important source for &lt;em&gt;motivation&lt;/em&gt;. To close the cycle, also (self-) &lt;em&gt;monitoring&lt;/em&gt; and &lt;em&gt;reflection&lt;/em&gt; influence developers &lt;em&gt;motivation&lt;/em&gt; and consequently their &lt;em&gt;behavior&lt;/em&gt;.&lt;/p&gt;

&lt;h3&gt;
  
  
  Monitoring and Self-reflection
&lt;/h3&gt;

&lt;p&gt;In our survey, we asked participants whether they regularly monitor their software development activities. &lt;strong&gt;38.7% of the 204 participants who answered that question said that they regularly monitor their software development activity&lt;/strong&gt;. The most important monitoring activity was &lt;em&gt;peer review&lt;/em&gt;, where participants mentioned asking co-workers for feedback, doing code-review, or doing pair-programming. One participant mentioned that he tries to "take note of how often [he] win[s] technical arguments with [his] peers." Participants also mentioned &lt;em&gt;time tracking&lt;/em&gt; tools like WakaTime or RescueTime, &lt;em&gt;issue tracking&lt;/em&gt; systems like Jira or GitHub issues, and &lt;em&gt;project management&lt;/em&gt; tools like &lt;em&gt;Redmine&lt;/em&gt; and &lt;em&gt;Scrum story points&lt;/em&gt; as sources for feedback, comparing expected to actual results (e.g., time goals or number of features to implement). Moreover, some developers mentioned writing a &lt;a href="https://news.ycombinator.com/item?id=14382965" rel="noopener noreferrer"&gt;&lt;em&gt;development diary&lt;/em&gt;&lt;/a&gt;. Participants reported using simple metrics such as the &lt;em&gt;commit frequency&lt;/em&gt;, &lt;em&gt;lines of code added/deleted&lt;/em&gt;, or the number of &lt;em&gt;issues resolved&lt;/em&gt;. Further, they reported to use &lt;em&gt;static analysis&lt;/em&gt; tools such as SonarQube, FindBugs, and Checkstyle, or to use GitHub's activity overview. Some participants were doubtful regarding the usefulness of metrics, one participant noted:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;"I do not think that measuring commits [or] LOC [...] automatically is a good idea to rate performance. It will raise competition, yes—but not the one an employer would like. It will just get people to optimize whatever is measured.''&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;The described phenomenon is also known as &lt;a href="https://en.wikipedia.org/wiki/Goodhart%27s_law" rel="noopener noreferrer"&gt;&lt;em&gt;Goodhart's law&lt;/em&gt;&lt;/a&gt;.&lt;/p&gt;

&lt;h3&gt;
  
  
  Experience vs. Expertise
&lt;/h3&gt;

&lt;p&gt;Since software developers' expertise is difficult to measure, researchers often rely on proxies for this abstract concept. We investigated the relationship and validity of the two proxies &lt;em&gt;length of experience&lt;/em&gt; and &lt;em&gt;self-assessed expertise&lt;/em&gt; to provide guidance for researchers. We found that neither developers' experience measured in years nor the self-assessed programming expertise ratings yielded consistent results across all analyzed settings. We were also interested in the validity of self-assessed expertise, which is, like other self-reports, &lt;a href="https://dornsife.usc.edu/assets/sites/780/docs/01_aje_schw_oys_behavior.pdf" rel="noopener noreferrer"&gt;context-dependent&lt;/a&gt;. The validity of self-assessed expertise is related to the concept of &lt;em&gt;self-reflection&lt;/em&gt;, but has also methodological implications for software engineering research in general, because self-assessed programming expertise is often used in studies with software developers to differentiate between novices and experts. To analyze the influence of question context on expertise self-assessments, we asked participants for two self-assessments of their Java expertise: One using a semantic differential scale from novice to expert (without further context) and one based on the &lt;a href="https://en.wikipedia.org/wiki/Dreyfus_model_of_skill_acquisition" rel="noopener noreferrer"&gt;Dreyfus model&lt;/a&gt; of skill acquisition (with context for each stage). We found that only the experienced developers tended to adjust their self-assessments to a higher rating after we provided context in form of the Dreyfus model. A possible interpretation of this result could be found in the &lt;a href="https://en.wikipedia.org/wiki/Dunning%E2%80%93Kruger_effect" rel="noopener noreferrer"&gt;&lt;em&gt;Dunning-Kruger effect&lt;/em&gt;&lt;/a&gt;: &lt;a href="http://psycnet.apa.org/buy/1999-15054-002" rel="noopener noreferrer"&gt;Kruger and Dunning&lt;/a&gt; found that participants with a high skill-level underestimate their ability and performance relative to their peers. This may have happened in our sample with experienced developers when they assessed their Java expertise using the semantic differential scale. When we provided context in form of the Dreyfus model, they adjusted their ratings to a more adequate rating, whereas the less experienced developers stuck to their, possibly overestimated, ratings.&lt;/p&gt;

&lt;h2&gt;
  
  
  Conclusion
&lt;/h2&gt;

&lt;p&gt;In this blog post, we presented  core concepts of our conceptual theory of software development expertise, which is grounded in data from an online survey with 355 software developers and in existing literature on expertise and expert performance. We described different properties of software development expertise and factors fostering or hindering its development. In particular, we described developers' &lt;em&gt;motivation&lt;/em&gt; and &lt;em&gt;performance decline&lt;/em&gt; and how the &lt;em&gt;task context&lt;/em&gt; and &lt;em&gt;deliberate practice&lt;/em&gt; can foster expertise development.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Researchers&lt;/strong&gt; can use our methodological findings about (self-assessed) expertise and experience when designing studies involving self-assessments. If researchers have a clear understanding what distinguishes novices and experts in their study setting, they should provide this context when asking for self-assessed expertise and later report it together with their results. In our theory, we did not describe expertise development in discrete steps, but a direction for future work could be to at least develop a standardized description of &lt;em&gt;novice&lt;/em&gt; and &lt;em&gt;expert&lt;/em&gt; for certain tasks, which could then be used in semantic differential scales. To design concrete experiments measuring certain aspects of software development expertise, one needs to &lt;a href="https://ieeexplore.ieee.org/document/4052585" rel="noopener noreferrer"&gt;operationalize&lt;/a&gt; our conceptual theory. In our &lt;a href="http://empirical-software.engineering/publications#fse18-expertise" rel="noopener noreferrer"&gt;paper&lt;/a&gt;, we already linked concepts to existing measurement instruments such as &lt;em&gt;UMS&lt;/em&gt; (motivation), &lt;em&gt;WAIS-IV&lt;/em&gt; (mental abilities), or &lt;em&gt;IPIP&lt;/em&gt; (personality) and also mentioned static analysis tools to measure code quality and basic productivity measures. This enables researchers to design experiments, but also to re-evaluate results from previous experiments. There are, for example, no coherent results about the connection of individual differences and programming performance yet.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Software developers&lt;/strong&gt; can use our results to see which properties are distinctive for experts in their field, and which behaviors may lead to becoming a better software developer. For example, the concept of &lt;em&gt;deliberate practice&lt;/em&gt;, and in particular having &lt;em&gt;challenging goals&lt;/em&gt;, a &lt;em&gt;supportive work environment&lt;/em&gt;, and getting &lt;em&gt;feedback from peers&lt;/em&gt; are important factors. Beside peer-feedback, developers can use different code quality and productivity measures and tools to monitor their &lt;em&gt;performance&lt;/em&gt; and &lt;em&gt;reflect&lt;/em&gt; about their progress in becoming better software developers. As outlined above, phenomena like the &lt;em&gt;Dunning-Kruger effect&lt;/em&gt; may affect developers' ability to &lt;em&gt;self-reflect&lt;/em&gt;. However, by establishing a combination of metrics, tools, peer-review, and mentoring, developers can try to mitigate such biases. The &lt;em&gt;task context&lt;/em&gt; is a factor that can heavily influence the ability of developers to improve their software development skills, but is often out of their control. Once developers are in a team lead or management role, they can try to establish some of our participants' suggestions to build a supportive work environment (see below).&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Employers&lt;/strong&gt; can use our results to learn what typical reasons for &lt;em&gt;demotivation&lt;/em&gt; among their employees are, and how they can build a &lt;em&gt;work environment&lt;/em&gt; supporting the self-improvement of their staff. They should be aware that &lt;em&gt;problem solving&lt;/em&gt; is one of the main motivations for software developers, leading to the main factor for demotivation, which is &lt;em&gt;non-challenging work&lt;/em&gt;. To avoid tasks becoming routine over time and thus being perceived as non-challenging, employers should make sure to have a good mix of continuity and change in their software development process.&lt;br&gt;
They should also communicate clear &lt;em&gt;visions, directions, and goals&lt;/em&gt; and &lt;em&gt;reward&lt;/em&gt; high-quality work wherever possible. Beside obvious strategies for expertise development such as offering training sessions or paying for conference visits, our results suggest that employers should think carefully about how &lt;em&gt;information is shared&lt;/em&gt; between their developers and also between the development team and other departments of the company. Facilitating meetings that explicitly target information exchange and learning new skills should be a priority of every company that cares about the development of their employees.&lt;/p&gt;

&lt;h2&gt;
  
  
  More Information
&lt;/h2&gt;

&lt;p&gt;A more detailed description of our research design and results can be found in our &lt;a href="http://empirical-software.engineering/publications#fse18-expertise" rel="noopener noreferrer"&gt;research paper&lt;/a&gt;. If you have any further questions, do not hesitate to contact me.&lt;/p&gt;

</description>
      <category>expertise</category>
      <category>theory</category>
      <category>productivity</category>
      <category>research</category>
    </item>
  </channel>
</rss>
