120 likes | 235 Views
Computer Science 313 – Advanced Programming Topics. Lecture 19: Command Pattern. Strategy Pattern. Define interface for family of algorithms Encapsulate algorithm in class of its own Algorithm instance held in field of Context class Delegate responsibility for action to this object
E N D
Computer Science 313 – Advanced Programming Topics Lecture 19:Command Pattern
Strategy Pattern • Defineinterface for family of algorithms • Encapsulate algorithm in class of its own • Algorithm instance held in field of Context class • Delegate responsibility for action to this object • Set field to change algorithm dynamically
Limits To Strategy • Several limitations to strategy pattern • Details of Strategy must be known by Context • Context must execute actual Strategy • Strategy should not maintain state • Cannot determine past Strategys
Limits To Strategy • Several limitations to strategy pattern • Details of Strategy must be known by Context • Context must execute actual Strategy • Strategy should not maintain state • Cannot determine past Strategys
Why Is This A Problem? • Unable to log steps taken during program • But a Strategy is not a tangible object • Cannot undo a Strategy once executed • To enable “undo” would need log of actions • But Strategy lacks state to save actual results • Strategyindependent of Context • Cannot use external objects when executed • Specific context cannot host a Strategy
Command Pattern • Encapsulates single action as an object • Each instance can be used one or more times • Define range of actions in abstract Command • But pattern has one way to execute Command • Adjust the state of a Command using fields • Modify how it executes and what it does • Use to specify which instance Command uses • More than parameters to control exposed method
Command Pattern Intent • Encapsulate single request within an instance • Client code can then pass requests as parameter • Pattern treats Command as normal object • Queue Commands to execute in certain order • Once executed, record Commands in log
Command Pattern Usage • Commands support undo & redo options • Additional method in Commandfor undo support • Use Command’s state to record what it did • Stack holds Commands once executed • Actions then are un-done by popping Commands
Command Pattern Intent • Split execution from performance • Pattern creates one class executes Commands • Command can select actor who performs it
Decoupling • Command pattern decouples (splits) What we want to do Who does it When it is done
Decoupling • Command pattern decouples (splits) What we want to do Who does it When it is done Wish I knew about the Command Pattern
For Next Class • Lab #5 on Angel & due next Friday • In the book, read pages 203 - 214 • Start implementing the Command Pattern • What classes would we need? • Who executes the command? • And what the heck is a NOP (Null Command)? • Midterm #1 in class next Friday • Test is to be open-book, open-note, open-reports • Cannot use slides as part of your notes