The idiomatic Go way is to write

   defer  ifDB.Close()

Simple is better than clever.

+ Readability does matter.


And in situations where you really need to check that the connection was 
successfully closed, and
you have a workable scheme for recovering from this situation, then write a 
named helper function
which encompasses this logic, rather than writing a convoluted anonymous 
function.

And make sure that all the execution paths in this function have unit tests.



On Tuesday, 19 March 2019 23:57:51 UTC, David Collier-Brown wrote:
>
> It's a known bad thing to defer a close for anything buffered, as 
> discussed at https://www.joeshaw.org/dont-defer-close-on-writable-files/
> but some constructs lack a Sync() call.
>
> For example, I have code like
>         ifDB, message, err := OpenInflux(server, debug)
>         if err != nil {
>                 // If this fails, fail fast so we notice
>                 panic(fmt.Errorf("failed to open and ping influxDB, %s %v",
>                         message, err))
>         }
>         defer func() {
>                 err = ifDB.Close()
>                 if err != nil {
>                         // This may be a harmless, very bad thing
>                         panic(fmt.Errorf("failure closing connection to 
> influxDB, %v", err))
>                 }
>         }()
>
>
> which closes an influxDB database, but will panic if the close fails.
>
> Separate logic makes sure I have passed the point at which the data is 
> committed before I commit my reading of input, so eventually the data will 
> be reread and rewritten. Nevertheless, this is exceedingly complex, and the 
> comment sums it up: "a harmless, very bad thing".
>
> Is there an idiomatic way to address this? I ended up reading influxDB 
> code and doing all sorts of deranged safety-critical-system DFAs to 
> reassure myself this will actually work, but every time I do that, my brain 
> hurts!
>
> --dave
>
>
>

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to