PHP: What is the purpose of encapsulation?
I'm talking specifically about the public, private and protected keywords that can apply to properties and methods. I've looked everywh开发者_如何学编程ere and I know what they do and how to use them, but don't see how they would be practical when programming. Could somebody explain or give an example?
The primary purpose of encapsulation (scope) is to ensure that you write code that can't be broken. This applies to scope in general, so let me use a simpler example of a local variable inside a function:
function xyz ($x) {
$y = 1;
while ($y <= 10) {
$array[] = $y * $x;
$y++;
}
return $array;
}
The purpose of this function is to pass a number and return an array. The example code is pretty basic. In order for function xyz() to be dependable, you need to be guaranteed that it does the exact same thing every time. So what if someone had the ability to from the outside change that initial value of $y or $array? Or even $x? If you were able to do that from outside of the function, you could no longer guarantee what that function is returning.
That is where scope (encapsulation) comes into play. It is a way of setting boundaries, of assigning permissions of what can and can't be done with your variables (and functions, properties, methods, objects) to make sure that bit of code will always do exactly what it is expected to do.
Take for instance any built-in php function like...strtolower() or preg_match() or ...well anything. They expect arguments to be passed to them, and they return something specific. Internally there are variables, loops, etc... to take the input and spit out an output. If you were to be able to change that stuff from the outside, there would be no way to guarantee that strotolower() will return a lowercased string you feed it, and that defeats the purpose of having a reusable code block.
This isn't necessarily all that useful when you are programming for yourself, but when you are writing code to be used and shared by many people, especially with using code that involves addons/plugins, etc... it is invaluable for ensuring your code does what it is supposed to be doing, and is accessed/used/called in an expected way.
Private/protected methods are used in compiled languages like C++ and Java. If code is compiled instead left in script form these rules are enforceable. And in these languages particularily can hide cumbersome internal or machine level implementations.
PHP only has these functions, because its developers thought the lack of protected/private methods was meant when people were deriding PHP4 as not being a proper object oriented language.
The use of encapsulation as design concept in PHP is undisputed. The use of these language constructs is however not necessary, and can easily be removed in source code anyway. But in lieu of proper library documentation or if coprogrammers don't honor coding style, it's useful to restrict access.
So, in conclusion: technical use case meager, encouraging to use designated interfaces to abstract processes okay. Often however it is more senseful to design APIs in a way that makes all desirable functionality and data easily available, so the temption to access extraneous interna is reduced. The more you expose, the more difficult it gets to change internal processing later. The more inherent data your expose, the less workarounds or convoluted object structures arise.
I think Grady Booch sums it up quite nicely:
"encapsulation serves to separate the contractual interface of an abstraction and its implementation"
you can find a nice discussion on the same here. Although it is related to .net (not on php) but still a discussion is quite general which includes discussion on the wikipedia article also.
精彩评论