详解如何在Go语言中循环数据结构 go循环引用

   2023-02-09 学习力0
核心提示:目录如何在Go中循环字符串如何在Go中循环map结构如何在Go中循环Struct数组是存储类似类型数据的强大数据结构。您可以通过索引识别和访问其中的元素。在Golang中,您可以通过在0初始化变量i并增加变量直到它达到数组的长度,使用for循环循环数组。它们的语法如

数组是存储类似类型数据的强大数据结构。您可以通过索引识别和访问其中的元素。

在Golang中,您可以通过在0初始化变量i并增加变量直到它达到数组的长度,使用for循环循环数组。

它们的语法如下所示:

for i := 0; i < len(arr); i++ {
    // perform an operation
}

例如,让我们循环一个整数数组:

package main

import (
	"fmt"
)

func main() {
	numbers := []int{7, 9, 1, 2, 4, 5}

	for i := 0; i < len(numbers); i++ {
		fmt.Println(numbers[i])

	}
}

在上面的代码中,我们定义了一个名为numbers的整数数组,并通过初始化变量i循环它们。然后,我们在增加i的同时打印出数组每个索引的值。

上面的代码输出如下:

7
9
1
2
4
5

我们还可以使用range关键字循环数组,该关键字迭代数组的整个长度。

语法如下所示:

for index, arr := range arr {
  // perform an operation	
}

例如:

package main

import (
	"fmt"
)

func main() {
	arr := []string{"a", "b", "c", "d", "e", "f"}

	for index, a := range arr {
		fmt.Println(index, a)
	}

}

在上面的代码中,我们定义了一个字符串数组,并使用for..range关键字循环其索引和值。

for...range的语法更简单,更容易理解。您使用它来迭代不同的数据结构,如数组、字符串、映射、切片等。

这输出以下内容:

0 a
1 b
2 c
3 d
4 e
5 f

假设我们忽略索引并简单地打印出数组的元素,您只需将index变量替换为下划线即可。

例如:

package main

import (
	"fmt"
)

func main() {
	arr := []string{"a", "b", "c", "d", "e", "f"}

	for _, a := range arr {
		fmt.Println(a)
	}

}

在上面的代码中,我们修改了前面的示例,并将index变量替换为下划线。我们这样做是为了忽略索引,而是输出数组的元素。

这输出以下内容:

a
b
c
d
e
f

如何在Go中循环字符串

编程中的字符串是不可变的——这意味着您在创建它们后无法修改它们。它们是一个或多个字符(如字母、数字或符号)的有序序列,可以是常数或变量。

在Golang中,字符串与Python或JavaScript等其他语言不同。它们表示为UTF-8字节序列,字符串中的每个元素都表示一个字节。

您使用for...range循环或使用常规循环循环字符串。

例如:

package main

import (
	"fmt"
)

func main() {
	word := "Ab$du"

	for index, a := range word {
		fmt.Println(index, string(a))
	}
}

在上面的代码中,我们定义了一个包含不同字符的字符串,并循环了其条目。字符串在Golang中表示为字节,这就是为什么在打印出来时,我们需要将每个值转换为类型string

此输出:

0 A
1 b
2 $
3 d
4 u

如果我们没有将每个条目转换为字符串,Golang会打印出字节表示形式。

例如:

package main

import (
	"fmt"
)

func main() {
	word := "Ab$du"

	for index, a := range word {
		fmt.Println(index, a)
	}
}

结果:

0 65
1 98
2 36
3 100
4 117

我们还可以通过使用常规for loop来迭代字符串。

package main

import (
	"fmt"
)

func main() {
	word := "ab$du"

	for i := 0; i < len(word); i++ {
		fmt.Println(i, string(word[i]))
	}
}

如何在Go中循环map结构

在Golang中,映射是一种将元素存储在键值对中的数据结构,其中键用于识别地图中的每个值。它类似于Python和Java等其他语言中的字典和哈希图。

您可以使用 for...range语句在 Golang 中迭代map,其中它获取索引及其相应值。

例如:

package main

import (
	"fmt"
)

func main() {
	books := map[string]int{
		"maths":     5,
		"biology":   9,
		"chemistry": 6,
		"physics":   3,
	}
	for key, val := range books {
		fmt.Println(key, val)
	}
}

在上面的代码中,我们定义了一个地图,存储以类型string为键,类型int作为其值的书店的详细信息。然后,我们使用for..range关键字循环浏览其键和值。

在Golang中迭代地图没有任何指定的顺序,我们不应该期望按我们循环时定义的顺序返回密钥。

此代码输出:

physics 3
maths 5
biology 9
chemistry 6

如果我们不想指定值而只返回键,我们根本不定义值变量,而只定义键变量。

例如:

package main

import (
	"fmt"
)

func main() {
	books := map[string]int{
		"maths":     5,
		"biology":   9,
		"chemistry": 6,
		"physics":   3,
	}
	for key := range books {
		fmt.Println(key)
	}
}

这输出以下内容:

maths
biology
chemistry
physics

同样,如果我们对地图的键不感兴趣,我们使用下划线来忽略键并为值定义变量。

例如:

package main

import (
	"fmt"
)

func main() {
	books := map[string]int{
		"maths":     5,
		"biology":   9,
		"chemistry": 6,
		"physics":   3,
	}
	for _, val := range books {
		fmt.Println(val)
	}
}

此输出:

5
9
6
3

如何在Go中循环Struct

Struct是Golang中的一种数据结构,用于将不同的数据类型组合成一个。与数组不同,结构可以包含整数、字符串、布尔值等——所有这些都集中在一个地方。

