1
0
Fork 0
mirror of https://github.com/vbatts/talks.git synced 2025-01-14 17:30:08 +00:00
talks/2015/06-devnation-golang-good-bad-ugly/talk.slide

214 lines
3.4 KiB
Text
Raw Normal View History

2015-06-11 22:28:27 +00:00
Golang - the good, the bad, the ugly
2015-06-11 22:28:51 +00:00
25 June 2015 - devnation.org
2015-06-11 22:28:27 +00:00
Vincent Batts
2015-06-24 22:06:11 +00:00
Engineer
2015-06-11 22:28:27 +00:00
@vbatts
vbatts@redhat.com
https://github.com/vbatts/talks
* howdy
2015-06-11 22:28:51 +00:00
$> finger $(whoami)
Login: vbatts Name: Vincent Batts
Such mail.
Plan:
2015-06-24 22:06:11 +00:00
OHMAN
2015-06-11 22:28:51 +00:00
$> id -Gn
vbatts devel openshift docker
2015-06-11 22:28:27 +00:00
* 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
.code ./imports.go /START1/,/STOP1/
* fast compiles
(Perhaps other compilers are slow)
.play ./hello.go /START1/,/STOP1/
* defer
.code ./good0.go /START1/,/STOP1/
* Garbage Collected
- Super convenient
- references
- completed goroutines
* simple exports
.code ./good1.go /START1/,/STOP1/
* concurrency
.play ./pingpong.go /STARTMAIN1/,/STOPMAIN1/
.link http://talks.golang.org/2013/advconc.slide Sameer Ajmani - Advanced Concurrency
2015-06-24 22:06:11 +00:00
* Marshalling
.code ./marshal.go /START1/,/STOP1/
.play ./marshal.go /START2/,/STOP2/
* Marshalling
.code ./marshal_xml.go /START1/,/STOP1/
.play ./marshal_xml.go /START2/,/STOP2/
2015-06-11 22:28:27 +00:00
*
.image ./kanye_imma_bookmarklet.png 320 _
- easy learning curve
2015-06-24 22:06:11 +00:00
- fast compiles
2015-06-11 22:28:27 +00:00
- `go get`
- cross-compiles
* Bad
*
# they come along, and affect how you do your work
.image ./cats20.gif
* Packaging
Addresses different concern than distributions
* lack of generics?
# i don't feel strongly about this, though many do
2015-06-24 22:06:11 +00:00
- interfaces - good enough for most
2015-06-11 22:28:27 +00:00
- 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", ...)
2015-06-24 22:06:11 +00:00
- go1.5 has much focus on DWARF symbols
2015-06-11 22:28:27 +00:00
* Concurrency and GC
2015-06-24 22:06:11 +00:00
- Calls like setns(2) are rough
(yes, even with runtime.LockOSThread())
2015-06-11 22:28:27 +00:00
2015-06-24 22:06:11 +00:00
- go1.5 will greatly improve garbage collections
(performance and pauses)
2015-06-11 22:28:27 +00:00
* Fork/Exec
Not Separate, but together
2015-06-24 22:06:11 +00:00
2015-06-11 22:28:27 +00:00
* Ugly? (maybe just new)
*
.image ./revenge-of-the-nerds-o.gif
* build tags
no #ifdef
.code ./tags.go /START1/,/STOP1/
or files with *_linux.go like suffix.
More like extern.
2015-06-24 22:06:11 +00:00
* pointer reciever
.play ./ugly2.go /START1/,/STOP1/
2015-06-11 22:28:27 +00:00
* _
bit bucket
* channels
.play ./ugly0.go /START1/,/STOP1/
* iota
.code ./ugly1.go /START1/,/STOP1/
* for range
array (or string)
.play ./primitive1.go /START1/,/STOP1/
* for range
map
.play ./primitive2.go /START1/,/STOP1/
* for range
channel (like an iterator)
.play ./primitive3.go /START1/,/STOP1/
* for range
channel
.code ./primitive3.go /START2/,/STOP2/
2015-06-24 22:06:11 +00:00
* interfaces and marshalling
.code ./marshal_ugly.go /START1/,/STOP1/
2015-06-11 22:28:27 +00:00
* Conclusions?
2015-06-24 22:06:11 +00:00
* Conclusions?
- easy to adopt
- enjoyable to learn
2015-06-11 22:28:27 +00:00
* use-case
- get familiar enough to like and dislike it
2015-06-24 22:06:11 +00:00
- like all languages, choose the one that aligns with your use-case
2015-06-11 22:28:27 +00:00
- don't be afraid to try it out