“Handler” pattern?

前端 未结 6 1753
臣服心动
臣服心动 2020-12-31 07:11

I\'ve come across a design pattern that\'s been referred to as a \"Handler Pattern,\" but I can\'t find any real references to this pattern anywhere. It\'s basically just a

相关标签:
6条回答
  • 2020-12-31 07:42

    I don't know if it's really recommended, but I've actually had to use that kind of pattern in some MATLAB applications I've written to mimic reference-like behavior for objects (which is needless now with newer versions).

    Ironically, I actually called the function "handler". My object simply stored one field containing a function handle reference (@handler) and methods were just wrappers that called this function. For example, an overloaded GET function for the object would just call:

    object.handler('get',...input argument list...)
    

    I'm not sure if this is considered a "good" design choice in other languages. I chose it out of necessity, because it was the only way I came across to create reference-like behavior in MATLAB (the handler function had access to a workspace of initialized data that I wouldn't have to pass in and out of the various method calls). The newest versions of MATLAB now have a HANDLE class that can do this stuff in a much cleaner way.

    0 讨论(0)
  • 2020-12-31 07:42

    I think the goal of avoiding recompiles is much better served by a COM influenced design. What extra flexibility do you get from this:

    IHandler UserHandler = ...;
    
    Dictionary<string,string> result = UserHandler.Handle(
        new Dictionary<string, string>{
            { "Action", "AddUser" },
            { "UserName", "Joe Bloggs" },
            { "Age", "23" } });
    NewUserId = Int.Parse(result["UserId"]);
    

    over:

    IUserHandler UserHandler = ...;
    
    AddUserResult result = UserHandler.AddUser(new AddUserArgs {
        UserName = "Joe Bloggs",
        Age = 23 });
    NewUserId = result.UserId;
    

    when you can extend the actions, results, and arguments:

    IUserHandler UserHandler = ...;
    
    AddUserResult2 result = UserHandler.AddUser(new AddUserArgs2 {
        UserName = "Joe Bloggs",
        Age = 23,
        Password = "xyzzy" });
    NewUserId = result.UserId;
    SessionId = result.SessionId;
    
    IUserHandler2 UserHandler2 = UserHandler as IUserHandler2;
    if (UserHandler2 != null)
    {
        LoginUserResult loginResult = UserHandler2.LoginUser(new LoginUserArgs {
            UserId = NewUserId,
            SessionId = SessionId,
            Password = "xyzzy" });
    }
    
    0 讨论(0)
  • 2020-12-31 07:43

    I use it under the name of "SingletonRegistry"

    See this thread

    I've use it a couple of times. Specially when the actions to take are unknown upfront ( in the first phases of the design ) or the app should support extreme flexibility.

    I load the dictionary either from a file or a database, and create a single instance of the class that will handle the request under certain "key".

    I've found this class also searching the web for that name.

    Looks like the same isn't?

    0 讨论(0)
  • 2020-12-31 07:44

    Because you had the word "Action" in your post, I am led to believe that this might be a part of the Command pattern. Check out the Wiki and search for "Handler"... maybe this will give a little more insight.

    http://en.wikipedia.org/wiki/Command_pattern

    0 讨论(0)
  • 2020-12-31 07:49

    I've seen the "Handler" classes around in legacy code bases, especially for web services. From what I've seen though, these typically turn out to be an Adapter, Facade, or some similar pattern and ends up getting called a Handler since it is handling a request.

    0 讨论(0)
  • 2020-12-31 07:54

    it's the OOP way to do closures on languages that doesn't have them. it didn't have a 'pattern' name because on functional languages it's the obvious way to work. on OOP languages, OTOH, you have to do some work, so it seems a nameable idiom. 'Handler' sounds right.

    (it's not a singleton, BTW)

    0 讨论(0)
提交回复
热议问题