tags:

views:

88

answers:

4

I've found myself that I tend not to have private class functions. If possible, all candidates to private class function rather I put in to unnamed namespace and pass all necessary information as function parameters. I don't have a sound explanation why I'm doing that but at least it looks more naturally to me. As a consequence I need to expose less internal details in the header file.

What is your opinion - is it correct practice?

A: 

I think this is a good practice. It often has the benefit of hiding auxiallary structures and data types as well, which reduces the frequency and size of rebuilds. It also makes the functions easier to split out into another module if it turns out that they're useful elsewhere.

Peter Ruderman
+1  A: 

It basically comes down to a question of whether the function in question really makes sense as part of the class. If your only intent is to keep details of the class out of the header, I'd consider using the pimpl idiom instead.

Jerry Coffin
+4  A: 

I've done this in the past, and it has always ended badly. You cannot pass class objects to the functions, as they need to access the private members, presumably by reference (or you end up with convoluted parameter lists) so you cannot call public class methods. And you can't call virtual functions, for the same reason. I strongly believe (based on experience) that this is A Bad Idea.

Bottom line: This sounds like the kind of idea that might work where the implementation "module" has some special access to the class, but this is not the case in C++.

anon
You're correct that sometimes parameter list is large enough. That's definitely drawback of this approach. On the other hand, I'm trying to stay away from use of any virtual function, so I very rarely fall in to need to call virtual function. Anyway thanks for the answer!
kriau
@kriau Why stay away from the use of virtual functions? And you have not removed your dependency on the header. It strikes me that what you may be looking for here is the PIMPL idiom.
anon
+1 for Pimpl (even though it's not part of the original answer)
Matthieu M.
Like any technique, it's easy to overdo it. Nevertheless, I've seen a ton of classes with private methods that are really just helper functions. Moving these out of the headers has a lot of benefits and doesn't suffer from the gotchas you've described.
Peter Ruderman
+2  A: 

In the semi large projects where I usually work (more than 2 million lines of code) I would ban private class functions if I could. The reason being that a private class function is private but yet it's visible in the header file. This means if I change the signature (or the comment) in anyway I'm rewarded sometimes with a full recompile which costs several minutes (or hours depending on the project).

Just say no to that and hide what's private in the cpp file.

If I would start fresh on a large c++ project I would enforce PIMPL Idiom: http://c2.com/cgi/wiki?PimplIdiom to move even more private details into the cpp file.

FuleSnabel