SlideShare a Scribd company logo
1 of 24
Slide 1




Java Design Pattern
Strategy Pattern


                   Swapnal Agrawal
                   Module Lead

                   Ganesh Kolhe
                   Senior Team Lead
Slide 2




Outline
๏‚ง Overview
๏‚ง Analysis and Design
๏‚ง Module and Client Implementation
๏‚ง Strategy
๏‚ง Variation in the Implementation
๏‚ง Java API Usage
๏‚ง Consequences
Slide 3




Overview
๏‚ง Using different algorithms on some values such as sorting, filters,
  etc.


๏‚ง Applying some logic or calculation to return a value to the client.


๏‚ง Implementing the algorithms in such a way that the correct
  algorithm is provided from different available algorithms on the
  client's request and the required value to the client is returned.
Slide 4




Analysis and Design
๏‚ง There are many solutions and alternatives which seem to be very
  simple and straightforward. Following are two such examples:


   ๏‚ง Separate implementation logic from
      client code.


   ๏‚ง Create a static class with a method
      and if-else or switch case ladder can
      be used to fetch different algorithms.
Slide 5




Module Implementation
public final class Compute {
       public static final int COMPUTE_SUM= 1;
       public static final int COMPUTE_PRODUCT= 2;

      private Compute() {}

       public static double getComputedValue(int type, double
a , double b){
              if (type == COMPUTE_SUM){
                     return a + b;
              }else if (type == COMPUTE_PRODUCT){
                     return a * b;
              }
              throw new IllegalArgumentException();
       }
}
Slide 6




Client Implementation
public class ApplicationClient {
      public static void main(String[] args) {
             System.out.println("Sum = "+
                   Compute.getComputedValue(
                   Compute.COMPUTE_SUM, 20, 25));


             System.out.println("Product = "+
                   Compute.getComputedValue(
                   Compute.COMPUTE_PRODUCT, 7, 3));
      }
}
Slide 7




The Design



             Easy Testing
              Easy Testing

                                        Code Reuse
                                         Code Reuse
                             Easy
                              Easy
                          Maintenance
                          Maintenance

                Easy
                 Easy
             Expansion
              Expansion
Slide 8




The Strategy
Design Pattern Type: Behavioral
Idea: Algorithm
Alias: Policy

๏‚งA class defines many behaviors and these appear as multiple conditional
statements in its operations. Instead of many conditionals, move related
conditional branches into their own Strategy class.
๏‚งStrategy pattern defines family of algorithms, encapsulates each one, and
makes them interchangeable.
๏‚ง Strategy lets algorithms vary independently from clients that use them.
   Calculations are based on the clientsโ€™ abstraction (not using the clientsโ€™
   implementation or global data).
Slide 9




Strategy Implementation
๏‚ง Define a Strategy Interface that is common to all supported
   algorithms.


๏‚ง Strategy Interface defines your Strategy Objectโ€™s behavior.


๏‚ง Implement the Concrete Strategy classes that share the common
   Strategy interface.
Slide 10




The Class Diagram

    Client
     Client


                               <<interface>>
                                <<interface>>
                           IComputeStrategy
                             IComputeStrategy
                            -----------------------
                              -----------------------
                                 Operation()
                                  Operation()




              Concrete
               Concrete         Concrete
                                 Concrete                Concrete
                                                          Concrete
              Strategy1
               Strategy1        Strategy2
                                 Strategy2              Strategyโ€ฆn
                                                         Strategyโ€ฆn
Slide 11




Module Implementation By Using Strategy
public interface IComputeStrategy01 {
       public double getValue(double a, double b);
}

public class ComputeSum01 implements IComputeStrategy01 {
       public double getValue(double a, double b) {
              return a + b;
       }
}

public class ComputeProduct01 implements IComputeStrategy01 {
       public double getValue(double a, double b) {
              return a * b;
       }
}
Slide 12




Client Code Using the Implementation
public class StrategyApplicationClient01 {
       public static void main(String[] args) {

      IComputeStrategy01 compute1 = new ComputeSum01();
      System.out.println("Sum = "+
             compute1.getValue(20, 25));

      IComputeStrategy01 compute2 = new ComputeProduct02();
      System.out.println("Product = "+
             compute2.getValue(7, 3));
      }
}
Slide 13




