Problems? Is your data what you think it is? | |
PerlMonks |
Re^2: Procedural vs OOP modulesby LanX (Saint) |
on Oct 28, 2021 at 23:28 UTC ( [id://11138160]=note: print w/replies, xml ) | Need Help?? |
> Is there any state that needs to be shared among them? If so, use OOP Actually you can share state in the package variables, but only one set of them. This pattern is similar to a singleton object in OOP. (The modular interface of Data::Dumper is a good example for that, with the global config vars, like $Data::Dumper::Indent ) But you are right, a very good reason to use methods instead of functions is if they all start to look like this
then it's obviously better to write
especially if there is a chance that you might need to have different initializations in the same code
( see Data::Dumper again with it's alternative OOP interface, where the configs are encapsulated in the objects like $OBJ->Indent([NEWVAL]) or $OBJ2->Indent([NEWVAL]) ) On a side note: I prefer to think about objects like actors which do things, not containers which have attributes. So reducing them to shared data is not the whole picture. Last but not least: PBP lists some criteria when to use what...
Cheers Rolf
In Section
Seekers of Perl Wisdom
|
|