While looking over various PHP libraries I've noticed that a lot of people choose to prefix some class methods with a single underscore, such as
public function _foo()
...instead of...
public function foo()
I realize that ultimately this comes down to personal preference, but I was wondering if anyone had some insight into where this habit comes from.
My thought is that it's probably being carried over from PHP 4, before class methods could be marked as protected or private, as a way of implying "do not call this method from outside the class". However, it also occurred to me that maybe it originates somewhere (a language) I'm not familiar with or that there may be good reasoning behind it that I would benefit from knowing.
Any thoughts, insights and/or opinions would be appreciated.
Drupal, and using underscore:
In a general way the underscore is to simple mark the fact that a function would probably only be called by a related parent function...
Of course, just a simple example...
I was looking for the same answer, I did some research, and I've just discovered that php frameworks suggest different styles:
Code Igniter
The official manual has a coding style section that encourages this practice:
Other frameworks do the same, like
Cakephp:
does the same:
And also
PEAR
does the same:
While
Drupal
code style specifically warns against this:
Symphony
on the other hand, declares:
I was strongly against prefixing private/protected methods with underscore since you can use private/protected keyword for that and IDE will mark it for you.
And I still am, but, I found one reason why it can be a good practice. Imagine that you have public method
addFoo()
and inside that method you have some part of task which is common with other methodsaddFooWhenBar()
,addFooWhenBaz()
... Now, best name for that common method would beaddFoo()
, but it is already taken, so you must come up with some ugly name likeaddFooInternal()
oraddFooCommon()
or ... but_addFoo()
private method looks like best one.It's from the bad old days of Object Oriented PHP (PHP 4). That implementation of OO was pretty bad, and didn't include things like private methods. To compensate, PHP developers prefaced methods that were intended to be private with an underscore. In some older classes you'll see
/**private*/ __foo() {
to give it some extra weight.I've never heard of developers prefacing all their methods with underscores, so I can't begin to explain what causes that.
They are called "magic methods".
I use a leading underscore in the PHP 5 class I write for private methods. It's a small visual cue to the developer that a particular class member is private. This type of hinting isn't as useful when using an IDE that distinguishes public and private members for you. I picked it up from my C# days. Old habits...