The Strategy Design



            Easy Testing
             Easy Testing

                                       Code Reuse
                                        Code Reuse
                            Easy
                             Easy
                         Maintenance
                         Maintenance

               Easy
                Easy
            Expansion
             Expansion
Slide 14




Variation In The Implementation
๏‚ง Singleton:

   ๏ƒ˜ Concrete classes as singleton objects.


   ๏ƒ˜ Define a static method to get a singleton instance.
Slide 15




Strategy Implementation By Using Singleton
//singleton implementation
public final class ComputeSum02 implements IComputeStrategy02
{

private static ComputeSum02 computeSum = new ComputeSum02();

private ComputeSum02(){}

public static IComputeStrategy02 getOnlyOneInstance(){
return computeSum;
}

public double getValue(double a, double b) {
return a + b;
}
}
Slide 16




Client - Strategy Implementation By Using Singleton
public class StrategyApplicationClient02 {
       public static void main(String[] args) {

             IComputeStrategy02 compute1 =
                    ComputeSum02.getOnlyOneInstance();
             System.out.println("Sum = "+
                    compute1.getValue(20, 25));

             IComputeStrategy02 compute2 =
                     ComputeProduct02.getOnlyOneInstance();
             System.out.println(โ€œProduct= "+
                    compute2.getValue(7, 3));
      }
}
Slide 17




Another Variation In the Implementation
Context:
  ๏ƒ˜ is configured with a Concrete Strategy object.

  ๏ƒ˜ maintains a private reference to a Strategy object.
  ๏ƒ˜ may define an interface that lets Strategy access its data.



  By changing the Context's Strategy, different behaviors can be
     obtained.
Slide 18




Strategy Implementation By Using Context
public interface IComputeStrategy03 {
        public double getValue(double a, double b);
}
//strategy context implementation
public class StrategyContext03 {
        private IComputeStrategy03 computeStrategy;
        public StrategyContext03 (IComputeStrategy03 computeStrategy){
                this.computeStrategy = computeStrategy;
        }
        public void setComputeStrategy(IComputeStrategy03
computeStrategy){
                this.computeStrategy = computeStrategy;
        }
        public double executeComputeStrategy(double a , double b){
                return computeStrategy.getValue(a, b);
        }
}
Slide 19




Client - Strategy Implementation By Using Context
public class StrategyApplicationClient03 {
 public static void main(String[] args) {

      StrategyContext03 ctx = new StrategyContext03(
             ComputeSum03.getOnlyOneInstance());
      System.out.println("Sum = "+
             ctx.executeComputeStrategy(20, 25));

      ctx.setComputeStratey(
             ComputeProduct03.getOnlyOneInstance());
      System.out.println("Product = "+
      ctx.executeComputeStrategy(7, 3));
      }
}
Slide 20




The Class Diagram

    Client
     Client              Context
                          Context


                                       <<interface>>
                                        <<interface>>
                                    IComputeStrategy
                                     IComputeStrategy
                                     -----------------------
                                      -----------------------
                                         Operation()
                                          Operation()




                    Concrete
                     Concrete            Concrete
                                          Concrete               Concrete
                                                                  Concrete
                    Strategy1
                     Strategy1           Strategy2
                                          Strategy2             Strategyโ€ฆn
                                                                 Strategyโ€ฆn
Slide 21




Java API Usage

                                 checkInputStream and checkOutputStream uses the
Java.util.zip
                                 strategy pattern to compute checksums on byte stream.


                                 compare(), executed by among
Java.util.comparator
                                 others Collections#sort().


                                 the service() and all doXXX() methods take
                                 HttpServletRequest and HttpServletResponse and the
Javax.servlet.http.HttpServlet
                                 implementor has to process them (and not to get hold
                                 of them as instance variables!).
Slide 22




Consequences
๏‚ง Benefits
  ๏ƒ˜ Provides an alternative to sub classing the Context class to get a variety
    of algorithms or behaviors.
  ๏ƒ˜ Eliminates large conditional statements.

  ๏ƒ˜ Provides a choice of implementations for the same behavior.



