|
using System;
namespace Command
{
class Program
{
static void Main()
{
Client client = new Client();
client.RunCommand();
}
}
public class Client
{
public void RunCommand()
{
var invoker = new Invoker();
var receiver = new Receiver();
var command = new ConcreteCommand(receiver);
command.Parameter = "Hello, world!";
invoker.Command = command;
invoker.ExecuteCommand();
}
}
public class Receiver
{
public void Action(string message)
{
Console.WriteLine("Action called with message, '{0}'.", message);
}
}
public class Invoker
{
public CommandBase Command { get; set; }
public void ExecuteCommand()
{
Command.Execute();
}
}
public abstract class CommandBase
{
protected readonly Receiver _receiver;
public CommandBase(Receiver receiver)
{
_receiver = receiver;
}
public abstract void Execute();
}
public class ConcreteCommand : CommandBase
{
public string Parameter { get; set; }
public ConcreteCommand(Receiver receiver) : base(receiver) { }
public override void Execute()
{
_receiver.Action(Parameter);
}
}
}
|
By viewing downloads associated with this article you agree to the Terms of Service and the article's licence.
If a file you wish to view isn't highlighted, and is a text file (not binary), please
let us know and we'll add colourisation support for it.
My name is Robert Kanasz and I have been working with ASP.NET, WinForms and C# for several years.
MCSD - Web Applications
MCSE - Data Platform
MCPD - ASP.NET Developer 3.5
- Web Developer 4
MCITP - Database Administrator 2008
- Database Developer 2008
MCSA - SQL Server 2012
MCTS - .NET Framework 3.5, ASP.NET Applications
- SQL Server 2008, Database Development
- SQL Server 2008, Implementation and Maintenance
- .NET Framework 4, Data Access
- .NET Framework 4, Service Communication Applications
- .NET Framework 4, Web Applications
MS - Programming in HTML5 with JavaScript and CSS3 Specialist
Open source projects:
DBScripter - Library for scripting SQL Server database objects
Please, do not forget vote