Sometimes you need to see through walls
- 6 November 2004
- proceedings article
- Published by Association for Computing Machinery (ACM)
Abstract
Information hiding is one of the most important and influential principles in software engineering. It prescribes that software modules hide implementation details from other modules in order to decrease the dependency between them. This separation also decreases the dependency among software developers implementing modules, thus simplifying some aspects of collaboration. A common instantiation of this principle is in the form of application programming interfaces (APIs). We performed a field study of the use of APIs and observed that they served many roles. We observed that APIs were successful indeed in supporting collaboration by serving as contracts among stakeholders as well as by reifying organizational boundaries. However, the separation that they accomplished also hindered other forms of collaboration, particularly among members of different teams. Therefore, we think argue that API's do not only have beneficial purposes. Based on our results, we discuss implications for collaborative software development tools.Keywords
This publication has 22 references indexed in Scilit:
- Building Collaboration into IDEsQueue, 2003
- Public versus published interfacesIEEE Software, 2002
- Protected variation: the importance of being closedIEEE Software, 2001
- The critical role of workplace studies in CSCWPublished by Cambridge University Press (CUP) ,2000
- Social translucenceACM Transactions on Computer-Human Interaction, 2000
- Version models for software configuration managementACM Computing Surveys, 1998
- How a Cockpit Remembers Its SpeedsCognitive Science, 1995
- Collaboration and controlCrisis management and multimedia technology in London Underground Line Control RoomsComputer Supported Cooperative Work (CSCW), 1992
- A field study of the software design process for large systemsCommunications of the ACM, 1988
- On the criteria to be used in decomposing systems into modulesCommunications of the ACM, 1972