๏‚ง Shortcomings
  ๏ƒ˜ Increases the number of objects.

  ๏ƒ˜ All algorithms must use the same Strategy interface.



  Think twice before implementing the Strategy pattern or any other design
     pattern to match your requirements.
Slide 23




About Cross Country Infotech
Cross Country Infotech (CCI) Pvt. Ltd. is a part of the Cross Country Healthcare (NYSE:
CCRN) group of companies. CCI specializes in providing a gamut of IT/ITES services and
is well equipped with technical expertise to provide smarter solutions to its customers.
Some of our cutting-edge technology offerings include Mobile, Web and BI Application
Development; ECM and Informix 4GL Solutions; and Technical Documentation, UI
Design and Testing services.
Slide 24




Thank You!

More Related Content

Similar to Strategy design pattern

Guice tutorial
Guice tutorialGuice tutorial
Guice tutorial
Anh Quรขn
ย 
Devoxx 2012 (v2)
Devoxx 2012 (v2)Devoxx 2012 (v2)
Devoxx 2012 (v2)
Jerome Dochez
ย 

Similar to Strategy design pattern (20)

Strategy Design Pattern
Strategy Design PatternStrategy Design Pattern
Strategy Design Pattern
ย 
Google GIN
Google GINGoogle GIN
Google GIN
ย 
Guice tutorial
Guice tutorialGuice tutorial
Guice tutorial
ย 
Dependency Injection for Android
Dependency Injection for AndroidDependency Injection for Android
Dependency Injection for Android
ย 
Dependency Injection for Android @ Ciklum speakers corner Kiev 29. May 2014
Dependency Injection for Android @ Ciklum speakers corner Kiev 29. May 2014Dependency Injection for Android @ Ciklum speakers corner Kiev 29. May 2014
Dependency Injection for Android @ Ciklum speakers corner Kiev 29. May 2014
ย 
Quickly Testing Qt Desktop Applications
Quickly Testing Qt Desktop ApplicationsQuickly Testing Qt Desktop Applications
Quickly Testing Qt Desktop Applications
ย 
Java programming concept
Java programming conceptJava programming concept
Java programming concept
ย 
Guide to Generate Extent Report in Kotlin
Guide to Generate Extent Report in KotlinGuide to Generate Extent Report in Kotlin
Guide to Generate Extent Report in Kotlin
ย 
Continuous Integration and Continuous Deployment (CI/CD) with WSO2 Enterprise...
Continuous Integration and Continuous Deployment (CI/CD) with WSO2 Enterprise...Continuous Integration and Continuous Deployment (CI/CD) with WSO2 Enterprise...
Continuous Integration and Continuous Deployment (CI/CD) with WSO2 Enterprise...
ย 
Exploring CameraX from JetPack
Exploring CameraX from JetPackExploring CameraX from JetPack
Exploring CameraX from JetPack
ย 
C# Tutorial MSM_Murach chapter-15-slides
C# Tutorial MSM_Murach chapter-15-slidesC# Tutorial MSM_Murach chapter-15-slides
C# Tutorial MSM_Murach chapter-15-slides
ย 
Unit Testing Using Mockito in Android (1).pdf
Unit Testing Using Mockito in Android (1).pdfUnit Testing Using Mockito in Android (1).pdf
Unit Testing Using Mockito in Android (1).pdf
ย 
Introduction to Configurator 2.0 architecture design
Introduction to Configurator 2.0 architecture designIntroduction to Configurator 2.0 architecture design
Introduction to Configurator 2.0 architecture design
ย 
The real beginner's guide to android testing
The real beginner's guide to android testingThe real beginner's guide to android testing
The real beginner's guide to android testing
ย 
Creating sub zero dashboard plugin for apex with google
Creating sub zero dashboard plugin for apex with googleCreating sub zero dashboard plugin for apex with google
Creating sub zero dashboard plugin for apex with google
ย 
Open Source ERP Technologies for Java Developers
Open Source ERP Technologies for Java DevelopersOpen Source ERP Technologies for Java Developers
Open Source ERP Technologies for Java Developers
ย 
Unit Testing Frameworks: A comparative study
Unit Testing Frameworks: A comparative studyUnit Testing Frameworks: A comparative study
Unit Testing Frameworks: A comparative study
ย 
The MirAL Story
The MirAL StoryThe MirAL Story
The MirAL Story
ย 
Devoxx 2012 (v2)
Devoxx 2012 (v2)Devoxx 2012 (v2)
Devoxx 2012 (v2)
ย 
Introduction to cython: example of GCoptimization
Introduction to cython: example of GCoptimizationIntroduction to cython: example of GCoptimization
Introduction to cython: example of GCoptimization
ย 

