Saturday, April 21, 2012

Coupling and Cohesion


 Coupling means dependency on others.

"Coupling is a measure of interdependencies between modules, which should be minimized"

Coupling - A measure of how much a module (package, class, method) relies on other modules. It is desirable to reduce coupling, or reduce the amount that a given module relies on the other modules of a system.

 If two modules communicate, they should exchange as little information as possible.

 Real World Example:-
·         Loose: You and the guy at the convenience store. You communicate through a well-defined protocol to achieve your respective goals - you pay money, he lets you walk out with the bag of Cheetos. Either one of you can be replaced without disrupting the system.
·         Tight: You and your wife.

Cohesion means completeness with itself.

"cohesion, a quality to be maximized, focuses on the relationships between the activities performed by each module."

Cohesion - A measure of how closely related the members (classes, methods, functionality within a method) of a module are to the other members of the same module. It is desirable to increase cohesion as that indicates that a module has a very specific task and does only that task.

Cohesion refers to how closely all the routines in a class or all the code in a routine support a central purpose
 Real World Example:-
·         Low: The convenience store. You go there for everything from gas to milk to ATM banking. Products and services have little in common, and the convenience of having them all in one place may not be enough to offset the resulting increase in cost and decrease in quality.
·         High: The cheese store. They sell cheese. Nothing else. Can't beat 'em when it comes to cheese though.