El mensaje que pasa entre contextos de ejecución livianos, junto con la capacidad de crear y destruir dinámicamente estos contextos, es básicamente el modelo de actor .
Los lenguajes de programación tienden a abordar el problema de la expresión de una de dos maneras: los lenguajes OO tienden a enfocarse en facilitar la implementación de las mismas operaciones utilizando diferentes tipos de datos (por ejemplo, "objeto en el que puedo hacer clic con el mouse" podría ser una barra de desplazamiento, una ventana, un menú, un cuadro de texto, etc. - misma operación, diferentes representaciones de datos), mientras que los lenguajes funcionales tienden a enfocarse en implementar fácilmente nuevas operaciones contra los mismos tipos de datos subyacentes. Al abandonar las jerarquías de clase, Go parece terminar más en el lado "funcional" de esta división.
Como Adam Crossland indicó en su comentario, la "interfaz de implementación de tipo ignorante" puede considerarse una forma de tipear pato, que es muy frecuente en lenguajes dinámicos. (Sin embargo, es más técnicamente correcto considerar esto como un sistema de tipo estructural dentro de Go. Las plantillas C ++ son probablemente la implementación más popular de un sistema de tipo estructural en la actualidad).
Go tiene muchos antecedentes: no creo que ninguna de sus ideas sea original del lenguaje. Pero creo que esa es generalmente la medida incorrecta para un lenguaje que pretende ser práctico. Go parece que combina ideas útiles de varios dominios diferentes de una manera elegante, que (creo) daría como resultado una programación más productiva que C # o Java podría producir. Espero que gane tracción.