Recently uploaded

DragonBall PowerPoint Template for demo.pptx
DragonBall PowerPoint Template for demo.pptxDragonBall PowerPoint Template for demo.pptx
DragonBall PowerPoint Template for demo.pptx
mirandajeremy200221
ย 
Design Inspiration for College by Slidesgo.pptx
Design Inspiration for College by Slidesgo.pptxDesign Inspiration for College by Slidesgo.pptx
Design Inspiration for College by Slidesgo.pptx
TusharBahuguna2
ย 
SD_The MATATAG Curriculum Training Design.pptx
SD_The MATATAG Curriculum Training Design.pptxSD_The MATATAG Curriculum Training Design.pptx
SD_The MATATAG Curriculum Training Design.pptx
janettecruzeiro1
ย 
VVIP CALL GIRLS Lucknow ๐Ÿ’“ Lucknow < Renuka Sharma > 7877925207 Escorts Service
VVIP CALL GIRLS Lucknow ๐Ÿ’“ Lucknow < Renuka Sharma > 7877925207 Escorts ServiceVVIP CALL GIRLS Lucknow ๐Ÿ’“ Lucknow < Renuka Sharma > 7877925207 Escorts Service
VVIP CALL GIRLS Lucknow ๐Ÿ’“ Lucknow < Renuka Sharma > 7877925207 Escorts Service
aroranaina404
ย 
CALL ON โžฅ8923113531 ๐Ÿ”Call Girls Aminabad Lucknow best Night Fun service
CALL ON โžฅ8923113531 ๐Ÿ”Call Girls Aminabad Lucknow best Night Fun serviceCALL ON โžฅ8923113531 ๐Ÿ”Call Girls Aminabad Lucknow best Night Fun service
CALL ON โžฅ8923113531 ๐Ÿ”Call Girls Aminabad Lucknow best Night Fun service
anilsa9823
ย 
call girls in Dakshinpuri (DELHI) ๐Ÿ” >เผ’9953056974 ๐Ÿ” genuine Escort Service ๐Ÿ”โœ”๏ธโœ”๏ธ
call girls in Dakshinpuri  (DELHI) ๐Ÿ” >เผ’9953056974 ๐Ÿ” genuine Escort Service ๐Ÿ”โœ”๏ธโœ”๏ธcall girls in Dakshinpuri  (DELHI) ๐Ÿ” >เผ’9953056974 ๐Ÿ” genuine Escort Service ๐Ÿ”โœ”๏ธโœ”๏ธ
call girls in Dakshinpuri (DELHI) ๐Ÿ” >เผ’9953056974 ๐Ÿ” genuine Escort Service ๐Ÿ”โœ”๏ธโœ”๏ธ
9953056974 Low Rate Call Girls In Saket, Delhi NCR
ย 
Peaches App development presentation deck
Peaches App development presentation deckPeaches App development presentation deck
Peaches App development presentation deck
tbatkhuu1
ย 
FULL ENJOY Call Girls In Mahipalpur Delhi Contact Us 8377877756
FULL ENJOY Call Girls In Mahipalpur Delhi Contact Us 8377877756FULL ENJOY Call Girls In Mahipalpur Delhi Contact Us 8377877756
FULL ENJOY Call Girls In Mahipalpur Delhi Contact Us 8377877756
dollysharma2066
ย 
young call girls in Vivek Vihar๐Ÿ” 9953056974 ๐Ÿ” Delhi escort Service
young call girls in Vivek Vihar๐Ÿ” 9953056974 ๐Ÿ” Delhi escort Serviceyoung call girls in Vivek Vihar๐Ÿ” 9953056974 ๐Ÿ” Delhi escort Service
young call girls in Vivek Vihar๐Ÿ” 9953056974 ๐Ÿ” Delhi escort Service
9953056974 Low Rate Call Girls In Saket, Delhi NCR
ย 
infant assessment fdbbdbdddinal ppt.pptx
infant assessment fdbbdbdddinal ppt.pptxinfant assessment fdbbdbdddinal ppt.pptx
infant assessment fdbbdbdddinal ppt.pptx
suhanimunjal27
ย 