与地图不同,我们可以轻松地循环其键和值,在Golang中循环结构需要您使用称为reflect的软件包。这允许我们您修改具有任意类型的对象。

例如,让我们创建一个结构并循环它:

package main

import (
	"fmt"
	"reflect"
)

type Person struct {
	Name   string
	Age    int
	Gender string
	Single bool
}

func main() {
	ubay := Person{
		Name:   "John",
		Gender: "Female",
		Age:    17,
		Single: false,
	}
	values := reflect.ValueOf(ubay)
	types := values.Type()
	for i := 0; i < values.NumField(); i++ {
		fmt.Println(types.Field(i).Index[0], types.Field(i).Name, values.Field(i))
	}
}

此输出:

0 Name John
1 Age 17
2 Gender Female
3 Single false

在上面的代码中,我们定义了一个名为Personstruct,具有不同的属性,并创建了该struct的新实例。然后,我们使用reflect包来获取struct及其type值。

通过使用正则for循环,我们增加初始化变量i,直到它达到结构的长度。

我们使用NumField方法来获取结构中的字段总数。types.Field(i).Index方法返回结构中每个键的索引。types.Field(i).Name方法返回结构中每个键的字段名。和values.Field(i)返回结构中每个键的值。

原文地址:https://juejin.cn/post/7157651221375877134
 
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • 《黑马程序员》 category分类的使用(Objective
    分类的作用:在不改变原来类的基础上,可以给类增加一些方法。使用注意 : ①  分类只能增加方法,不可以增加成员变量                ②  分类的方法在实现中可以访问成员变量,不过成员变量必须手动实现。               
    03-16
  • intellij idea go go go!
    安装如下:1. intellij idea2. jdk-8u31-windows-x643.1. scala:Scala是一门多范式的编程语言,一种类似java的编程语言[1]  ,设计初衷是实现可伸缩的语言[2]  、并集成面向对象编程和函数式编程的各种特性。 2.IdeaVimEmulates Vim editorVim是一个类似
    03-08
  • 用 VSCode 搭建 Go 语言开发环境
    用 VSCode 搭建 Go 语言开发环境
    介绍这是来自 Funai Research Institute Digital 的 osw。由于我决定使用 Go 语言进行工作,所以我会在学习时将其记录在备忘录中。如果您可以参考,我将不胜感激。目标听众从现在开始学习 Go 语言的人我正在考虑使用 VSCode本次使用的环境这次,我们将基于以
    03-08
  • 我比较了 Go 和 C# 的速度
    我比较了 Go 和 C# 的速度
    我在 Go 和 C# 之间进行了速度比较。我通常使用 C#,但我有机会使用 Go,并且由于传闻 Go 速度很快,所以我实际测量了它。测量内容我在 Go 和 C# 中执行了一个简单的循环和判断过程,以查看整数 2 到 N 是否为质数。来源是Github参考。测量模式 逻辑内核 8 Wi
    03-08
  • Nginx动态路由的新姿势:使用Go取代lua nginx路由规则
    Nginx动态路由的新姿势:使用Go取代lua nginx路
    导语: 在Nitro 中, 我们需要一款专业的负载均衡器。 经过一番研究之后,Mihai Todor和我使用Go构建了基于Nginx、Redis 协议的路由器解决方案,其中nginx负责所有繁重工作,路由器本身并不承载流量。 这个解决方案过去一年在生产环境中运行顺畅。 以下是我
    03-08
  • 《zw版·Halcon-delphi系列原创教程》 Halcon分
    《zw版·Halcon-delphi系列原创教程》 Halcon分类函数012,polygon,多边形为方便阅读,在不影响说明的前提下,笔者对函数进行了简化::: 用符号“**”,替换:“procedure”:: 用大写字母“X”,替换:“IHUntypedObjectX”:: 省略了字符:“const”、“OleVa
    02-09
  • 设计模式之开放-封闭原则(引申出Objective-C中
    开放封闭原则(OCP原则The Open-Closed Principle)是面向对象的核心设计所在。它是说,软件开发实体(类、模块、函数等)应该可以扩展,但是不能修改。这个原则有两个特征,一个是说“对于扩展是开放的”,另一个是说“对于更改是封闭的”。我们在编写任何ap
    02-09
  • Objective-C——消息、Category和Protocol Objective-C
    Objective-C——消息、Category和Protocol Obje
    面向对象永远是个可以吐槽的话题,从开始提出到推崇备至,到充满质疑,一路走来让人唏嘘不已。面向对象的思想可谓历史悠久,20世纪70年代的Smalltalk可以说是面向对象语言的经典,直到今天我们依然将这门语言视为面向对象语言的基础。面向对象是大部分编程语
    02-09
  • Go语言使用goroutine及通道实现并发详解
    Go语言使用goroutine及通道实现并发详解
    目录使用通道接收数据阻塞接收数据非阻塞接收数据接收任意数据,忽略掉接收的数据循环接收数据使用通道接收数据在上一篇文章中介绍了通道以及使用通道发送数据,本篇接着了解通道的基本内容,如何使用通道接收数据;通道的接收同样使用"-"操作符;使用通道接
  • Go 数据结构之堆排序示例详解
    Go 数据结构之堆排序示例详解
    目录堆排序堆排序过程动画显示开始堆排序代码实现总结堆排序堆排序是一种树形选择排序算法。简单选择排序算法每次选择一个关键字最小的记录需要 O(n) 的时间,而堆排序选择一个关键字最小的记录需要 O(nlogn)的时间。堆可以看作一棵完全二叉树的顺序存储结构
点击排行