Go Proverbs: Difference between revisions

From NovaOrdis Knowledge Base
Jump to navigation Jump to search
(Created page with "=Internal= * Go Engineering =Overview= * Don't communicate by sharing memory, share memory by communicating. * Concurrency is not parallelism. *...")
 
Line 3: Line 3:


=Overview=
=Overview=
Rob Pike's:


* Don't communicate by sharing memory, share memory by communicating.
* Don't communicate by sharing memory, share memory by communicating.

Revision as of 23:20, 28 December 2023

Internal

Overview

Rob Pike's:

  • Don't communicate by sharing memory, share memory by communicating.
  • Concurrency is not parallelism.
  • Channels orchestrate; mutexes serialize.
  • The bigger the interface, the weaker the abstraction.
  • Make the zero value useful.
  • interface{} says nothing.
  • gofmt's style is no one's favorite, yet gofmt is everyone's favorite.
  • A little copying is better than a little dependency.
  • Syscall must always be guarded with build tags.
  • Cgo must always be guarded with build tags.
  • Cgo is not Go.
  • With the unsafe package there are no guarantees.
  • Clear is better than clever.
  • Reflection is never clear.
  • Errors are just values.
  • Don't just check errors, handle them gracefully.
  • Design the architecture, name the components, document the details.
  • Documentation is for users.
  • Don't panic.