[refactor] Remove unnecessary declarations in service-locator pattern.

This commit is contained in:
ruslanpa 2015-02-10 10:02:44 +02:00
parent 4b432a79d9
commit 14058082bb
6 changed files with 119 additions and 120 deletions

View File

@ -1,9 +1,10 @@
package com.iluwatar; package com.iluwatar;
/** /**
* Service locator pattern, used to lookup jndi services * Service locator pattern, used to lookup jndi services
* and cache them for subsequent requests. * and cache them for subsequent requests.
* @author saifasif
* *
* @author saifasif
*/ */
public class App { public class App {
public static void main(String[] args) { public static void main(String[] args) {
@ -16,5 +17,4 @@ public class App {
service = ServiceLocator.getService("jndi/serviceA"); service = ServiceLocator.getService("jndi/serviceA");
service.execute(); service.execute();
} }
} }

View File

@ -3,27 +3,27 @@ package com.iluwatar;
/** /**
* For JNDI lookup of services from the web.xml. Will match name of the service name that * For JNDI lookup of services from the web.xml. Will match name of the service name that
* is being requested and return a newly created service object with the name * is being requested and return a newly created service object with the name
* @author saifasif
* *
* @author saifasif
*/ */
public class InitContext { public class InitContext {
/** /**
* Perform the lookup based on the service name. The returned object will need to be * Perform the lookup based on the service name. The returned object will need to be
* casted into a {@link Service} * casted into a {@link Service}
* @param serviceName *
* @return * @param serviceName a string
* @return an {@link Object}
*/ */
public Object lookup(String serviceName){ public Object lookup(String serviceName) {
if( serviceName.equals("jndi/serviceA") ){ if (serviceName.equals("jndi/serviceA")) {
System.out.println("Looking up service A and creating new service for A"); System.out.println("Looking up service A and creating new service for A");
return new ServiceImpl("jndi/serviceA"); return new ServiceImpl("jndi/serviceA");
} else if( serviceName.equals("jndi/serviceB") ){ } else if (serviceName.equals("jndi/serviceB")) {
System.out.println("Looking up service B and creating new service for B"); System.out.println("Looking up service B and creating new service for B");
return new ServiceImpl("jndi/serviceB"); return new ServiceImpl("jndi/serviceB");
} else { } else {
return null; return null;
} }
} }
} }

View File

@ -14,16 +14,15 @@ public interface Service {
/* /*
* The human readable name of the service * The human readable name of the service
*/ */
public String getName(); String getName();
/* /*
* Unique ID of the particular service * Unique ID of the particular service
*/ */
public int getId(); int getId();
/* /*
* The workflow method that defines what this service does * The workflow method that defines what this service does
*/ */
public void execute(); void execute();
} }

View File

@ -8,29 +8,29 @@ import java.util.Map;
* On first hit, the cache will be empty and thus any service that is being requested, will be * On first hit, the cache will be empty and thus any service that is being requested, will be
* created fresh and then placed into the cache map. On next hit, if same service name will * created fresh and then placed into the cache map. On next hit, if same service name will
* be requested, it will be returned from the cache * be requested, it will be returned from the cache
* @author saifasif
* *
* @author saifasif
*/ */
public class ServiceCache { public class ServiceCache {
private Map<String, Service> serviceCache; private final Map<String, Service> serviceCache;
public ServiceCache() { public ServiceCache() {
serviceCache = new HashMap<String, Service>(); serviceCache = new HashMap<String, Service>();
} }
/** /**
* Get the service from the cache. null if no service is found matching the * Get the service from the cache. null if no service is found matching the name
* name *
* @param serviceName * @param serviceName a string
* @return {@link Service} * @return {@link Service}
*/ */
public Service getService(String serviceName){ public Service getService(String serviceName) {
Service cachedService = null; Service cachedService = null;
for (String serviceJndiName : serviceCache.keySet()){ for (String serviceJndiName : serviceCache.keySet()) {
if( serviceJndiName.equals( serviceName ) ){ if (serviceJndiName.equals(serviceName)) {
cachedService = serviceCache.get(serviceJndiName); cachedService = serviceCache.get(serviceJndiName);
System.out.println("(cache call) Fetched service " + cachedService.getName() + "("+cachedService.getId()+") from cache... !"); System.out.println("(cache call) Fetched service " + cachedService.getName() + "(" + cachedService.getId() + ") from cache... !");
} }
} }
return cachedService; return cachedService;
@ -38,9 +38,10 @@ public class ServiceCache {
/** /**
* Adds the service into the cache map * Adds the service into the cache map
* @param newService *
* @param newService a {@link Service}
*/ */
public void addService(Service newService){ public void addService(Service newService) {
serviceCache.put(newService.getName(), newService); serviceCache.put(newService.getName(), newService);
} }
} }

View File

@ -4,20 +4,20 @@ package com.iluwatar;
* This is a single service implementation of a sample service. This is the actual * This is a single service implementation of a sample service. This is the actual
* service that will process the request. The reference for this service is to * service that will process the request. The reference for this service is to
* be looked upon in the JNDI server that can be set in the web.xml deployment descriptor * be looked upon in the JNDI server that can be set in the web.xml deployment descriptor
* @author saifasif
* *
* @author saifasif
*/ */
public class ServiceImpl implements Service { public class ServiceImpl implements Service {
private String serviceName; private final String serviceName;
private int id; private final int id;
public ServiceImpl(String serviceName) { public ServiceImpl(String serviceName) {
// set the service name // set the service name
this.serviceName = serviceName; this.serviceName = serviceName;
// Generate a random id to this service object // Generate a random id to this service object
this.id = (int)Math.floor(Math.random()*1000)+1; this.id = (int) Math.floor(Math.random() * 1000) + 1;
} }
@Override @Override

View File

@ -5,7 +5,6 @@ package com.iluwatar;
* Will fetch service from cache, otherwise creates a fresh service and update cache * Will fetch service from cache, otherwise creates a fresh service and update cache
* *
* @author saifasif * @author saifasif
*
*/ */
public class ServiceLocator { public class ServiceLocator {
@ -15,12 +14,13 @@ public class ServiceLocator {
* Fetch the service with the name param from the cache first, * Fetch the service with the name param from the cache first,
* if no service is found, lookup the service from the {@link InitContext} and * if no service is found, lookup the service from the {@link InitContext} and
* then add the newly created service into the cache map for future requests. * then add the newly created service into the cache map for future requests.
* @param serviceJndiName *
* @param serviceJndiName a string
* @return {@link Service} * @return {@link Service}
*/ */
public static Service getService(String serviceJndiName){ public static Service getService(String serviceJndiName) {
Service serviceObj = serviceCache.getService(serviceJndiName); Service serviceObj = serviceCache.getService(serviceJndiName);
if ( serviceObj != null ){ if (serviceObj != null) {
return serviceObj; return serviceObj;
} else { } else {
/* /*
@ -33,5 +33,4 @@ public class ServiceLocator {
return serviceObj; return serviceObj;
} }
} }
} }