Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Can a class return an object of itself

Tags:

oop

Can a class return an object of itself.

In my example I have a class called "Change" which represents a change to the system, and I am wondering if it is in anyway against design principles to return an object of type Change or an ArrayList which is populated with all the recent Change objects.

like image 423
Ankur Avatar asked Sep 15 '09 04:09

Ankur


4 Answers

Yes, a class can have a method that returns an instance of itself. This is quite a common scenario.

In C#, an example might be:

public class Change
{
    public int ChangeID { get; set; }

    private Change(int changeId)
    {
        ChangeID = changeId;
        LoadFromDatabase();
    }

    private void LoadFromDatabase()
    {
        // TODO Perform Database load here.
    }

    public static Change GetChange(int changeId)
    {
        return new Change(changeId);
    }
}
like image 114
Scott Ferguson Avatar answered Oct 17 '22 11:10

Scott Ferguson


Yes it can. In fact, that's exactly what a singleton class does. The first time you call its class-level getInstance() method, it constructs an instance of itself and returns that. Then subsequent calls to getInstance() return the already-constructed instance.

Your particular case could use a similar method but you need some way of deciding the list of recent changes. As such it will need to maintain its own list of such changes. You could do this with a static array or list of the changes. Just be certain that the underlying information in the list doesn't disappear - this could happen in C++ (for example) if you maintained pointers to the objects and those objects were freed by your clients.

Less of an issue in an automatic garbage collection environment like Java since the object wouldn't disappear whilst there was still a reference to it.

However, you don't have to use this method. My preference with what you describe would be to have two clases, changelist and change. When you create an instance of the change class, pass a changelist object (null if you don't want it associated with a changelist) with the constructor and add the change to that list before returning it.

Alternatively, have a changelist method which creates a change itself and returns it, remembering the change for its own purposes.

Then you can query the changelist to get recent changes (however you define recent). That would be more flexible since it allows multiple lists.

You could even go overboard and allow a change to be associated with multiple changelists if so desired.

like image 38
paxdiablo Avatar answered Oct 17 '22 09:10

paxdiablo


Another reason to return this is so that you can do function chaining:

class foo
{
    private int x;
    public foo()
    {
        this.x = 0;
    }

    public foo Add(int a)
    {
        this.x += a;
        return this;
    }

    public foo Subtract(int a)
    {
        this.x -= a;
        return this;
    }

    public int Value
    {
        get { return this.x; }
    }

    public static void Main()
    {
        foo f = new foo();
        f.Add(10).Add(20).Subtract(1);
        System.Console.WriteLine(f.Value);
    }
}
$ ./foo.exe
29

There's a time and a place to do function chaining, and it's not "anytime and everywhere." But, LINQ is a good example of a place that hugely benefits from function chaining.

like image 42
Mark Rushakoff Avatar answered Oct 17 '22 10:10

Mark Rushakoff


A class will often return an instance of itself from what is sometimes called a "factory" method. In Java or C++ (etc) this would usually be a public static method, e.g. you would call it directly on the class rather than on an instance of a class.

In your case, in Java, it might look something like this:

List<Change> changes = Change.getRecentChanges();

This assumes that the Change class itself knows how to track changes itself, rather than that job being the responsibility of some other object in the system.

A class can also return an instance of itself in the singleton pattern, where you want to ensure that only one instance of a class exists in the world:

Foo foo = Foo.getInstance();
like image 26
Ben Zotto Avatar answered Oct 17 '22 10:10

Ben Zotto