Skip to content Skip to sidebar Skip to footer

Is It A Convention To Prefix Private Classes With Underscores?

I have seen code in which functions/constants are prefixed with underscores. My understanding is that this indicates that they are not to be used directly. Can I do this with class

Solution 1:

Better only use one _. This indicates that a name is private within a module.

It is not imported with the catch-all from <module> import *, and it has some other features such as "preferred destruction".

From here:

If __all__ is not defined, the set of public names includes all names found in the module’s namespace which do not begin with an underscore character ('_').

From here:

Starting with version 1.5, Python guarantees that globals whose name begins with a single underscore are deleted from their module before other globals are deleted.

Double-underscore starting class members are name-mangled.

Solution 2:

Yes; the single underscore usage is endorsed by PEP8 for internal-use classes.

I don't believe the double underscore usage will have any real effect most of the time, since it's used to active name mangling for class attributes, and generally a class isn't an attribute of another class (granted, it can be, in which case Python will happily mangle the name for you.)

Solution 3:

Yes, and this is not only a convention. When you import * from this module, names starting with underscore will not be imported.

Solution 4:

You can use a single underscore as the first character in any variable, but it is carries the implied meaning, "Do not use outside of the class/module unless you really know what you're doing" (eg. intended protected/internal) and it will not import if you use from <module> import *.

Using a double underscore is something you should never do outside of a class as it could mess with name mangling otherwise (and by "could", I mean, "caused me a big headache this past week because I did not realize that it does").

Post a Comment for "Is It A Convention To Prefix Private Classes With Underscores?"