So in 2012 Cyril Oblikov wrote
Why isn't this code correct?
var N int = ...
for i := range N {
doSmth(i)
}
In my opinion it looks much simpler than:
var N int = ...
for i := 0; i < N; i++ {
doSmth(i)
}
So we should say to Cyril (whether he is today), that it is now correct.
You just needed to wait around for a 12 years.
Because you were just ahead of your time....
And if you are reading these lines, please post again to give us a glimpse
of what new features we should expect to be added to Go in 2036...
- amnon
On Saturday 24 February 2024 at 01:20:04 UTC Duncan Harris wrote:
> I made some changes to use range over int in our code base and was
> pleasantly surprised with the improvement in readability.
>
> We had quite a few instances where the number of iterations involved a
> function call which we don't want to repeat:
>
> - for i, n := 0, f(); i < n; i++ {
> + for i := range f() {
>
> A surprising amount where we no longer need the range variable including
> some nested loops:
>
> - for repeat := 0; repeat < col.Repeat; repeat++ {
> - for j := 0; j < len(cats); j++ {
> - for k := 0; k < numStats; k++ {
> + for range col.Repeat {
> + for range len(cats) {
> + for k := range numStats {
>
> There were also all the benchmarks:
>
> - for n := 0; n < b.N; n++ {
> + for range b.N {
>
> We could update the docs in https://pkg.go.dev/testing accordingly :-)
>
>
> On Friday 23 February 2024 at 06:18:33 UTC Henry wrote:
>
> This is one feature that provides little value beyond saving a few
> keystrokes and looking slightly nice, but with potential of increased
> complexity when we need to implement more important features to the
> language down the road. This is my opinion. It shouldn't have been added,
> but what was done is done. There is nothing we can do about it now.
>
> On Sunday, February 18, 2024 at 5:38:25 AM UTC+7 [email protected]
> wrote:
>
> I agree with you.
>
>
> Powered By Citizen
>
> On Saturday, February 17, 2024, 1:19 AM, Kurtis Rader <
> [email protected]> wrote:
>
> It's not just changing `k` inside the loop body that makes the
> transformation invalid -- your observation also applies to modifying `i`
> inside the loop body. Modifying either variable inside the loop body is
> extremely rare in my experience and doing so warrants a "dragons be here"
> comment. Still, your point is valid and anyone applying such a
> transformation should carefully evaluate the body of each loop to see if
> either variable might be modified by the loop body. Obviously it would be
> nice if a tool automated that analysis and transformation but I'm not going
> to hold my breath waiting for someone to implement that tool.
>
> On Fri, Feb 16, 2024 at 11:06 PM Patrick Smith <[email protected]> wrote:
>
> On Fri, Feb 16, 2024 at 10:27 PM Amnon <[email protected]> wrote:
>
> But now it is out, I think it is great, and have run
> perl -pi -e 's/for (\w+) := 0; \1 < ([\w()]+); \1\+\+/for \1 := range
> \2/' $(git grep -l for) over my entire codebase to use it everywhere.
>
>
> You know your own codebase, and maybe this was safe for you to do. But in
> general, blindly applying such a blanket change has the potential to cause
> bugs, as these two are not always equivalent:
>
> for i := range k
> for i := 0; i < k; i++
>
> In particular, if k is changed inside the loop they may be very different.
> https://go.dev/play/p/kAHcmu7377I
>
> (Yes, many people, myself included, would consider changing k inside such
> a loop to be bad coding style. But "bad style" doesn't mean it's not going
> to be done.)
>
> --
> 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 [email protected].
> To view this discussion on the web visit
> https://groups.google.com/d/msgid/golang-nuts/CAADvV_trGNxeLUma722wk-JOGnz42fJqM8%3DVZ36TKpr5s-%3DmOQ%40mail.gmail.com
>
> <https://groups.google.com/d/msgid/golang-nuts/CAADvV_trGNxeLUma722wk-JOGnz42fJqM8%3DVZ36TKpr5s-%3DmOQ%40mail.gmail.com?utm_medium=email&utm_source=footer>
> .
>
>
>
> --
> Kurtis Rader
> Caretaker of the exceptional canines Junior and Hank
>
> --
> 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 [email protected].
>
> To view this discussion on the web visit
> https://groups.google.com/d/msgid/golang-nuts/CABx2%3DD9Hyjj_N9KjY6XfFH0ZUt55f27VCcZQSj_DyX36gzrX1g%40mail.gmail.com
>
> <https://groups.google.com/d/msgid/golang-nuts/CABx2%3DD9Hyjj_N9KjY6XfFH0ZUt55f27VCcZQSj_DyX36gzrX1g%40mail.gmail.com?utm_medium=email&utm_source=footer>
> .
>
>
--
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 [email protected].
To view this discussion on the web visit
https://groups.google.com/d/msgid/golang-nuts/ee355172-59a4-423f-8287-56010883c97cn%40googlegroups.com.