I didn't get a chance to look at all of them, but your Proxy pattern
example is incorrect.

The idea of a proxy is that the proxy object exposes the same interface as
the underlying object, so they are substitutable.

In your example, Car is concrete (meaning that callers cannot substitute
any other type in its place). Also, the signature of the operation on Car
differs from the one on the Proxy that is meant to wrap it. Here's a fixed
version: https://play.golang.org/p/gq6Koi8f6XC

I'll also pointed out that the example code -- which I see is
transliterated from the code snippets in Wikipedia -- likes more like its a
related pattern: the decorator (sometimes known as the interceptor pattern).

----
*Josh Humphries*
jh...@bluegosling.com

On Fri, Feb 2, 2018 at 12:03 PM, <matthewju...@gmail.com> wrote:

> I’m looking at patterns summarized on Wikipedia from “Design Patterns:
> Elements of Reusable Object-Oriented Software” and writing out a few as the
> equivalent in Go.
>
> Visitor: https://play.golang.org/p/A5tNzxMmetH
>
> Abstract Factory: https://play.golang.org/p/SWwuX49eysd
>
> Factory Method: https://play.golang.org/p/FRgDBx2CLFf
>
> Facade: https://play.golang.org/p/forPdwy9VCi
>
> Proxy: https://play.golang.org/p/DFWuDPTOzEP
>
> I’m curious how more experienced people rank these and the other patterns.
>
> Matt
>
> --
> You received this message because you are subscribed to the Google Groups
> "golang-nuts" group.
> To unsubscribe from this group and stop receiving emails from it, send an
> email to golang-nuts+unsubscr...@googlegroups.com.
> For more options, visit https://groups.google.com/d/optout.
>

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to