Recently uploaded (20)

DragonBall PowerPoint Template for demo.pptx
DragonBall PowerPoint Template for demo.pptxDragonBall PowerPoint Template for demo.pptx
DragonBall PowerPoint Template for demo.pptx
ย 
Booking open Available Pune Call Girls Nanded City 6297143586 Call Hot India...
Booking open Available Pune Call Girls Nanded City  6297143586 Call Hot India...Booking open Available Pune Call Girls Nanded City  6297143586 Call Hot India...
Booking open Available Pune Call Girls Nanded City 6297143586 Call Hot India...
ย 
Pooja 9892124323, Call girls Services and Mumbai Escort Service Near Hotel Gi...
Pooja 9892124323, Call girls Services and Mumbai Escort Service Near Hotel Gi...Pooja 9892124323, Call girls Services and Mumbai Escort Service Near Hotel Gi...
Pooja 9892124323, Call girls Services and Mumbai Escort Service Near Hotel Gi...
ย 
Design Inspiration for College by Slidesgo.pptx
Design Inspiration for College by Slidesgo.pptxDesign Inspiration for College by Slidesgo.pptx
Design Inspiration for College by Slidesgo.pptx
ย 
Best VIP Call Girls Noida Sector 44 Call Me: 8448380779
Best VIP Call Girls Noida Sector 44 Call Me: 8448380779Best VIP Call Girls Noida Sector 44 Call Me: 8448380779
Best VIP Call Girls Noida Sector 44 Call Me: 8448380779
ย 
Kala jadu for love marriage | Real amil baba | Famous amil baba | kala jadu n...
Kala jadu for love marriage | Real amil baba | Famous amil baba | kala jadu n...Kala jadu for love marriage | Real amil baba | Famous amil baba | kala jadu n...
Kala jadu for love marriage | Real amil baba | Famous amil baba | kala jadu n...
ย 
Pooja 9892124323, Call girls Services and Mumbai Escort Service Near Hotel Hy...
Pooja 9892124323, Call girls Services and Mumbai Escort Service Near Hotel Hy...Pooja 9892124323, Call girls Services and Mumbai Escort Service Near Hotel Hy...
Pooja 9892124323, Call girls Services and Mumbai Escort Service Near Hotel Hy...
ย 
SD_The MATATAG Curriculum Training Design.pptx
SD_The MATATAG Curriculum Training Design.pptxSD_The MATATAG Curriculum Training Design.pptx
SD_The MATATAG Curriculum Training Design.pptx
ย 
VVIP CALL GIRLS Lucknow ๐Ÿ’“ Lucknow < Renuka Sharma > 7877925207 Escorts Service
VVIP CALL GIRLS Lucknow ๐Ÿ’“ Lucknow < Renuka Sharma > 7877925207 Escorts ServiceVVIP CALL GIRLS Lucknow ๐Ÿ’“ Lucknow < Renuka Sharma > 7877925207 Escorts Service
VVIP CALL GIRLS Lucknow ๐Ÿ’“ Lucknow < Renuka Sharma > 7877925207 Escorts Service
ย 
Case Study of Hotel Taj Vivanta, Pune
Case Study of Hotel Taj Vivanta, PuneCase Study of Hotel Taj Vivanta, Pune
Case Study of Hotel Taj Vivanta, Pune
ย 
The_Canvas_of_Creative_Mastery_Newsletter_April_2024_Version.pdf
The_Canvas_of_Creative_Mastery_Newsletter_April_2024_Version.pdfThe_Canvas_of_Creative_Mastery_Newsletter_April_2024_Version.pdf
The_Canvas_of_Creative_Mastery_Newsletter_April_2024_Version.pdf
ย 
CALL ON โžฅ8923113531 ๐Ÿ”Call Girls Aminabad Lucknow best Night Fun service
CALL ON โžฅ8923113531 ๐Ÿ”Call Girls Aminabad Lucknow best Night Fun serviceCALL ON โžฅ8923113531 ๐Ÿ”Call Girls Aminabad Lucknow best Night Fun service
CALL ON โžฅ8923113531 ๐Ÿ”Call Girls Aminabad Lucknow best Night Fun service
ย 
call girls in Dakshinpuri (DELHI) ๐Ÿ” >เผ’9953056974 ๐Ÿ” genuine Escort Service ๐Ÿ”โœ”๏ธโœ”๏ธ
call girls in Dakshinpuri  (DELHI) ๐Ÿ” >เผ’9953056974 ๐Ÿ” genuine Escort Service ๐Ÿ”โœ”๏ธโœ”๏ธcall girls in Dakshinpuri  (DELHI) ๐Ÿ” >เผ’9953056974 ๐Ÿ” genuine Escort Service ๐Ÿ”โœ”๏ธโœ”๏ธ
call girls in Dakshinpuri (DELHI) ๐Ÿ” >เผ’9953056974 ๐Ÿ” genuine Escort Service ๐Ÿ”โœ”๏ธโœ”๏ธ
ย 
Peaches App development presentation deck
Peaches App development presentation deckPeaches App development presentation deck
Peaches App development presentation deck
ย 
call girls in Kaushambi (Ghaziabad) ๐Ÿ” >เผ’8448380779 ๐Ÿ” genuine Escort Service ๐Ÿ”...
call girls in Kaushambi (Ghaziabad) ๐Ÿ” >เผ’8448380779 ๐Ÿ” genuine Escort Service ๐Ÿ”...call girls in Kaushambi (Ghaziabad) ๐Ÿ” >เผ’8448380779 ๐Ÿ” genuine Escort Service ๐Ÿ”...
call girls in Kaushambi (Ghaziabad) ๐Ÿ” >เผ’8448380779 ๐Ÿ” genuine Escort Service ๐Ÿ”...
ย 
VVIP Pune Call Girls Hadapsar (7001035870) Pune Escorts Nearby with Complete ...
VVIP Pune Call Girls Hadapsar (7001035870) Pune Escorts Nearby with Complete ...VVIP Pune Call Girls Hadapsar (7001035870) Pune Escorts Nearby with Complete ...
VVIP Pune Call Girls Hadapsar (7001035870) Pune Escorts Nearby with Complete ...
ย 
Best VIP Call Girls Noida Sector 47 Call Me: 8448380779
Best VIP Call Girls Noida Sector 47 Call Me: 8448380779Best VIP Call Girls Noida Sector 47 Call Me: 8448380779
Best VIP Call Girls Noida Sector 47 Call Me: 8448380779
ย 
FULL ENJOY Call Girls In Mahipalpur Delhi Contact Us 8377877756
FULL ENJOY Call Girls In Mahipalpur Delhi Contact Us 8377877756FULL ENJOY Call Girls In Mahipalpur Delhi Contact Us 8377877756
FULL ENJOY Call Girls In Mahipalpur Delhi Contact Us 8377877756
ย 
young call girls in Vivek Vihar๐Ÿ” 9953056974 ๐Ÿ” Delhi escort Service
young call girls in Vivek Vihar๐Ÿ” 9953056974 ๐Ÿ” Delhi escort Serviceyoung call girls in Vivek Vihar๐Ÿ” 9953056974 ๐Ÿ” Delhi escort Service
young call girls in Vivek Vihar๐Ÿ” 9953056974 ๐Ÿ” Delhi escort Service
ย 
infant assessment fdbbdbdddinal ppt.pptx
infant assessment fdbbdbdddinal ppt.pptxinfant assessment fdbbdbdddinal ppt.pptx
infant assessment fdbbdbdddinal ppt.pptx
ย 

