On Friday, October 14, 2016 at 12:14:34 AM UTC+8, Ian Lance Taylor wrote:
>
> On Thu, Oct 13, 2016 at 8:36 AM,  <di...@veryhaha.com <javascript:>> 
> wrote: 
> > 
> > On Thursday, October 13, 2016 at 11:24:50 PM UTC+8, Jesper Louis 
> Andersen 
> > wrote: 
> >> 
> >> The rule is that a short variable declaration requires that at least 
> one 
> >> non-blank variable is new (the specification even says so) Consider 
> >> 
> >>     _, y := 4,5 
> >> 
> >> where one variable, y, is new. In 
> >> 
> >>     _ := 6 
> >> 
> >> or 
> >> 
> >>     _, _ := 5, 7 
> >> 
> >> this rule is violated, since there are no non-blank variables (and thus 
> >> vacuously nothing new). 
> >> 
> >> I think the reason this is a rule is because it may detect some 
> spurious 
> >> errors by forcing the programmer to write code in a certain style, but 
> I may 
> >> be wrong. 
> > 
> > 
> > 
> > What spurious errors? 
>
> The error of thinking that because you are using := you are getting a 
> new variable. 
>
> The handling of := is a bit tricky, perhaps too tricky.  It used to 
> always declare new variables, and give an error if there was already a 
> variable of the same name in the same scope.  But that was too painful 
> to use with the err variable, because of the common use of 
>     n, err := F() 
> So := was changed to permit reusing a variable if it already existed 
> in the same scope with the same name and (inferred) type. 
>
> Ian 
>

But the long variable declaration form only allows all variables are new 
ones generally, except for the blank _ identifier.
Why not also make an exception for the blank _ identifier in the short form?

-- 
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