Encapsulation (computer programming)

Encapsulation, in object-oriented programming, is the bundling of data with the methods that operate on that data, or the restricting of direct access to some of an objects components.[1] Encapsulation is used to hide the values or state of a structured data object inside a class, preventing unauthorized parties' direct access to them. Publicly accessible methods are generally provided in the class (so-called getters and setters) to access the values, and other client classes call these methods to retrieve and modify the values within the object.

This mechanism is not unique to object-oriented programming. Implementations of abstract data types, e.g. modules, offer a similar form of encapsulation. This similarity stems from the fact that both notions rely on the same mathematical fundamental of an existential type.[2]

A language mechanism for restricting direct access to some of the object's components.[5][6]

A language construct that facilitates the bundling of data with the methods (or other functions) operating on that data.[1][7]

Some programming language researchers and academics use the first meaning alone or in combination with the second as a distinguishing feature of object-oriented programming, while some programming languages that provide lexical closures view encapsulation as a feature of the language orthogonal to object orientation.

The second definition is motivated by the fact that in many OOP languages, components are not hidden automatically and this can be overridden; thus, information hiding is defined as a separate notion by those who prefer the second definition.

The features of encapsulation are supported using classes in most object-oriented programming languages, although other alternatives also exist.

Encapsulation can be used to hide data members and member functions. Under this definition, encapsulation means that the internal representation of an object is generally hidden from view outside of the object's definition. Typically, only the object's own methods can directly inspect or manipulate its fields. Some languages like Smalltalk and Ruby only allow access via object methods, but most others (e.g. C++, C#, Delphi or Java) offer the programmer a degree of control over what is hidden, typically via keywords like public and private.[6] ISO C++ standard refers to protected, private and public as "access specifiers" and that they do not "hide any information". Information hiding is accomplished by furnishing a compiled version of the source code that is interfaced via a header file.

Hiding the internals of the object protects its integrity by preventing users from setting the internal data of the component into an invalid or inconsistent state. A supposed benefit of encapsulation is that it can reduce system complexity, and thus increase robustness, by allowing the developer to limit the inter-dependencies between software components[citation needed].

Almost always, there is a way to override such protection – usually via reflection API (Ruby, Java, C#, etc.), sometimes by mechanism like name mangling (Python), or special keyword usage like friend in C++.

Below is an example in C# that shows how access to a data field can be restricted through the use of a private keyword:

classProgram{publicclassAccount{privatedecimalaccountBalance=500.00m;publicdecimalCheckBalance(){returnaccountBalance;}}staticvoidMain(){AccountmyAccount=newAccount();decimalmyBalance=myAccount.CheckBalance();/* This Main method can check the balance via the public * "CheckBalance" method provided by the "Account" class * but it cannot manipulate the value of "accountBalance" */}}

classAccount{/** * How much money is currently in the account * @var float */private$accountBalance;/** * @param float $currentAccountBalance Initialize account to this dollar amount */publicfunction__construct($currentAccountBalance){$this->accountBalance=$currentAccountBalance;}/** * Add money to account * @param float $money Dollars to add to balance * @return void */publicfunctiondeposit($money){$this->accountBalance+=$money;}/** * Remove money from account * @param float $money Dollars to subtract from balance * @throws Exception * @return void */publicfunctionwithdraw($money){if($this->accountBalance<$money){thrownewException('Cannot withdraw $'.$money.' from account as it contains $'.$this->accountBalance);}$this->accountBalance-=$money;}/** * Get current account balance, that takes all additions and subtractions into consideration. * @return float */publicfunctiongetAccountBalance(){return$this->accountBalance;}}// Create a new object from the Account class with a starting balance of $500.00$myAccount=newAccount(500.00);// We have clearly defined methods for adding and subtracting money from the Account// If we didn't have a method for withdraw(), nothing would prevent us from withdrawing more money than was available in the account$myAccount->deposit(10.24);$myAccount->withdraw(4.45);// Get the current balance$accountBalance=$myAccount->getAccountBalance();echo'My Account Balance: $'.$accountBalance;// 505.79// Our code forbids us from withdrawing more than we have$myAccount->withdraw(600.00);// Exception Message: Cannot withdraw $600 from account as it contains $505.79

Below is an example in Swift. The balance property cannot be accessed directly—one (e.g. a merchant) can only check whether the requested amount is available for spending using the isAvailable(_:) method.

Encapsulation is also possible in non-object-oriented languages. In C, for example, a structure can be declared in the public API (i.e., the header file) for a set of functions that operate on an item of data containing data members that are not accessible to clients of the API:

// Header file "api.h"structEntity;// Opaque structure with hidden members// API functions that operate on 'Entity' objectsexternstructEntity*open_entity(intid);externintprocess_entity(structEntity*info);externvoidclose_entity(structEntity*info);// extern keywords here are redundant, but they won't hurt.// extern keyword defines functions to have external linkage (i.e. can be called outside current file)// which is the default behavior even without the keyword extern

Clients call the API functions to allocate, operate on, and deallocate objects of an opaque data type. The contents of this type are known and accessible only to the implementation of the API functions; clients cannot directly access its contents. The source code for these functions defines the actual contents of the structure:

The authors of Design Patterns[9] discuss the tension between inheritance and encapsulation at length and state that in their experience, designers overuse inheritance. The danger is stated as follows:

Because inheritance exposes a subclass to details of its parent's implementation, it's often said that "inheritance breaks encapsulation"

^Scott, Michael Lee (2006). Programming language pragmatics (2 ed.). Morgan Kaufmann. p. 481. ISBN978-0-12-633951-2. Encapsulation mechanisms enable the programmer to group data and the subroutines that operate on them together in one place, and to hide irrelevant details from the users of an abstraction.