Role-oriented programming as a form of
computer programming
Computer programming is the process of performing a particular computation (or more generally, accomplishing a specific computing result), usually by designing and building an executable computer program. Programming involves tasks such as anal ...
aims at expressing things in terms that are analogous to human
concept
Concepts are defined as abstract ideas. They are understood to be the fundamental building blocks of the concept behind principles, thoughts and beliefs.
They play an important role in all aspects of cognition. As such, concepts are studied by s ...
ual understanding of the
world
In its most general sense, the term "world" refers to the totality of entities, to the whole of reality or to everything that is. The nature of the world has been conceptualized differently in different fields. Some conceptions see the worl ...
. This should make programs easier to understand and maintain.
The main idea of role-oriented programming is that humans think in terms of
role
A role (also rôle or social role) is a set of connected behaviors, rights, obligations, beliefs, and norms as conceptualized by people in a social situation. It is an expected or free or continuously changing behavior and may have a given indivi ...
s. This claim is often backed up by examples of
social relations. For example, a student attending a class and the same student at a party are the same person, yet that person plays two different roles. In particular, the interactions of this person with the outside world depend on his current role. The roles typically share features, e.g., the intrinsic properties of being a person. This sharing of properties is often handled by the
delegation
Delegation is the assignment of authority to another person (normally from a manager to a subordinate) to carry out specific activities. It is the process of distributing and entrusting work to another person,Schermerhorn, J., Davidson, P., Poole ...
mechanism.
In the older literature and in the field of
database
In computing, a database is an organized collection of data stored and accessed electronically. Small databases can be stored on a file system, while large databases are hosted on computer clusters or cloud storage. The design of databases spa ...
s, it seems that there has been little consideration for the context in which roles interplay with each other. Such a context is being established in newer role- and
aspect-oriented programming
In computing, aspect-oriented programming (AOP) is a programming paradigm that aims to increase modularity by allowing the separation of cross-cutting concerns. It does so by adding behavior to existing code (an advice) ''without'' modifying ...
languages such as
Object Teams
Object may refer to:
General meanings
* Object (philosophy), a thing, being, or concept
** Object (abstract), an object which does not exist at any particular time or place
** Physical object, an identifiable collection of matter
* Goal, an a ...
. Compare the use of "role" as "a set of software programs (services) that enable a server to perform specific functions for users or computers on the network" in
Windows Server
Windows Server (formerly Windows NT Server) is a group of operating systems (OS) for servers that Microsoft has been developing since July 27, 1993. The first OS that was released for this platform was Windows NT 3.1 Advanced Server. With the ...
jargon.
Many researchers have argued the advantages of roles in
modeling and implementation. Roles allow objects to evolve over time, they enable independent and
concurrently existing views (interfaces) of the object, explicating the different contexts of the object, and
separating concerns. Generally roles are a natural element of human daily concept-forming. Roles in programming languages enable objects to have changing interfaces, as we see in
real life
Real life is a phrase used originally in literature to distinguish between the real world and fictional, virtual or idealized worlds, and in acting to distinguish between actors and the characters they portray. It has become a popular term on the ...
- things change over time, are used differently in different contexts, etc.
Authors of role literature
Barbara PerniciBruce Wallace*
Charles Bachman
Charles William Bachman III (December 11, 1924 – July 13, 2017) was an American computer scientist, who spent his entire career as an industrial researcher, developer, and manager rather than in academia. He was particularly known for hi ...
Friedrich SteimannKasper B. GraversenKasper Østerbye*
Trygve Reenskaug
Thomas Kühn
Programming languages with explicit support for roles
*
JavaScript Delegation - Functions as Roles (Traits and Mixins)
Object Teams*
Perl (Moose)
*
Raku
powerJavaSCala ROLes Language
See also
*
Aspect-oriented programming
In computing, aspect-oriented programming (AOP) is a programming paradigm that aims to increase modularity by allowing the separation of cross-cutting concerns. It does so by adding behavior to existing code (an advice) ''without'' modifying ...
*
Data, context and interaction
*
Object Oriented Role Analysis Method
*
Object-role modeling
*
Subject (programming)
*
Subject-oriented programming
In computing, subject-oriented programming is an object-oriented software paradigm in which the state (fields) and behavior (methods) of objects are not seen as intrinsic to the objects themselves, but are provided by various subjective perceptio ...
*
Traits (computer science)
References
External links
Adaptive Plug-and-Play Components for Evolutionary Software Development by Mira Mezini and Karl Lieberherr
Overview and taxonomy of Role languagesROPE: Role Oriented Programming Environment for Multiagent Systems
{{compu-prog-stub
Object-based programming languages
Programming paradigms