Egoless programming: Difference between revisions
Magioladitis (talk | contribs) m WP:CHECKWIKI error fixes, replaced: isbn=<!--0201734850-->9 → isbn= 9 using AWB (11967) |
|||
Line 3: | Line 3: | ||
== Origin == |
== Origin == |
||
The concept was first propounded by [[Gerald |
The concept was first propounded by [[Gerald M. Weinberg]] in his seminal book of 1971, ''The Psychology of Computer Programming''.<ref>{{cite book | url=http://books.google.co.uk/books?id=76dIAAAAMAAJ&pgis=1 | title=The Psychology of Computer Programming | publisher=Van Nostrand Reinhold | year=1971 | last=Weinberg | first=Gerald M.}}</ref> |
||
==Peer reviews of code== |
==Peer reviews of code== |
Revision as of 18:48, 19 October 2016
Egoless programming is a style of computer programming in which personal factors are minimized so that quality may be improved. The cooperative methods suggested are similar to those used by other collective ventures such as Wikipedia.
Origin
The concept was first propounded by Gerald M. Weinberg in his seminal book of 1971, The Psychology of Computer Programming.[1]
Peer reviews of code
To ensure quality, reviews of code by other programmers are made. The concept of egoless programming emphasises that such reviews should be made in a friendly, collegial way in which personal feelings are put aside. Structured walkthroughs are one way of making such a formal review.[2]
Strengths
- works best for complex tasks
- open communication channels allow information to flow freely to team members
- greater conformity that helps in consistent documentation
- team members have greater job satisfaction[3]
Weaknesses
- projects take a longer time to complete[3]
- projects experience a higher failure rate due to the decentralized nature of and volume of communication between members of the team [3]
- risky shift phenomenon - programmers attempt riskier solutions to solve a software problem[3]
- simple tasks made more difficult by open communication channels[citation needed]
Rival concepts
Egoless programming explicitly minimizes constraints of hierarchy and status so as to enable the free exchange of ideas and improvements. It may be contrasted with the chief programmer team concept which emphasises specialisation and leadership in teams so that they work in a more disciplined way.[4]
See also
References
- ^ Weinberg, Gerald M. (1971). The Psychology of Computer Programming. Van Nostrand Reinhold.
- ^ Wiegers, Karl Eugene (2001). Peer Reviews in Software: A Practical Guide. Addison-Wesley. p. 14. ISBN 978-0-201-73485-0.
- ^ a b c d Mantei, Marilyn (March 1981). "The Effect of Programming Team Structures on Programming Tasks" (PDF). Communications of the ACM. 24 (3): 106–113. doi:10.1145/358568.358571.
- ^ Grubb, Penny; Takang, Armstrong A. (2003), Software maintenance: concepts and practice, World Scientific, ISBN 978-981-238-426-3