Tutorials : Designing Abstraction :

OCP compliant solution

To make the design OCP compliant, we need to make the following changes:

  • The strong coupling between LoanRequestHandler and any Validator objects should be avoided.
  • Individual validator objects implementing different business logics for approving a loan request should represent an abstract type and the LoanRequestHandler should use this abstract type rather than any specific sub-type to avoid any strong coupling.

Bearing these facts in mind, we come up with the following design. I will only show the skeleton of the modified design and the code inside each of them remains same as before. Only the design changes, not the implementation.

Listing 3

public class LoanRequestHandler {

	private int balance;
	private int period;
	/** Creates a new instance of LoanRequestHandler */
	public LoanRequestHandler(int balance, int period) {
		this.balance = balance;
		this.period = period;
	}

	public void approveLoan(Validator validator) {
		if(validator.isValid(balance))
		   //sanction the loan
		   System.out.println("Loan approved...");
		else
		   System.out.println("Sorry not enough balance...");
	}
}

The LoanRequestHandler now uses an interface type of object named Validator, which defines the method for approving the loan. Each individual Validator object will implement this method, with the object specific business logic within the method inherited from the defined Validator interface.

Listing 4

public interface Validator {

  public Boolean isValid(int balance);
}

Now each individual Validator object will implement this interface and make use of their individual business logic to approve or reject a loan request. Based on this the PersonalLoanValidator  object changes to the following.

Listing 5

public class PersonalLoanValidator implements Validator{

	/** Creates a new instance of PersonalLoanValidator */
	public PersonalLoanValidator() {
	}

	public boolean isValid(int balance) {
		if(balance>1000)
			return true;
		else
			return false;
	}
}

Now we will implement another Validator named BusinessLoanValidator.

public class BusinessLoanValidator implements Validator{
	/** Creates a new instance of PersonalLoanValidator */
	public PersonalLoanValidator() {
	}

	public boolean isValid(int balance) {
		if(balance>5000)
		   return true;
		else
		   return false;
	}
}

The BusinessLoanValidator only approves the loan request if the balance is more than 5000, whereas the PersonalLoanValidator will approve it if the balance is more than 1000. But the LoanRequestHandler remains unaffected by this change in the business logic change. So long it is supplied the correct Validator, it will operate correctly.

Clearly, this is a better design. Any new loan type can be handled by adding a new XXXValidator object, implementing the Validator interface. This is OCP compliant solution.

How to Add Java Applets to Your Site

New on the Java Boutique:

New Review:

Time Management Made Easy with the Quartz Enterprise Job Scheduler
Why not just use the Java timer API? This open source scheduling API boasts simplicity, ease-of-integration, a well-rounded feature set, and it's free!

New Applet:

Reverse Complement
Reverse Complement is a simple applet that converts DNA or RNA sequences into three useful formats.

Elsewhere on internet.com:

WebDeveloper Java
Lots of Java information on webdeveloper.com

WDVL Java
Thorough Java resource at the Web Developer's Virtual Library.

ScriptSearch Java
Hundreds of free Java code files to download.

jGuru: Your View of the Java Universe
Customizable portal with online training, FAQs, regular news updates, and tutorials.