Strategy design pattern

  • 1. Slide 1 Java Design Pattern Strategy Pattern Swapnal Agrawal Module Lead Ganesh Kolhe Senior Team Lead
  • 2. Slide 2 Outline ๏‚ง Overview ๏‚ง Analysis and Design ๏‚ง Module and Client Implementation ๏‚ง Strategy ๏‚ง Variation in the Implementation ๏‚ง Java API Usage ๏‚ง Consequences
  • 3. Slide 3 Overview ๏‚ง Using different algorithms on some values such as sorting, filters, etc. ๏‚ง Applying some logic or calculation to return a value to the client. ๏‚ง Implementing the algorithms in such a way that the correct algorithm is provided from different available algorithms on the client's request and the required value to the client is returned.
  • 4. Slide 4 Analysis and Design ๏‚ง There are many solutions and alternatives which seem to be very simple and straightforward. Following are two such examples: ๏‚ง Separate implementation logic from client code. ๏‚ง Create a static class with a method and if-else or switch case ladder can be used to fetch different algorithms.
  • 5. Slide 5 Module Implementation public final class Compute { public static final int COMPUTE_SUM= 1; public static final int COMPUTE_PRODUCT= 2; private Compute() {} public static double getComputedValue(int type, double a , double b){ if (type == COMPUTE_SUM){ return a + b; }else if (type == COMPUTE_PRODUCT){ return a * b; } throw new IllegalArgumentException(); } }
  • 6. Slide 6 Client Implementation public class ApplicationClient { public static void main(String[] args) { System.out.println("Sum = "+ Compute.getComputedValue( Compute.COMPUTE_SUM, 20, 25)); System.out.println("Product = "+ Compute.getComputedValue( Compute.COMPUTE_PRODUCT, 7, 3)); } }
  • 7. Slide 7 The Design Easy Testing Easy Testing Code Reuse Code Reuse Easy Easy Maintenance Maintenance Easy Easy Expansion Expansion
  • 8. Slide 8 The Strategy Design Pattern Type: Behavioral Idea: Algorithm Alias: Policy ๏‚งA class defines many behaviors and these appear as multiple conditional statements in its operations. Instead of many conditionals, move related conditional branches into their own Strategy class. ๏‚งStrategy pattern defines family of algorithms, encapsulates each one, and makes them interchangeable. ๏‚ง Strategy lets algorithms vary independently from clients that use them. Calculations are based on the clientsโ€™ abstraction (not using the clientsโ€™ implementation or global data).
  • 9. Slide 9 Strategy Implementation ๏‚ง Define a Strategy Interface that is common to all supported algorithms. ๏‚ง Strategy Interface defines your Strategy Objectโ€™s behavior. ๏‚ง Implement the Concrete Strategy classes that share the common Strategy interface.
  • 10. Slide 10 The Class Diagram Client Client <<interface>> <<interface>> IComputeStrategy IComputeStrategy ----------------------- ----------------------- Operation() Operation() Concrete Concrete Concrete Concrete Concrete Concrete Strategy1 Strategy1 Strategy2 Strategy2 Strategyโ€ฆn Strategyโ€ฆn
  • 11. Slide 11 Module Implementation By Using Strategy public interface IComputeStrategy01 { public double getValue(double a, double b); } public class ComputeSum01 implements IComputeStrategy01 { public double getValue(double a, double b) { return a + b; } } public class ComputeProduct01 implements IComputeStrategy01 { public double getValue(double a, double b) { return a * b; } }
  • 12. Slide 12 Client Code Using the Implementation public class StrategyApplicationClient01 { public static void main(String[] args) { IComputeStrategy01 compute1 = new ComputeSum01(); System.out.println("Sum = "+ compute1.getValue(20, 25)); IComputeStrategy01 compute2 = new ComputeProduct02(); System.out.println("Product = "+ compute2.getValue(7, 3)); } }
  • 13. Slide 13 The Strategy Design Easy Testing Easy Testing Code Reuse Code Reuse Easy Easy Maintenance Maintenance Easy Easy Expansion Expansion
  • 14. Slide 14 Variation In The Implementation ๏‚ง Singleton: ๏ƒ˜ Concrete classes as singleton objects. ๏ƒ˜ Define a static method to get a singleton instance.
  • 15. Slide 15 Strategy Implementation By Using Singleton //singleton implementation public final class ComputeSum02 implements IComputeStrategy02 { private static ComputeSum02 computeSum = new ComputeSum02(); private ComputeSum02(){} public static IComputeStrategy02 getOnlyOneInstance(){ return computeSum; } public double getValue(double a, double b) { return a + b; } }
  • 16. Slide 16 Client - Strategy Implementation By Using Singleton public class StrategyApplicationClient02 { public static void main(String[] args) { IComputeStrategy02 compute1 = ComputeSum02.getOnlyOneInstance(); System.out.println("Sum = "+ compute1.getValue(20, 25)); IComputeStrategy02 compute2 = ComputeProduct02.getOnlyOneInstance(); System.out.println(โ€œProduct= "+ compute2.getValue(7, 3)); } }
  • 17. Slide 17 Another Variation In the Implementation Context: ๏ƒ˜ is configured with a Concrete Strategy object. ๏ƒ˜ maintains a private reference to a Strategy object. ๏ƒ˜ may define an interface that lets Strategy access its data. By changing the Context's Strategy, different behaviors can be obtained.
  • 18. Slide 18 Strategy Implementation By Using Context public interface IComputeStrategy03 { public double getValue(double a, double b); } //strategy context implementation public class StrategyContext03 { private IComputeStrategy03 computeStrategy; public StrategyContext03 (IComputeStrategy03 computeStrategy){ this.computeStrategy = computeStrategy; } public void setComputeStrategy(IComputeStrategy03 computeStrategy){ this.computeStrategy = computeStrategy; } public double executeComputeStrategy(double a , double b){ return computeStrategy.getValue(a, b); } }
  • 19. Slide 19 Client - Strategy Implementation By Using Context public class StrategyApplicationClient03 { public static void main(String[] args) { StrategyContext03 ctx = new StrategyContext03( ComputeSum03.getOnlyOneInstance()); System.out.println("Sum = "+ ctx.executeComputeStrategy(20, 25)); ctx.setComputeStratey( ComputeProduct03.getOnlyOneInstance()); System.out.println("Product = "+ ctx.executeComputeStrategy(7, 3)); } }
  • 20. Slide 20 The Class Diagram Client Client Context Context <<interface>> <<interface>> IComputeStrategy IComputeStrategy ----------------------- ----------------------- Operation() Operation() Concrete Concrete Concrete Concrete Concrete Concrete Strategy1 Strategy1 Strategy2 Strategy2 Strategyโ€ฆn Strategyโ€ฆn
  • 21. Slide 21 Java API Usage checkInputStream and checkOutputStream uses the Java.util.zip strategy pattern to compute checksums on byte stream. compare(), executed by among Java.util.comparator others Collections#sort(). the service() and all doXXX() methods take HttpServletRequest and HttpServletResponse and the Javax.servlet.http.HttpServlet implementor has to process them (and not to get hold of them as instance variables!).
  • 22. Slide 22 Consequences ๏‚ง Benefits ๏ƒ˜ Provides an alternative to sub classing the Context class to get a variety of algorithms or behaviors. ๏ƒ˜ Eliminates large conditional statements. ๏ƒ˜ Provides a choice of implementations for the same behavior. ๏‚ง Shortcomings ๏ƒ˜ Increases the number of objects. ๏ƒ˜ All algorithms must use the same Strategy interface. Think twice before implementing the Strategy pattern or any other design pattern to match your requirements.
  • 23. Slide 23 About Cross Country Infotech Cross Country Infotech (CCI) Pvt. Ltd. is a part of the Cross Country Healthcare (NYSE: CCRN) group of companies. CCI specializes in providing a gamut of IT/ITES services and is well equipped with technical expertise to provide smarter solutions to its customers. Some of our cutting-edge technology offerings include Mobile, Web and BI Application Development; ECM and Informix 4GL Solutions; and Technical Documentation, UI Design and Testing services.

Editor's Notes

  1. Project Name
  2. Project Name
  3. Project Name