Cowboy coding

Cowboy coding

Cowboy coding is a term used to describe software development where programmers have autonomy over the development process. This includes control of the project's schedule, languages, algorithms, tools, frameworks and coding style.

A cowboy coder can be a lone developer or part of a group of developers working with minimal process or discipline[citation needed]. Usually it occurs when there is little participation by business users, or fanned by management that controls only non-development aspects of the project, such as the broad targets, timelines, scope, and visuals (the "what", but not the "how")[citation needed].

Cowboy coding typically has more negative connotations, depending on one's opinions on the role of management and formal process in software development; "cowboy coding" is often used as a derogatory term by supporters of software development methodologies, such as Agile. However, the term has been reclaimed to some extent by those practicing within the community[citation needed].

Contents

Disadvantages of cowboy coding

In cowboy coding, the lack of formal software project management methodologies may be indicative (though not necessarily) of a project's small size or experimental nature[1]. Software projects with these attributes may exhibit:

Lack of release structure

Lack of estimation or implementation planning may cause a project to be delayed. Sudden deadlines or pushes to release software may encourage the use of quick and dirty or code and fix techniques that will require further attention later.

Inexperienced developers

Cowboy coding can be common at the hobbyist or student level where developers may initially be unfamiliar with the technologies, such as testing, version control and/or build tool, usually more than just the basic coding a software project requires.

This can result in time required for learning to be underestimated, causing delays in the development process. Inexperience may also lead to disregard of accepted standards, making the project source difficult to read or causing conflicts between the semantics of the language constructs and the result of their output.

Uncertain design requirements

Custom software applications, even when using a proven development cycle, can experience problems with the client concerning requirements. Cowboy coding can accentuate this problem by not scaling the requirements to a reasonable timeline, and may result in unused or unusable components being created before the project is finished. Similarly, projects with less tangible clients (often experimental projects, see independent game development) may begin with code and never a formal analysis of the design requirements. Lack of design analysis may lead to incorrect or insufficient technology choices, possibly requiring the developer to port or rewrite their software in order for the project to be completed.

Incompleteness

Many software development models, such as Extreme Programming, use an incremental approach which stresses that the software must be releasable at the end of each iteration. Non-managed projects may have few unit tests or working iterations, leaving an incomplete project unusable.

Advantages of cowboy coding

  • Developers maintain a free-form working environment that may encourage experimentation, learning, and free distribution of results.
  • It allows developers to cross architectural and/or tiered boundaries to resolve design limitations and defects.
  • Without a development/designer framework, the programmer, as opposed to the project manager, is responsible for removing roadblocks. This may improve the speed of development.
  • Independent developers can begin with cowboy coding techniques before later selling them to commercial use or creating community-supported projects.
  • Small projects may be burdened by heavy software management methodologies; cowboy coding removes this burden.
  • By coding in their own time, a hobby project may come to fruition which otherwise wouldn't have[2].
  • It allows truly talented developers the license they need to maximize their potential.[citation needed]

External links

References

  1. ^ Hughes, Bob and Cotterell, Mike (2006). Software Project Management, pp.283-289. McGraw Hill Education, Berkshire. ISBN 007719899
  2. ^ K, Alex. Google's "20 percent time" in action http://googleblog.blogspot.com/2006/05/googles-20-percent-time-in-action.html, Official Google Blog, 2006-5-18

Wikimedia Foundation. 2010.

Игры ⚽ Нужен реферат?

Look at other dictionaries:

  • cowboy code — /kaʊbɔɪ ˈkoʊd/ (say kowboy kohd) noun Computers a programming code that is immediately functional but put into operation without revision for improvements or bug fixing. –cowboy coder, noun –cowboy coding, noun …  

  • Design — For the 1970s music group, see Design (UK band). All Saints Chapel in the Cathedral Basilica of St. Louis by Louis Comfort Tiffany. The building structure and decorations are both examples of design …   Wikipedia

  • List of software development philosophies — This is an incomplete list of approaches, styles, and philosophies in software development.* Agile software development * Agile Unified Process (AUP) * Behavior Driven Development (BDD) * Big Design Up Front (BDUF) * Brooks s law * Cathedral and… …   Wikipedia

  • Scrum (development) — Scrum is an iterative incremental process of software development commonly used with agile software development. Despite the fact that Scrum is not an acronym, some companies implementing the process have been known to adhere to an all capital… …   Wikipedia

  • DTS (sound system) — For other uses, see DTS (disambiguation). DTS, Inc. Type Public Traded as NASDAQ: DTSI …   Wikipedia

  • Marlboro (cigarette) — Marlboro Introduced 1924[1] Produced by Altria Group Philip Morris International …   Wikipedia

  • Lie to Me — For other uses, see Lie to Me (disambiguation). Lie to Me Genre Drama Crime Police procedural Comedy drama Created by Samuel Baum …   Wikipedia

  • performing arts — arts or skills that require public performance, as acting, singing, or dancing. [1945 50] * * * ▪ 2009 Introduction Music Classical.       The last vestiges of the Cold War seemed to thaw for a moment on Feb. 26, 2008, when the unfamiliar strains …   Universalium

  • Business and Industry Review — ▪ 1999 Introduction Overview        Annual Average Rates of Growth of Manufacturing Output, 1980 97, Table Pattern of Output, 1994 97, Table Index Numbers of Production, Employment, and Productivity in Manufacturing Industries, Table (For Annual… …   Universalium

  • American English — US English redirects here. For the political organization, see U.S. English (organization). For other uses, see American English (disambiguation). English language prevalence in the United States. Darker shades of blue indicate higher… …   Wikipedia

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”