Spring4 Singleton Vs Prototype Scope Project

Click here to download eclipse supported ZIP file



This is MainProgram.java file having the source code to execute business logic.


 

    
package com.cv.spring.scope;

import org.apache.log4j.Logger;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

/**
 @author Chandra Vardhan
 */
public class MainProgram {

  private final static Logger LOGGER = Logger.getLogger(MainProgram.class);
  

  public static void main(String[] args) {
    ApplicationContext context = new ClassPathXmlApplicationContext(
        "beans.xml");

    Student defaultStudent = (Studentcontext
        .getBean("defaultStudent");

    LOGGER.info("=========================================================");
    defaultStudent.setMessage("I'm object DefaultStudent");
    LOGGER.info(defaultStudent.getMessage());

    Student defaultStudent2 = (Studentcontext
        .getBean("defaultStudent");
    LOGGER.info(defaultStudent2.getMessage());
    
    
    Student singletonStudent = (Studentcontext
        .getBean("singletonStudent");

    LOGGER.info("=========================================================");
    singletonStudent.setMessage("I'm object SingletonStudent");
    LOGGER.info(singletonStudent.getMessage());

    Student singletonStudent2 = (Studentcontext
        .getBean("singletonStudent");
    LOGGER.info(singletonStudent2.getMessage());

    LOGGER.info("=========================================================");

    Student prototypeStudent = (Studentcontext
        .getBean("prototypeStudent");
    prototypeStudent.setMessage("I'm object PrototypeStudent");
    LOGGER.info(prototypeStudent.getMessage());

    Student prototypeStudent2 = (Studentcontext
        .getBean("prototypeStudent");
    if(prototypeStudent2.getMessage() == null)
    LOGGER.info("null");

  }
}


This is Student.java file having the source code to execute business logic.


 

    
package com.cv.spring.scope;

/**
 @author Chandra Vardhan
 */
public class Student {

  private String message;

  public String getMessage() {
    return message;
  }

  public void setMessage(String message) {
    this.message = message;
  }

}




This is pom.xml file having the entries of dependency jars and information to build the application .


	
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">.0" encoding="UTF-8"?> <modelVersion>4.0.0</modelVersion> <groupId>com.cv.spring.scope</groupId> <artifactId>Spring4SingletonVsPrototypeScope</artifactId> <name>Spring4SingletonVsPrototypeScope</name> <packaging>jar</packaging> <version>1.0</version> <properties> <java-version>1.8</java-version> <log4j-version>1.2.16</log4j-version> <org.springframework-version>4.2.0.RELEASE</org.springframework-version> </properties> <dependencies> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>${org.springframework-version}</version> </dependency> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>${log4j.version}</version> </dependency> </dependencies> <build> <pluginManagement> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.1</version> <configuration> <source>1.8</source> <target>1.8</target> </configuration> </plugin> </plugins> </pluginManagement> </build> </project>


This is beans.xml file having the spring configuration properties.


 
<beans:beans xmlns="http://www.springframework.org/schema/mvc"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:beans="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">

<beans:bean id="defaultStudent" class="com.cv.spring.scope.Student" />
<beans:bean id="singletonStudent" class="com.cv.spring.scope.Student"
scope="singleton" />
<beans:bean id="prototypeStudent" class="com.cv.spring.scope.Student"
scope="prototype" />
</beans:beans>



This is log4j.properties file having the entries for logging the information into the console/file.



#By default enabling Console appender
# Root logger option
log4j.rootLogger=INFO, stdout

# Redirect log messages to console
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%-5p [%c]:%L -->> %m%n

# Redirect log messages to a log file
#log4j.appender.file=org.apache.log4j.RollingFileAppender
#log4j.appender.file.File=C:\servlet-application.log
#log4j.appender.file.MaxFileSize=5MB
#log4j.appender.file.MaxBackupIndex=10
#log4j.appender.file.layout=org.apache.log4j.PatternLayout
#log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n


No comments:

Post a Comment