2015-02-05 23:58:25 +00:00
|
|
|
Golang - the good, the bad, the ugly
|
|
|
|
06 Feb 2015 - devconf.cz
|
|
|
|
|
|
|
|
Vincent Batts
|
|
|
|
Developer
|
|
|
|
@vbatts
|
|
|
|
vbatts@redhat.com
|
2015-02-06 00:08:14 +00:00
|
|
|
https://github.com/vbatts/talks
|
2015-02-05 23:58:25 +00:00
|
|
|
|
|
|
|
* howdy
|
|
|
|
|
|
|
|
$> whoami
|
|
|
|
vbatts
|
|
|
|
$> id -Gn
|
|
|
|
vbatts devel openshift docker
|
|
|
|
|
|
|
|
* golang
|
|
|
|
|
|
|
|
## Notes
|
|
|
|
# - libraries - source only, but can link to C *.so and *.a
|
|
|
|
# - Fork/Exec are coupled together (for coroutine and GC reasons)
|
|
|
|
# - Threading, and multiproc, concurrent logic
|
|
|
|
# -- nice and easy to use
|
|
|
|
# -- Make for tricky handling of C calls (i.e. setns)
|
|
|
|
# - `go get` is handy
|
|
|
|
# - cross-compile without hardly any bootstrapping
|
|
|
|
# -- native compiler supported arches
|
|
|
|
# -- gccgo works for the arch gcc is compiled for
|
|
|
|
# - primitives can seem a bit magical
|
|
|
|
# -- conditional returns
|
|
|
|
# -- for ... range
|
|
|
|
# -- iota
|
|
|
|
# - no ifdefs, but build tags
|
|
|
|
# - error handling, rather than exception catching
|
|
|
|
|
|
|
|
*
|
|
|
|
|
|
|
|
.image ./gopher.png
|
|
|
|
|
|
|
|
* Overview
|
|
|
|
|
|
|
|
- strongly typed
|
|
|
|
- compiled
|
|
|
|
- stylistically nice
|
|
|
|
- opinionated
|
|
|
|
|
|
|
|
* Good
|
|
|
|
|
|
|
|
*
|
|
|
|
|
|
|
|
.image ./rainbow.jpg
|
|
|
|
|
|
|
|
* fully qualified imports
|
|
|
|
|
2015-02-06 00:04:10 +00:00
|
|
|
.code ./imports.go /START1/,/STOP1/
|
2015-02-05 23:58:25 +00:00
|
|
|
|
|
|
|
* fast compiles
|
|
|
|
|
|
|
|
(Perhaps other compilers are slow)
|
|
|
|
|
2015-02-06 00:04:10 +00:00
|
|
|
.play ./hello.go /START1/,/STOP1/
|
2015-02-05 23:58:25 +00:00
|
|
|
|
|
|
|
* defer
|
|
|
|
|
2015-02-06 00:04:10 +00:00
|
|
|
.code ./good0.go /START1/,/STOP1/
|
2015-02-05 23:58:25 +00:00
|
|
|
|
|
|
|
* Garbage Collected
|
|
|
|
|
|
|
|
- Super convenient
|
|
|
|
- references
|
|
|
|
- completed goroutines
|
|
|
|
|
|
|
|
* simple exports
|
|
|
|
|
2015-02-06 00:04:10 +00:00
|
|
|
.code ./good1.go /START1/,/STOP1/
|
2015-02-05 23:58:25 +00:00
|
|
|
|
|
|
|
* concurrency
|
|
|
|
|
2015-02-06 00:04:10 +00:00
|
|
|
.play ./pingpong.go /STARTMAIN1/,/STOPMAIN1/
|
2015-02-05 23:58:25 +00:00
|
|
|
.link http://talks.golang.org/2013/advconc.slide Sameer Ajmani - Advanced Concurrency
|
|
|
|
|
|
|
|
*
|
|
|
|
.image ./kanye_imma_bookmarklet.png 320 _
|
|
|
|
|
|
|
|
- easy learning curve
|
|
|
|
- `go get`
|
|
|
|
- cross-compiles
|
|
|
|
|
|
|
|
|
|
|
|
* Bad
|
|
|
|
|
|
|
|
*
|
|
|
|
|
|
|
|
# they come along, and affect how you do your work
|
|
|
|
.image ./cats20.gif
|
|
|
|
|
2015-06-05 20:20:32 +00:00
|
|
|
* Packaging
|
|
|
|
|
|
|
|
Addresses different concern than distributions
|
|
|
|
|
2015-02-05 23:58:25 +00:00
|
|
|
* lack of generics?
|
|
|
|
# i don't feel strongly about this, though many do
|
|
|
|
- interfaces - are enough for most
|
|
|
|
- go1.4 introduced go:generate
|
|
|
|
# produce code for Set, Graph etc, for the types needed, but at compile time. No need to reflect.
|
|
|
|
|
|
|
|
* Debugging
|
|
|
|
|
|
|
|
- gdb is there, sort of
|
|
|
|
- some known debugging tools for ELF are not useful
|
|
|
|
- fmt.Printf("%#v\n", ...)
|
|
|
|
|
|
|
|
* Concurrency and GC
|
|
|
|
|
|
|
|
Calls like setns(2) are rough
|
|
|
|
|
|
|
|
|
|
|
|
(yes, even with runtime.LockOSThread())
|
|
|
|
|
|
|
|
* Fork/Exec
|
|
|
|
|
|
|
|
Not Separate, but together
|
|
|
|
|
|
|
|
* Ugly? (maybe just new)
|
|
|
|
|
|
|
|
*
|
|
|
|
.image ./revenge-of-the-nerds-o.gif
|
|
|
|
|
|
|
|
* build tags
|
|
|
|
|
2015-06-05 20:20:32 +00:00
|
|
|
no #ifdef
|
|
|
|
|
2015-02-06 00:04:10 +00:00
|
|
|
.code ./tags.go /START1/,/STOP1/
|
2015-02-05 23:58:25 +00:00
|
|
|
|
2015-06-05 20:20:32 +00:00
|
|
|
or files with *_linux.go like suffix.
|
|
|
|
|
|
|
|
More like extern.
|
|
|
|
|
2015-02-05 23:58:25 +00:00
|
|
|
|
|
|
|
* _
|
|
|
|
|
|
|
|
bit bucket
|
|
|
|
|
|
|
|
* channels
|
|
|
|
|
2015-02-06 00:04:10 +00:00
|
|
|
.play ./ugly0.go /START1/,/STOP1/
|
2015-02-05 23:58:25 +00:00
|
|
|
|
|
|
|
* iota
|
|
|
|
|
2015-02-06 00:04:10 +00:00
|
|
|
.code ./ugly1.go /START1/,/STOP1/
|
2015-02-05 23:58:25 +00:00
|
|
|
|
|
|
|
* for range
|
|
|
|
|
|
|
|
array (or string)
|
|
|
|
|
2015-02-06 00:04:10 +00:00
|
|
|
.play ./primitive1.go /START1/,/STOP1/
|
2015-02-05 23:58:25 +00:00
|
|
|
|
|
|
|
* for range
|
|
|
|
|
|
|
|
map
|
|
|
|
|
2015-02-06 00:04:10 +00:00
|
|
|
.play ./primitive2.go /START1/,/STOP1/
|
2015-02-05 23:58:25 +00:00
|
|
|
|
|
|
|
* for range
|
|
|
|
|
|
|
|
channel (like an iterator)
|
|
|
|
|
2015-02-06 00:04:10 +00:00
|
|
|
.play ./primitive3.go /START1/,/STOP1/
|
2015-02-05 23:58:25 +00:00
|
|
|
|
|
|
|
* for range
|
|
|
|
|
|
|
|
channel
|
|
|
|
|
2015-02-06 00:04:10 +00:00
|
|
|
.code ./primitive3.go /START2/,/STOP2/
|
2015-02-05 23:58:25 +00:00
|
|
|
|
|
|
|
* Conclusions?
|
|
|
|
|
|
|
|
* use-case
|
|
|
|
|
|
|
|
- like all languages, align with you use-case
|
2015-02-06 00:04:10 +00:00
|
|
|
- get familiar enough to like and dislike it
|
|
|
|
- don't be afraid to try it out
|
|
|
|
|