Skip to main content

some OOPS concepts and examples

The class is the description of the object and the object in an instance of the
class. For example the class of humans would describe us as having the attributes such as
arms, hands, legs and heads; and methods such as talk, think, eat, and sit. However each of us
would be an instance of that class, an object. If I can jump it’s because humans can jump, if I can laugh, it’s because humans can laugh. That is, the class defines the methods and attributes
for each object belonging to that class.

POLYMORPHISM :
Polymorphism is the ability for objects to respond differently to the same message, depending upon what type of object they are. For example, members from each of the following classes; Spouse, YoungerBrother, TotalStranger or LawEnforcementOfficer, are likely to behave differently when the hug method is called upon them.
Polymorphism becomes very useful when we have a group of related objects upon which we want to perform an operation, but those objects may need to react in different ways. For example, an ElectricCar will need to react differently to a FossilFuelCar when asked to accelerate.
There are two distinct forms of polymorphism in object oriented programming; interface and
inheritance polymorphism. Interface polymorphism is where two or more unrelated classes provide the same interface to certain methods. For example both sparrows and aeroplanes can fly. Although sparrows and aeroplanes fly in completely different ways, if we implement our classes in such a way that the methods have the same arguments and argument order then we have an example of interface polymorphism.
Inheritance polymorphism is where a child class inherits methods from an ancestor. Hence if the
Machine class, mentioned above, implemented a turn_on method then the DrinksMachine class
would inherit that method. If we were to call the turn_on method on a DrinksMachine object the
DrinksMachine object would behave as if it were merely a Machine object for that method call.

Ten rules for when to use OO :

1. When your design is large, or is likely to become large.
2. When data is aggregated into obvious structures, especially if there’s a lot of data in each
aggregate.
A person’s name is often not a good candidate for an object. A string of any length is still only a
single piece of information. If however, you wish to associate other information with the name,
such as age, address, phone number (enough data for example that you’d think to use a hash),
then you have a good case for an object.

my %person1 = (
name => "Julien Gileson",
age => 42,
address => "42 Halloway St"
);
3. When types of data form a natural hierarchy that lets us use inheritance.

Inheritance allows us to have a common set of operations shared by all similar objects, while
still allowing specific operations for each specialised type. For example, one may have a class
that tests the functionality on a website, and another that spiders a company’s local intra-net.
Both classes share a common base concerning access and parsing of web-pages.

4. When operations on data varies on data type.

Many similar types of data have similar operations. For example music stored on CD is a
different kind of data than music stored on disk in mp3 or ogg vorbis format. However, although
the details are different for all, all these kinds of music can be played. An OO model allows
code similar to the following, without needing to be concerned about the underlying format:
foreach my $song ($cd_track, $mp3, $ogg) {
$song->play();
}

5. When it’s likely you’ll have to add data types later.
Consider the above example. If our specification says that we want something which will handle mp3 files and music from CDs, we could code a solution to handle these two exact cases.
However, as requirements tend to evolve over time it may become likely that we’ll need to
handle ogg vorbis, midi, iTunes, and other formats too. A carefully designed OO model can allow us to accommodate these future requirements without significant changes to our application.


6. When interactions between data is best shown by operators.
Perl’s object model allows operators to be overloaded so that things work the way you’d like
them to. For example: $volume += 5;
is traditionally only meaningful if $volume is a number. However, with overloading, $volume
can represent the actual state of our speakers, and numerical adjustments can directly increase or decrease the energy output of the speakers.

7. When implementation of components is likely to change, especially in the same program.
Object oriented programming assists in data encapsulation. A class should be treated as a black box by the code which uses it. Defining clear interfaces allows the internals of the class to be changed as many times as necessary without affecting the rest of the project.
Thus if your class implements access to some data in a file, then the data’s format could change
from being in plain-text, to a flat-file database, to a full relational database without the rest of the application needing to change.

8. When the system design is already object-oriented.

9. When huge numbers of clients use your code.
In addition to encapsulation, object oriented code encourages modularisation. By breaking your
project up into separate modules it becomes easier to maintain and re-use. A change to a class
should not change any application code, making bug-fixes and improvements more
straightforward.

10. When you have a piece of data on which many different operations are applied.
Consider a piece of data representing sound. This sound can be mixed, adjusted, run backwards, have echo effects added and many other kinds of operations. By wrapping it in a Perl object we can associate these operations with this kind of data. The resulting code is often easier to read, understand, and maintain

11. When the kinds of operations have standard names (check, process, etc).
The traditional way of handling identical names for operations on unrelated data is to use the
data type in the subroutine name. For example.
sub process_person { ... }
sub process_payment { ... }
sub process_music { ... }

Objects side-step this issue by associating the operation with the data allowing all of the
subroutines to have the same name, but be in different name spaces.
So: Person::process(); Payment::process(); Music::process();

Comments

Popular posts from this blog

How to Use Chisanbop (Korean Finger Math) for Basic Addition and Counting | eHow.com

How to Use Chisanbop (Korean Finger Math) for Basic Addition and Counting eHow.com Difficulty: Easy Instructions Step 1 In Chisanbop you'll be using your two hands and ten fingers to represent numbers from 0 to 99. Start out with your hands out in front of you with closed fists. This represents 0. Each finger (not thumb) on your right hand represents 1. To represent 3, just press down three right hand fingers. Your right thumb represents 5. To represent 7, press down your right thumb and 2 right hand fingers. Think of your right hand as the ones or units place (column). Step 2 Your left hand represents the tens place (column). Each finger on your left hand is worth 10. For example, to represent 30, press down three left hand fingers. To represent 38, do the same, but also use your right hand to represent 8 as described above. Your left thumb represents 50. To represent 86, press down your left thumb and three left hand fingers for the 80, and your right thumb and one righ...
Should we allow our staff to use social networking sites? Some people say they are dangerous but I can't see how. Can you explain the dangers? > EXPERT RESPONSE There's nothing wrong with using Facebook, other than the potential impact on working time, but that's not a security matter! The issue is in how your staff configures Facebook, and what information they place on it. A few tips to pass on to your staff: Don't allow anyone that isn't part of your network of 'friends' to see your profile. Don't allow non-friends to see your friends. Why? I could easily impersonate one of your friends, fake a new profile, and send you an invite. You accept, thinking a genuine friend has created a new profile, then I'm in your network of friends and can see your profile. Think about what information is in your profile. What would be useful in stealing your identity? Date of birth, address, email address, employer, interests. why does this type of information n...

Creative commons

Few Terms related to CC  - Commons :  The Commons refers to resources that are collectively owned. [1] This can include everything from land to software. [2] The process by which the commons are transformed into private property is often termed enclosure . [source : wikipedia ] The public domain (public ownership of creative works) is an intellectual property designation for the range of content that is not owned or controlled by anyone. These materials are "public property", and available for anyone to use freely (the "right to copy" [1] ) for any purpose. The public domain is most often discussed in contrast to works whose use is restricted by copyright . Under modern law, most original works of art, literature, music, etc. are covered by copyright from the time of their creation for a limited period of time (which varies by country). When the copyright expires, the work enters the public domain. The public domain can be defined in contrast to several f...