| CARVIEW |
- #bless REF,CLASSNAME
- #bless REF
-
blesstells Perl to mark the item referred to byREFas an object in a package. The two-argument version ofblessis always preferable unless there is a specific reason to not use it.Bless the referred-to item into a specific package (recommended form):
bless $ref, $package;The two-argument form adds the object to the package specified as the second argument.
Bless the referred-to item into package
main:bless $ref, "";If the second argument is an empty string,
blessadds the object to packagemain.Bless the referred-to item into the current package (not inheritable):
bless $ref;If
blessis used without its second argument, the object is created in the current package. The second argument should always be supplied if a derived class might inherit a method executingbless. Because it is a potential source of bugs, one-argumentblessis discouraged.
See perlobj for more about the blessing (and blessings) of objects.
blessreturns its first argument, the supplied reference, as the value of the function; sinceblessis commonly the last thing executed in constructors, this means that the reference to the object is returned as the constructor's value and allows the caller to immediately use this returned object in method calls.CLASSNAMEshould always be a mixed-case name, as all-uppercase and all-lowercase names are meant to be used only for Perl builtin types and pragmas, respectively. Avoid creating all-uppercase or all-lowercase package names to prevent confusion.Also avoid
blessing things into the class name0; this will cause code which (erroneously) checks the result ofrefto see if a reference isblessed to fail, as "0", a false value, is returned.See "Perl Modules" in perlmod for more details.
Perldoc Browser is maintained by Dan Book (DBOOK). Please contact him via the GitHub issue tracker or email regarding any issues with the site itself, search, or rendering of documentation.
The Perl documentation is maintained by the Perl 5 Porters in the development of Perl. Please contact them via the Perl issue tracker, the mailing list, or IRC to report any issues with the contents or format of the documentation.