Search code examples
design-patternsrepositorycouplinggrasp

Does GRASP Creator really decouples?


I'm learning GRASP pattern at school and I have a question about the Creator pattern.

Let's say you have three class, Computer, UserRespository and User.

One of the rules of the GRASP Creator pattern tells you to assign the responsibility of creating an object to the class containing those object. By following this guideline, UserRepository should be the creator of User.

So if Computer wants to create a user, he'll ask UserRespository.

//in Computer's code
repo.createUser("John");


//in UserRepository
public void createUser(String name)
{
    users.add(new User(name));
}

This effectively decouple Computer from User. Really?

Clearly, Computer doesn't have any reference to User, but I think Computer is still highly coupled to the creation of User. Why? The createUser method is poorly hiding the creation. If User change it's constructor, you'd have to change the createUser method to reflect those changes and also every client using the method.

What are the advantage of using this pattern then?


Solution

  • I've learned that decoupling is really asking "Can you extract this class from the system?". So by hiding the creation of an object behind a method, given this object is not used anywhere else than in the creator, it effectively decouple the object from the system.