首页 > 其他分享 >Golang - goto语句

Golang - goto语句

时间:2024-08-13 20:38:53浏览次数:13  
标签:语句 goto 代码 控制流 使用 Golang 跳转

用途

可以无条件地转移到过程中指定的行。该语句通常与条件语句配合使用,可用来实现条件转移,构成循环,跳出循环体等功能,但在结构化程序设计中一般不主张使用goto语句,以免造成程序流程的混乱,使理解和调试程序都产生困难。

语法

goto label;  
...  
label: statement;

注意:

  • 作用域:只能跳转到同一函数内的标签处,不能跨函数跳转。
  • 避免滥用:尽管在某些情况下可以简化代码,但在结构化程序设计中一般不主张使用,因为它可能导致程序流程混乱,增加理解和调试的难度。
  • 跳转限制:该语句与标签之间不能插入变量声明,否则会导致编译错误。

优点

  • 简化复杂控制流:在某些情况下,特别是当需要从深层嵌套的循环或条件语句中快速跳出时,可以提供一种简洁的方式来控制程序的流程。这可以避免编写大量的布尔变量或额外的循环控制逻辑。

  • 提高代码可读性(在某些情况下):虽然这听起来有些矛盾,但在某些特定的、复杂的控制流场景中,可以使代码的逻辑更加直观。然而,这通常取决于具体的使用情况和编程者的能力。

  • 历史遗留代码:在一些老旧的或历史遗留的代码中,可能已经被广泛使用。在这种情况下,继续使用可能是为了保持代码的一致性和减少修改量。

缺点

  • 降低代码可读性:该语句可以轻易地破坏代码的结构和逻辑流,使得其他开发者(或未来的你)难以理解代码的意图。它可能导致所谓的“意大利面条代码”,即代码的流程像一盘乱糟糟的意大利面条一样难以追踪。

  • 增加维护难度:使用该语句的代码更难以维护和修改。因为该语句可以跳转到程序中的任何位置,所以修改一个该语句或它所指向的标签可能会影响到整个程序的逻辑。

  • 鼓励不良编程习惯:过度依赖该语句可能会鼓励开发者编写难以理解和维护的代码。它可能会掩盖更清晰的编程结构(如循环、条件语句、函数等)的使用。

  • 限制代码重用:由于该语句的特定性和局限性,它可能会限制代码的重用性。使用更通用的控制流结构(如函数和循环)可以使代码更易于重用和模块化。

  • 现代编程语言的替代方案:许多现代编程语言提供了更强大、更灵活的控制流结构(如异常处理、协程、闭包等),这些结构通常可以替代该语句的使用,同时提供更好的代码可读性和可维护性。

package main

import "fmt"

func main() {
    n := 22
    maxReTries := 3
    fmt.Println("test0")
label:
    fmt.Println("test1")

    if n > 20 && maxReTries > 0 {
        maxReTries--
        goto label
    }
    fmt.Println("test2")
}

总结

goto在 Go 中的使用应该是有限且谨慎的,通常只用于解决特定的、复杂的控制流问题。在大多数情况下,应该优先考虑其他更清晰的编程结构。

标签:语句,goto,代码,控制流,使用,Golang,跳转
From: https://www.cnblogs.com/beatle-go/p/18357389

相关文章

  • golang 管道channel相关问题
    一funcmain(){ c1:=make(chanany) <-c1}上面代码运行肯定会报deadlock的死锁错误,但是下面这样,如果有一个协程一直在运行,则不会报错,大致就是因为协程还在运行,所属主协程main不确定是否会往管道c1中写数据,所以就会一直阻塞在这里,上面的代码块或者没有一直执行的协程......
  • 使用一次sql语句,返回分页数据和总条数
    日常搬砖,总少不了需要获取分页数据和总行数。一直以来的实践是编码两次sql请求,分别拉分页数据和totolCount。最近我在思考:常规实践为什么不是在一次sql请求中中执行多次sql查询或多次更新,显而易见的优势:①能显著减低“客户端和服务器之间的网络往返次数”,提高吞吐量②简化......
  • MySQL——单表查询(一)简单查询(1)SELECT语句
        MySQL从数据表中查询数据的基本语句是SELECT语句。在SELECT语句中,可以根据自己对数据的需求,使用不同的查询条件,SELECT语句的基本语法格式如下:SELECT[DISTINCT]*|字段名1,字段名2,字段名3,…FROM表名[WHERE条件表达式1][GR......
  • 【PostgreSQL教程】PostgreSQL GROUP BY 语句
    博主介绍:✌全网粉丝20W+,CSDN博客专家、Java领域优质创作者,掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域✌技术范围:SpringBoot、SpringCloud、Vue、SSM、HTML、Nodejs、Python、MySQL、PostgreSQL、大数据、物联网、机器学习等设计与开发。感兴趣的可以先......
  • switch、case语句的问题
    switch、case语句:点击查看代码intstate=1;switch(state){case1:{//状态1执行的程序}case2:{//状态2执行的程序}defalt:{//默认执行的程序}}在工作过程当中的一个switchcase语句为:点击查看代码UINTCCS2X90_HHU_DirectUpgrad......
  • Golang中使用redis,mysql
    一、redis简介redis(REmoteDIctionaryServer)是一个由SalvatoreSanfilippo写key-value存储系统,它由C语言编写、遵守BSD协议、支持网络、可基于内存亦可持久化的日志型、Key-Value类型的数据库,并提供多种语言的API。和Memcached类似,它支持存储的value类型相对更多,包括string(......
  • 使用条件语句登录QQ(Pythonn实验实训项目)
    实验目的1、掌握变量的创建方法及变量赋值运算的使用方法;2、掌握的掌握if-elif--else条件语句和循环语句的嵌套使用;3、掌握比较运算符的应用;4、掌握输入语句的使用方法;5、掌握continue和break语句的用法。二、实验内容使用条件语句实现QQ登录:若用户名和密码都输入正确,则......
  • Python之赋值语句(多重赋值和交换赋值)
    这是《Python入门经典以解决计算问题为导向的Python编程实践》73-74页关于赋值的内容。讲了Python中几种赋值方式。赋值语句1、最简单的赋值:a=b2、多重赋值:a,b,c=1,2,33、交换:a,b=b,a1、最简单的赋值:a=bb可以是数字、字符串,也可以是一个表达式。a必须是一个对象,不......
  • 【第1篇】mysql语句大全及用法
    【第1篇】mysql语句大全及用法【第1篇】mysql语句大全及用法1.创建数据库2.选择数据库3.创建数据表4.插入数据5.查询数据6.更新数据7.删除数据8.修改数据表结构10.删除索引11.创建视图12.删除视图13.创建存储过程14.调用存储过程15.创建触发器17.备份数据......
  • Redis之golang编程实战
    Redis介绍官网:Redis-TheReal-timeDataPlatformRedis可作为数据库、缓存、流引擎和消息代理的开源内存数据存储。被用在不计其数的应用中。Redis连续5年被评为最受欢迎的数据库,是开发人员、架构师和开源贡献者参与社区的中心。Redis是一个开源(BSD许可)的内存数据......