- Team programming
In
software engineering , team programming is aproject management strategy for coordinating task distribution incomputer software development projects, which involves the assignment of two or morecomputer programmer s to work collaboratively on an individual sub-task within a larger programming project. In general, the manner in which this term is used today refers to methods currently in vogue within the software development industry where multiple individuals work simultaneously on the same activity; in these systems, programmers are often grouped in pairs at the samecomputer workstation , one observing the other working on the software and alternating roles at time intervals.Traditional team management methods
Traditional software development has nearly always involved multiple programmers working on separate parts of a computer system for any project of significant scope and scale -- a method of
division of labour . Clearly, it is unreasonable to imagine that a single programmer could adequately complete all the required work for a complex system working entirely on their own within a viable timescale; and as development projects become more complex, specialised expertise becomes of paramount importance in aspects such assystems analysis ,quality assurance , and technical challenges posed by individual components. Initially this tended to be an informal process, but with the rise of commercial software development as a viable industry, a more industrial and systematic approach became necessary.Paper-orientated systems methodologies originally designed for undertaking governmental projects, such as the
Structured Systems Analysis and Design Method (SSADM), assigned individual people to carry out individual tasks, and specified the role of designers as being clearly separate from that of the programmers in the waterfall software development model. This methodology also clearly separated each of the individual "life-cycle" stages through which a system development project progressed. The resulting "paper trail" for a systems development project could take so long to build that often parts of the analysis documentation -- or sometimes its entirety -- was out of date by the time of actual development, rendering them worse than useless.Modern trends: multiple programmers to one sub-task
Difficulties were experienced with these older methods, such as costs spiralling out of control as systems grew, and schedules failing to meet time-to-market targets. These issues gave rise to techniques such as
pair programming , along with new systems lifecycle structures such as theBoehm spiral . Specification of these new approaches began in the mid-1980s and continues today. Many of these strategies involve multiple programmers working collaboratively on the "same" piece ofsource code as opposed to being "individually" responsible for individual tasks. For example, in "pair programming", responsibility for the resulting product is equally shared between two programmers who work on their assigned sub-task together. Benefits of this approach include the ability for deficiencies in knowledge and ability in specific areas to be compensated for by the other programmer; in addition, the shared responsibility is thought to increase incentives for meeting project deadlines and quality targets.This technique is frequently used in newer programming methodologies that are focused around
object-oriented programming techniques, such as theRational Unified Process andExtreme Programming (acronym "XP"), often in combination with design documentation methods such as theUnified Modelling Language (UML). In object-oriented programming languages, software functionality forms modular, discrete units (termedclasses for the functional elements, andpackages for constellations of interlinked classes that carry out a particular function); the two most well-known of these areC++ and Java. This lends itself well towards the division of programming projects into sub-teams, although issues are still often encountered in integrating the resulting product following completion of each sub-task.References
Wikimedia Foundation. 2010.