Egoless programming: Difference between revisions
First draft |
→History: RM WP:PEACOCK. |
||
(67 intermediate revisions by 53 users not shown) | |||
Line 1: | Line 1: | ||
{{Short description|Computer development technique}} |
|||
'''Egoless programming''' is a style of [[computer programming]] in which personal factors are |
'''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]]. |
||
== |
==History== |
||
⚫ | The concept was first propounded by [[Gerald M. Weinberg]] in his 1971 book, ''The Psychology of Computer Programming''.<ref>{{cite book | url=https://books.google.com/books?id=76dIAAAAMAAJ | title=The Psychology of Computer Programming | publisher=Van Nostrand Reinhold | year=1971 | last=Weinberg | first=Gerald M.| isbn=9780442207649 }}</ref> |
||
==Peer reviews of code== |
|||
⚫ | The concept was first propounded by [[Gerald |
||
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. [[Software walkthrough|Structured walkthrough]]s are one way of making such a formal review.<ref>{{cite book | url=https://books.google.com/books?id=d7BQAAAAMAAJ | title=Peer Reviews in Software: A Practical Guide | publisher=Addison-Wesley | year=2001 | page=14 | isbn= 978-0-201-73485-0 | last=Wiegers | first=Karl Eugene}}</ref> |
|||
== |
==Strengths== |
||
* Works best for complex tasks. |
|||
The key principles have been summarised as:<ref>{{cite web|title=Ten Commandments of egoless programming|author=Lamont Adams|date=6 June 2002|url=http://news.zdnet.co.uk/itmanagement/0,1000000308,2111465,00.htm}}</ref> |
|||
* Open communication channels allow information to flow freely to team members |
|||
* Greater conformity that helps in consistent documentation |
|||
* Team members have greater job satisfaction.<ref name="mantei1981"/> |
|||
==Weaknesses== |
|||
# Understand and accept that you will make mistakes. |
|||
* Projects take longer to complete.<ref name="mantei1981">{{cite journal | url=http://sunnyday.mit.edu/16.355/mantei-teams.pdf | title=The Effect of Programming Team Structures on Programming Tasks | last=Mantei | journal=Communications of the ACM |date=March 1981 | volume=24 | issue=3 | pages=106–113 | first=Marilyn | doi=10.1145/358568.358571| s2cid=207907944 }}</ref> |
|||
# You are not your code. |
|||
* Projects experience a higher failure rate due to the decentralized nature of and volume of communication between members of the team.<ref name="mantei1981">{{cite journal | url=http://sunnyday.mit.edu/16.355/mantei-teams.pdf | title=The Effect of Programming Team Structures on Programming Tasks | last=Mantei | journal=Communications of the ACM |date=March 1981 | volume=24 | issue=3 | pages=106–113 | first=Marilyn | doi=10.1145/358568.358571| s2cid=207907944 }}</ref> |
|||
# No matter how much ''kung fu'' you know, someone else will always know more. |
|||
* Risky shift phenomenon{{snd}} Programmers attempt riskier solutions to solve a software problem.<ref name="mantei1981">{{cite journal | url=http://sunnyday.mit.edu/16.355/mantei-teams.pdf | title=The Effect of Programming Team Structures on Programming Tasks | last=Mantei | journal=Communications of the ACM |date=March 1981 | volume=24 | issue=3 | pages=106–113 | first=Marilyn | doi=10.1145/358568.358571| s2cid=207907944 }}</ref> |
|||
# Don't rewrite code without consultation. |
|||
* Simple tasks are made more difficult by open communication channels.{{Clarify|date=February 2020}}{{citation needed|date=June 2014}} |
|||
# Treat people who know less than you with respect, deference, and patience. |
|||
# The only constant in the world is change. |
|||
==Rival concepts== |
|||
# The only true authority stems from knowledge, not from position. |
|||
Egoless programming explicitly minimizes constraints of [[hierarchy]] and [[Social status|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.<ref>{{Citation | url=https://books.google.com/books?id=ge8o_VkAsiYC&pg=PA210 | title=Software maintenance: concepts and practice | publisher=World Scientific | year=2003 | isbn=978-981-238-426-3 | last1=Grubb | first1=Penny | last2=Takang | first2=Armstrong A.}}</ref> |
|||
# Fight for what you believe, but gracefully accept defeat. |
|||
# Don't be "the guy in the room". |
|||
# Critique code instead of people - be kind to the coder, not to the code. |
|||
==See also== |
==See also== |
||
* [[List of software development philosophies]] |
|||
⚫ | |||
*[[Software review]] |
|||
⚫ | |||
==References== |
==References== |
||
{{reflist}} |
{{reflist}} |
||
==External links== |
|||
[[Category:Computer programming]] |
|||
*[http://blog.codinghorror.com/the-ten-commandments-of-egoless-programming/ The Ten Commandments of Egoless Programming] |
|||
{{DEFAULTSORT:Egoless Programming}} |
|||
[[Category:Software development process]] |
Latest revision as of 00:08, 9 November 2024
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.
History
[edit]The concept was first propounded by Gerald M. Weinberg in his 1971 book, The Psychology of Computer Programming.[1]
Peer reviews of code
[edit]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
[edit]- 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
[edit]- Projects take longer 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 are made more difficult by open communication channels.[clarification needed][citation needed]
Rival concepts
[edit]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
[edit]References
[edit]- ^ Weinberg, Gerald M. (1971). The Psychology of Computer Programming. Van Nostrand Reinhold. ISBN 9780442207649.
- ^ 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. S2CID 207907944.
- ^ Grubb, Penny; Takang, Armstrong A. (2003), Software maintenance: concepts and practice, World Scientific, ISBN 978-981-238-426-3