One of the main principles of OOP is the **encapsulation principle**, which says that complex problems should be broken down into many small problems that we can solve independently and simultaneously. At the same time, we as users don't care how it happens and the data (internal state) remains isolated.
For example, if we are solving the problem of how to return the result 1.6
based on a user query with the expression (5+3)*(2/(7+3))
, probably none of us can write a single function or method that solves this problem at once.
HINT: A ready-made solution to this type of example is in the article Processing a mathematical expression as a string, but be prepared for the fact that it's not easy.
With encapsulation, you'll be able to use objects "as a user", that is, call their methods and not worry at all about how they work internally.
Suppose we are dealing with calculating an employee's salary and we want to use an existing class from another programmer to do it. We only need to know the mandatory constructor parameters and we can "just use" the class:
$wage = new WageEmployee(25000, // gross wage6, // number of years in the company10, // number of years of experiencetrue // is he a man?);echo $wage->getHruba(); // 25000echo $mzda->getCista(); // 17800
The parameters of the object are fictional and do not correspond to how the wage is actually calculated. In particular, the principle is illustrated by the fact that we only need to know the general public interface and we don't even need to deal with the internal state of the object, not even the internal implementation and certainly not why it works the way it does. We simply call the getCista()
method and get the net payoff.
It is important to note that encapsulation itself is not a feature or syntax of the language. The fact that a class and application is encapsulated is only a matter of the programmer designing the application and thinking about the code.
Always think of class design like this:
For properties and methods that deal with internal logic, it makes sense to set the visibility as private
. The main advantage of this is that they won't be called from outside and the user will be forced to use your designed interface, thus protecting the data and the internal state of the object.
For example, let's have an object representing a bank account where we want to post payments and deal with the current balance:
class BankAccount{private int $sum;public function __construct(int $startSum){$this->sum = $startSum >= 0 ? $startSum : 0;}public function getSum(): int{return $this->sum;}public function pay(int $price): void{$newSum = $this->sum - $price;if ($newSum < 0) {throw new \Exception('You don't have that much money!');}$this->sum = $newSum;}public function addMoney(int $money): void{$this->sum += $money;}}
Note that the class contains only a single private
property $sum
, which contains the current balance.
If we want to get the current balance, there is a getSum()
method for that, but we have no way to change the new balance value. We can only remove money using the pay()
method or add money using the addMoney()
method.
Thanks to this principle, we always know for sure that nobody can break the object.
If the user tries to pay more money than is actually in the account, the pay()
method will not allow it because it performs a check calculation before overwriting the $sum
property, and if the balance should be negative (less than zero), an error exception is thrown and the operation stops.
We have demonstrated the basic principle of encapsulation, which allows us to think better about object abstraction and brings a whole new perspective.
Once you get a good grasp of this principle, you'll see that frameworks start to make a huge amount of sense, because they internally encapsulate a lot of cleverness that you can just use.
Next time we'll look at dedicacy and visibility.
Jan Barášek Více o autorovi
Autor článku pracuje jako seniorní vývojář a software architekt v Praze. Navrhuje a spravuje velké webové aplikace, které znáte a používáte. Od roku 2009 nabral bohaté zkušenosti, které tímto webem předává dál.
Rád vám pomůžu:
Články píše Jan Barášek © 2009-2025 | Kontakt | Mapa webu
Status | Aktualizováno: ... | en