Skip to main content

Spring : Detailed Example for bean creation and management

Now Objects which are used in the application have some data which is either loaded from the
Database or provided by the user as input i.e.in both the cases the data becomes available at the time
of execution. To get the object initialize either from user input or from database factory method is
used.
In the application example 1; Two beans were configured by the name “num1” and “num2” with fixed values given by the programmer. Whenever these beans will be requested they will have same values.
In real application scenario different users want to provide the different values to their objects.
It can be facilitated by concerting the direct object creation approach to indirect object creating
approach i.e. we can add static factory methods to Complex.java and Rational.java to create and
initialize their object from the user input.
Now Application Example 1 is looks like the following:
1. Number.java
package com.jubilation.spring.user;
public interface Number {
public Number add(Number n);
public void display();
}
2. Complex.java
package com.jubilation.spring.user;
public class Complex implements Number {
private int real, img;
public Complex(int real, int img) {
this.real = real;
this.img = img;
}
@Override
public Number add(Number n) {
Complex c = (Complex) n;
int real = this.real + c.real;
int img = this.img + c.img;
return new Complex(real, img);
}
@Override
public void display() {
System.out.println("The Number is :" + real + "+" + img + "i");
}
public static Number getNumber()
{
Scanner in= new Scanner(System.in);
System.out.println(“Enter the real part”);
int r=in.nextInt();
System.out.println(“Enter the imaginary part”);
int i=in.nextInt();
return new Complex(r,i);
} }
3. Rational.java
package com.jubilation.spring.user;
public class Rational implements Number{
private int p, q;
public Rational(int p, int q) {
this.p = p;
this.q = q;
}
@Override
public Number add(Number n) {
Rational r = (Rational) n;
int p= this.p*r.q + this.q*r.p;
int q = this.p* r.q;
return new Rational(p, q);
}
@Override
public void display() {
System.out.println("The Number is :" + p + "/" + q);
}
public static Number getNumber()
{
Scanner in= new Scanner(System.in);
System.out.println(“Enter the denominator”);
int p=in.nextInt();
System.out.println(“Enter the numerator”);
int q=in.nextInt();
return new Rational(p,q);
}}
4. IOCUser.java
package com.jubilation.spring.user;
import org.springframework.beans.factory.BeanFactory;
public class IOCUser {
public static void main(String[] args) {
// TODO code application logic here
BeanFactory factory = MyFactory.getBeanFactory();
Number n1 = (Number) factory.getBean("num");
Number n2 = (Number) factory.getBean("num");
Number n3 = n1.add(n2);
n3.display();
Number N1 = (Number) factory.getBean("num");
Number N2 = (Number) factory.getBean("num");
Number N3 = N1.add(N2);
N3.display();
}
}
5. MyFactory.java
package com.jubilation.spring.user;
import org.springframework.beans.factory.BeanFactory;
import org.springframework.beans.factory.xml.XmlBeanFactory;
import org.springframework.core.io.ClassPathResource;
import org.springframework.core.io.Resource;
public class MyFactory {
private static BeanFactory factory;
static{
Resource resource=new ClassPathResource("beanscfg.xml");
factory=new XmlBeanFactory(resource);
}
public static BeanFactory getBeanFactory() {
return factory;
}
}
6. Beanscfg.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd">
<bean id="num"
class="com.jubilation.spring.user.Complex"
scope=”prototype”
factory-method=”getNumber”>
</bean>
</beans>
Now only one bean with id “num” is used because each time new object is created as we changed the
scope default to prototype.
Adding the factory method to each implementation is not a good idea sometimes it creates some
trouble same class static factory method approach can’t be used when the source code of the classes
to be instantiated is not available i.e. classes in jar file.In such scenario different class static factory method approach can be used. Let’s assume that we
don’t have the source code of the Relational and Complex classes but their objects are to be created
using the factory method. It can be done by defining the factory class as follows:
1. NumberFactory.java
package com.jubilation.spring.user;
public class NumberFactory {
public Number getRational()
{
Scanner in= new Scanner(System.in);
System.out.println(“Enter the denominator”);
int p=in.nextInt();
System.out.println(“Enter the numerator”);
int q=in.nextInt();
return new Rational(p,q);
}
public Number getComplex()
{
Scanner in= new Scanner(System.in);
System.out.println(“Enter the real part”);
int r=in.nextInt();
System.out.println(“Enter the imaginary part”);
int i=in.nextInt();
return new Complex(r,i);
} }
And the factory methods will be removed from the implementing classes and putted into a separate
class.
Now the configuration file will look like this:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd">
<bean id="num"
class="com.jubilation.spring.user.NumberFactory"
scope=”prototype”
factory-method=”getRational”>
</bean>
</beans>
But this approach will not be good if a tie will have multiple implementations, each implementation is to be instantiated with the help of factory method. For example:
Number interface has two implementations by the name Complex and Rational in case of different class static factory we need to provide the two factory methods by the name getComplex and getRational i.e. in this approach a factory method for each implementation will need to be exposed to the end user such implementation will nullify the advantage of Interfaces. Each time a new implementation is provided or an existing implementation is needed application programmer need to be notified.
To solve this problem there should be one generalized factory method for all the implementation such
a method need some input from the user to decide which implementation is to be instantiated. The problem with spring is that we can’t pass parameters to the factory methods. This limitation can
be overcome if the static factory is to be non-static because we can pass parameters to the constructor.
It can be done by defining the factory class as follows:
1. NumberFactory.java
package com.jubilation.spring.user;
public class NumberFactory {
private String numType;
public NumberFactory(String nType)
{
numType=nType;
}
public number getNumber()
{i
f(numType.equalsIgnoreCase(“Rational”))
return getRational();
if(numType.equalsIgnoreCase(“Complex”))
return getComplex();
}
private Number getRational()
{
Scanner in= new Scanner(System.in);
System.out.println(“Enter the denominator”);
int p=in.nextInt();
System.out.println(“Enter the numerator”);
int q=in.nextInt();
return new Rational(p,q);
}
private Number getComplex()
{
Scanner in= new Scanner(System.in);
System.out.println(“Enter the real part”);
int r=in.nextInt();
System.out.println(“Enter the imaginary part”);
int i=in.nextInt();
return new Complex(r,i);
}}
Now the configuration file will look like this:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd">
<bean id="cf" class="com.jubilation.spring.user.NumberFactory" >
<constructor-arg value=”Complex”/>
</bean>
<bean id="rf" class="com.jubilation.spring.user.NumberFactory" >
<constructor-arg value=”Rational”/>
</bean>
<bean id="num"
scope=”prototype”
factory-bean=”cf”
factory-method=”getNumber”>
</bean>
</beans>

