I am new to go and have a bunch of questions to get myself off the ground and running!
Currently my dev circle is severely lacking in go developers and more importantly someone who knows good go practices. I want to take the initiative and be the chosen one.
I've done a few trivial go programs and went through the "A Tour of Go" examples. I've read a few go gotcha threads and go articles here and there, and watched a pretty awesome video on go concurrency.
Quick background:
- Most recently (for 7 years), I have been developing in python.
- My editor of choice is nano on linux and notepad on windows. (I know I know. I get grief almost every day.)
- Printing to the console is my debugging
- Introspection is how I learn/find new things
Questions:
Is there a good introspection feature (like dir() in python)? I do not want something like tab complete in my editor, I just want a way to see all the features an object from time to time. fmt.Println an object seems to give the values but not the names that go with them, maybe I am missing something.
How are you supposed to find what file functions are within? I was looking at a few larger projects and it felt daunting to search through all the files in the folder for any given package to find the right file that housed the function that was being called. Is it just based on naming conventions or is there something that points to the specific file (kind of like in python)?
What are the "best" handful of blogs/posts/vids for learning, using, and best practices for go? I will start checking out the "Resources for new Go Programmers" on the sidebar.
Is there a package manager that lets you pull down projects for snap-able pieces (like pip)?
Is there a multi environment tool that lets you have different versions of go libraries (like virtualenv)?
Is the convention of returning an error value in (almost) every function and then checking if there was an error in the calling function standard practice? I believe I understand that there is no try/except in go and only to use panic when you really want things to bubble up.
I am sure I will think of more questions but I think for now answers to these should get me moving pretty quickly!
评论:
DeedleFake:
golangnewb:Welcome to Go. I don't know Python as well as I should, but I'll try to answer your questions. Hopefully someone will correct what I inevitably get wrong.
Is there a good introspection feature (like dir() in python)? I do not want something like tab complete in my editor, I just want a way to see all the features an object from time to time. fmt.Println an object seems to give the values but not the names that go with them, maybe I am missing something.
You could use
fmt.Printf("%#v")
, but I think thatgodoc
can do what you want. Go 1.5 will introducego doc
, which is more tailored for command-line use. For example, if you want to see all the exported fields and methodsjson.Encoder
, you could just rungo doc encoding/json.encoder
, and it would list them.How are you supposed to find what file functions are within? I was looking at a few larger projects and it felt daunting to search through all the files in the folder for any given package to find the right file that housed the function that was being called. Is it just based on naming conventions or is there something that points to the specific file (kind of like in python)?
This is a bit of an issue which has been complained about before, but the simple syntax in Go makes it pretty easy to find specific things most of the time using something like
grep
. For example, let's say you want to find which file inencoding/json
defines theEncoder
type. You could usegrep 'type Encoder' *.go
.What are the "best" handful of blogs/posts/vids for learning, using, and best practices for go? I will start checking out the "Resources for new Go Programmers" on the sidebar.
One that I rather enjoy recommending, if only for the sole reason that Go is pretty much the only language you can do this with, is the spec. You can literally read through the entire thing in about an hour.
Is there a package manager that lets you pull down projects for snap-able pieces (like pip)?
I'm not exactly sure how
pip
works, but you could trygb
Go 1.5 will be adding experimental support for vendoring, so hopefully Go 1.6 will have a more full-fledged system available.Is there a multi environment tool that lets you have different versions of go libraries (like virtualenv)?
Provided I am understanding your question correctly, this isn't really necessary, since Go binaries are statically linked. The aforementioned vendoring support should make it possible to determine versions more easily at compile-time as well.
Is the convention of returning an error value in (almost) every function and then checking if there was an error in the calling function standard practice? I believe I understand that there is no try/except in go and only to use panic when you really want things to bubble up.
Pretty much. A function shouldn't have an
error
return if it's not going to cause an error, though.panic()
andrecover()
usage is pretty rare, so far as I have seen.I hope that helps, and I hope someone can fill in what I missed.
DeedleFake:Thanks for this!
I will take a look at the spec link you provided, and read up on all the new 1.5 changes (exciting to jump in when a new version hits).
To find things in the sea of files, I was greping through the repos as you said but was hoping there was a better way.
I just tried the fmt.Printf("%#v", obj), I think it does the same thing and does not show the names of the fields only what is in the fields if that makes sense. Maybe I am doing something wrong.
golangnewb:I just tried the fmt.Printf("%#v", obj), I think it does the same thing and does not show the names of the fields only what is in the fields if that makes sense. Maybe I am doing something wrong.
Did you take a look at the link? It does show field names.
One thing to keep in mind, though, is that fields in a struct and methods on a type are completely, vastly different things in Go. Fields are what you would expect them to be from Python, but methods are more like functions with some syntactical sugar. They can be defined on any type in the same package that that type is declared, and types do not need to be structs.
Bake_Jailey:Didn't notice it was a link.
I see, it works on this demo. I figured out why it did not work for me when I tried to use your line. I used Println not Printf. I will look into the difference!
Thanks!
Fwippy:I'd also like to recommend go-spew. I use it a lot for my debugging, as it works recursively. You can make a custom config that does things like format (into a JSON-like look), and let you completely skip the Stringer interface (for pesky types that hide information behind a string).
golangnewb:I really recommend using an editor that has some Go support - its not essential (like for C# or Java), but a little help can go a long way. Personally, I use vim and the vim-go plugin, but vim is not really nano. I hear good things about the sublime text go plugin, which is probably closer to what you are used to.
For a pip analog, you'll want "go get" - it downloads the source, any dependencies, and executables (if any).
godoc.org is where you can find the best documentation of packages - and if you click the function you're interested in, it'll take to right to the definition in the source.
https://golang.org/doc/effective_go.html and https://tour.golang.org are good starting points and could be all the resources you need. Seriously, they're short, but they're pretty comprehensive. The go tour is like a tutorial, effective go is closer to your manual.
Hope this helps!
Edit: Oops, looks like I was beaten to the punch. :)
izuriel:Thanks!
I may check out the vim-go plugin. Seems like that is the way people are pointing.
Can't believe I missed "go get". It's right there when you type go.
golangnewb:To your first two:
No. What you want doesn't really exist in Go. I mean, the reflect package let you do all kinds of inspection but you would be silly doing that when there are tools designed to look into Go docs. That said, you want go docs. The site godoc.org is the best resource and is capable of generating documentation for files on public VCS repos. Use it.
To your third question:
The Go blog is obviously great. In response to a later question they have an article about error handling. Also Effective Go is an article on the go sites that is a go to for idiomatic Go information.
The next two:
Not really. You'll find a handful of tools that helps age versions for reproducible builds but they all (basically) wrap the go get command which is your "package" manager.
To the last:
There is a great article on the go blog about handling errors in more efficient ways that's great to read. But a more direct answer is yes. Any function that does a "thing" that can fail should return an error. Failure is different than noop situations. Just because you don't do anything on a given input doesn't mean you should have errors. I mean situations where something should work but can fail (like bad file pointers, trying to write to a folder or sending data to a database that is no longer available). I also want to make it clear that using panic doesn't "bubble" an error, it kills the application and prints some error info. Only use it when that's what you really want which is probably rarely outside of small personal projects.
A final note:
Get yourself an editor. I can't believe you would be productive using those editors and definitely wouldn't let something like that happen on my team. I'm all for letting devs use their tools of choice but I guess the hidden requirement there would be that they have to be dev tools. At the very least use Notepad++ on Windows which at least tries to be a useful editor.
Also, sorry there are no links. I'm on a phone and that makes linking a bit more work - Google should find all of this easily though.
TheMerovius:Thanks for the help!
Looks like godoc.org is the place to be!
Trust me, I hear it all the time from my team mates about the editors. However the introspection in python and forcing me to learn where things are make me very quick. I used visual studio back when I was a c# dev, intellisense was super sweet, but I feel I know python std libraries way better than I knew c# std libraries.
However if things get rough I can always go back to my trusty vim!
izuriel:One thing I find really important for programming in go (I mean… like… really important, it won't be any fun otherwise) is automatically running goimports on save. Not only do you want to make sure that all your code is always properly formatted all the time -- missing or superfluous imports are a compilation error in go, so without goimports you will need to adjust your import all the time.
I don't really care what editor you use as long as you can integrate goimports. :) Notepad can't do that, as far as I know.
I mentioned Notepad++ because it's just a text editor. It doesn't have intellisense it just highlights code and then provides some more code related features.
Sublime is a much better choice but is very similar. Sublime offers plugins that make the editor more powerful. Atom is an open source clone (not 100% the same) of sublime. But the key point is they are all just text editors. Not IDEs.