go语言函数练习题 go语言chan

GO语言(十八):模糊测试入门(下)-Reverse为了解决这个问题,如果输入不是有效的 UTF-8  , 让我们返回一个错误 。
a.在您的文本编辑器中,将现有Reverse函数替换为以下内容 。
如果输入字符串包含无效的 UTF-8 字符,此更改将返回错误 。
b.由于 Reverse 函数现在返回错误,因此修改main函数以丢弃额外的错误值 。将现有main功能替换为以下内容 。
这些调用Reverse应该返回一个 nil 错误 , 因为输入字符串是有效的 UTF-8 。
c.您将需要导入错误和 unicode/utf8 包 。main.go 中的 import 语句应如下所示 。
d.修改reverse_test.go文件检查是否有错误,如果返回产生错误则跳过测试 。
除了返回之外,您还可以调用t.Skip()以停止执行该模糊输入 。
a.使用 go test 运行测试
b.使用go test -fuzz=Fuzz进行模糊测试,几秒钟后,停止用ctrl-C模糊测试 。
除非您通过-fuzztime标志进行限制 , 否则模糊测试将一直运行 , 直到遇到失败的输入 。如果没有发生故障,默认是永远运行,并且可以使用 中断该过程ctrl-C 。
c. 使用go test -fuzz=Fuzz -fuzztime 30s 。如果没有30 秒发现失败,它会在退出模糊测试 。
模糊测试通过了!
做得很好!您刚刚学习了在 Go 中进行模糊测试 。
— main.go —
— reverse_test.go —
3.6 Go语言函数的延迟调用(Deferred Code)在以下这段代码中 , go语言函数练习题我们操作一个文件,无论成功与否都需要关闭文件句柄 。这里在三处不同go语言函数练习题的位置都调用go语言函数练习题了file.Close()方法 , 代码显得非常冗余 。
我们利用延迟调用来优化代码 。定义后的defer代码,会在return之前返回,让代码显得更加紧凑,且可读性变强,对上面的代码改造如下:
我们通过这个示例来看一下延迟调用与正常代码之间的执行顺序
先简单分析一下代码逻辑:
从输出中,我们可以观察到如下现象:
从这个实例中 , 我们很明显观察到,defer语句是在return之前执行
如果一个函数内定义了多个defer,则调用顺序为LIFO(后进先出)方式执行 。
仍然是相同的例子,但是在TestDefer中我们定义了三个defer输出,根据LIFO原则,输出的顺序是3rd-2nd-1st,根据最后的结果,也是逆向向上执行defer输出 。
就在整理这篇笔记的时候,发现了自己的认知误区 , 主要是本节实例三中发现的,先来看一下英文的描述:
对于上面的这段话的理解:
下面是代码执行输出 , 我们来一起分析一下:
虽然在a()函数内,显示的返回了10,但是main函数中得到的结果是defer函数自增后的结果 , 我们来分析一下代码:
在这篇文章的上一版,我曾经尝试用指针取解释defer修改返回值的类型,但是感觉不够透彻,也让阅读者非常困惑 , 索性参考了一下go官方blog中的一篇文章,在此基础上进行了扩展 。如需要阅读原文,可以参考下面的文章 。
GO语言学习系列八——GO函数(func)的声明与使用 GO是编译性语言,所以函数的顺序是无关紧要的,为了方便阅读,建议入口函数 main 写在最前面,其余函数按照功能需要进行排列
GO的函数 不支持嵌套,重载和默认参数
GO的函数 支持 无需声明变量,可变长度,多返回值,匿名,闭包等
GO的函数用 func 来声明 , 且左大括号 { 不能另起一行
一个简单的示例:
输出为:
参数:可以传0个或多个值来供自己用
返回:通过用 return来进行返回

推荐阅读