Note: Spring can make objects even factory method is private or constructor is private.

Comments

Top 5 Most Read Posts

Who is Peter Lynch and what is his philosophy in equity market investment? 25 Golden Rules of the most successful Fund Manager.

Peter Lynch (born January 19, 1944) is an American investor, mutual fund manager, and philanthropist. As the manager of the Magellan Fund at Fidelity Investments between 1977 and 1990, Lynch averaged a 29.2% annual return, consistently more than doubling the S&P 500 stock market index and making it the best-performing mutual fund in the world. During his 13 year tenure, assets under management increased from $18 million to $14 billion. He also co-authored a number of books and papers on investing and coined a number of well known mantras of modern individual investing strategies, such as Invest in what you know and ten bagger. Lynch is consistently described as a "legend" by the financial media for his performance record. Base on his career I have compiled his investing rules here. 25 GOLDEN RULES by @Peter Lynch 1: Nobody can predict interest rates, the future direction of the economy or the stock market. Dismiss all such forecasts & concentrate on what's actual...

What is version checking in Hibernate ?

Version checking used in hibernate when more then one thread trying to access same data. For example : User A edit the row of the TABLE for update ( In the User Interface changing data This is user thinking time) and in the same time User B edit the same record for update and click the update. Then User A click the Update and update done. Change made by user B is gone. In hibernate you can prevent slate object updation using version checking. Check the version of the row when you are updating the row. Get the version of the row when you are fetching the row of the TABLE for update. On the time of updation just fetch the version number and match with your version number (on the time of fetching).

What is wrong with HDFC securities? Are they doing some fraudulent activities or just causing issues with their platform as usually it don't work during market hours?

I have opened a DEMAT account with HDFC Securities in 2019 as HDFC group is well known for the customer services and I also hold a salary account with HDFC Bank, DEMAT account with the following conditions/offers as expressed by the executive. Trading Account Opening Charges (One Time) :  ₹999 (At that time it offered on lower price, I forget the exact price) Trading Annual Maintenance Charges AMC (Yearly Fee) : ₹0 Demat Account Opening Charges (One Time) : ₹0 Demat Account Annual Maintenance Charges AMC (Yearly Fee) : ₹750, nil if portfolio value below ₹2 lacs. Equity Delivery : 0.50% Equity Intraday : 0.05% Equity Futures : 0.05% Equity Options : ₹100 per lot or 1% of the premium (whichever is higher) Currency Futures : ₹23 per contract Currency Options : ₹20 per contract Commodity Futures : 0.02% for Intraday / 0.025% for positional Commodity Options : 0.02% for Intraday / 0.025% for positional It was going good but after 2-3 months I got to know that there are...

Fundamental Analysis : Asian Paints Ltd.

Asian Paints group is the largest paint manufacturer in India also engaged in the business of manufacturing of varnishes, enamels or lacquers, surfacing preparation, organic composite solvents and thinners. It operates in 15 countries and has 26 paint manufacturing facilities in the world serving consumers in over 60 countries. Besides Asian Paints, the group operates around the world through its various brands viz. Asian Paints Berger, Apco Coatings, SCIB Paints, Taubmans, Causeway Paints and Kadisco Asian Paints. It also manufactures metal sanitary ware such as bath, sinks, washbasins and similar articles. Recently introduced Lightings, Furnishings and Furniture thus adding more products in the Home décor and Interior Design category. Market Cap ₹ 244,763 Cr. Current Price ₹ 2,552 High / Low ₹ 2,873 / 1,483 Stock P/E 89.0 Book Value ₹ 115 Dividend Yield 0.47 % ROCE 33.8 % ROE 27.5 % Face Value ₹ 1.00 Price to book value 22.2 EPS ₹ 28.7 High price all time ₹ 2,873 Low price all time ₹...

What are JEE Containers? What are their different types?

Containers are the interface between a component and the low-level, platform-specific functionality that supports the component. Before it can be executed, a web, enterprise bean, or application client component must be assembled into a Java EE module and deployed into its container. The assembly process involves specifying container settings for each component in the Java EE application and for the Java EE application itself. Container settings customize the underlying support provided by the Java EE server, including such services as security, transaction management, Java Naming and Directory Interface (JNDI) API lookups, and remote connectivity. Here are some of the highlights. The Java EE security model lets you configure a web component or enterprise bean so that system resources are accessed only by authorized users. The Java EE transaction model lets you specify relationships among methods that make up a single transaction so that all methods in one transaction are treated as a ...