当前位置: 首页 > news >正文

小程序定制开发团队长沙网站seo服务

小程序定制开发团队,长沙网站seo服务,建企业网站行业网,小程序模板平台哪家好函数 需要声明原型支持不定参数 func sum(numbers ...int)int支持返回多值支持递归支持命名返回参数 // 命名返回参数 func add(a, b int) (sum int) {sum a breturn // 这里不需要显式地写出返回值#xff0c;因为已经在函数签名中声明了命名返回参数 } 支持匿名函数、闭包…函数 需要声明原型支持不定参数 func sum(numbers ...int)int支持返回多值支持递归支持命名返回参数 // 命名返回参数 func add(a, b int) (sum int) {sum a breturn // 这里不需要显式地写出返回值因为已经在函数签名中声明了命名返回参数 } 支持匿名函数、闭包函数也是一种类型函数可以赋值给变量本质函数指针一个包中能有名字一样的函数不支持重载!等等均不支持)默认参数 简单demo package mainimport fmt//测试函数 func test(x, y int, s string) (int, string) {n : x yreturn n, fmt.Sprintf(%s,%d\n, s, n) } func main() {a, b : test(1, 2, 你好)// _可以忽略某些值的返回fmt.Println(a)fmt.Println(b)} 回调函数demo 回调函数本质其实就是函数指针作为形参传递给了函数增加了代码的灵活度。 package mainimport fmt// 回调函数1 func testFunc(fn func() int) int {return fn() }// 定义函数类型 type FormatFunc func(s string, x, y int) stringfunc format(fn FormatFunc, s string, x, y int) string {return fn(s, x, y) }func formatHelper(s string, x, y int) string {return fmt.Sprintf(s, x, y) }func main() {s1 : testFunc(func() int {return 100})fmt.Println(s1) //100//匿名函数回调进行格式化返回string//s2 : format(func(s string, x, y int) string {// return fmt.Sprintf(s, x, y)//}, %d %d, 10, 20)s2 : format(formatHelper, %d %d, 10, 20)fmt.Println(s2) }闭包demo 闭包很简单可以理解为返回值是一个函数指针其他的再看就很好理解了。 https://juejin.cn/post/6844903793771937805 package mainimport (fmt )//返回函数指针 func()int func a() func() int {i : 0b : func() int {ifmt.Println(i)return i}return b }func main() {//a执行完返回func() int 的这个函数指针其中赋值给c//那么这里面保存有这个b匿名函数的所有信息实现了自增可以不用定义全局变量c : a()c()c()c()//因为这个是函数指针a() //不会输出i }递归demo package mainimport fmt// 递归1求阶乘 func Factorial(n int) int {if n 1 {return 1}return n * Factorial(n-1) }// 递归2斐波那契数列 func Fibonaci(n int) int {if n 0 {return 0}if n 1 {return 1}return Fibonaci(n-1) Fibonaci(n-2) } func main() {fmt.Println(5!, Factorial(5))fmt.Println(前10项斐波那契数列)for i : 0; i 10; i {fmt.Printf(%d\t, Fibonaci(i))} }异常处理demo 参考文档异常处理 · Go语言中文文档 使用panic抛出错误defer捕获错误一般panic中抛出异常defer中捕获异常之后正常处理。 panic: 内置函数panic后的代码不执行 interface{}直到goroutine整个退出并报告错误 recover: 1.利用recover处理panic指令defer 必须放在 panic 之前定义另外 recover 只有在 defer 调用的函数中才有效。否则当panic时recover无法捕获到panic无法防止panic扩散。 2.recover 处理异常后逻辑并不会恢复到 panic 那个点去函数跑到 defer 之后的那个点。 3.多个 defer 会形成 defer 栈后定义的 defer 语句会被最先调用。 painc处理demo painc会导致程序直接退出平时开发中尽量不随便使用。 一般场景我的服务想要启动必须依赖某些服务、日志、mysql能联通配置文件没问题那么才能启动的时候直接使用panic 一旦服务启动这时你的某行代码不小心触发panic那么这就是重大事故比如别人请求你直接挂了 但是架不住有些地方被动触发panic这时就引入了recover来捕获panic package mainimport fmt// painc部分后面代码不执行 func test() {defer func() {if err : recover(); err ! nil {println(recover panic:, err.(string))}}()panic(panic错误测试)//panic后的代码不执行//fmt.Println(panic后代码) }func main() {test()fmt.Println(main) }error处理 demo package mainimport (errorsfmt )func A() (int, error) {return 2, errors.New(this is an error)}func main() {if _, err : A(); err ! nil {fmt.Println(err)} }recover捕获panic的demo recover需要延迟调用也就是必须在defer的函数内部否则返回nil package mainimport fmtfunc except() {fmt.Println(except延迟函数调用!)fmt.Println(except延迟函数recover:, recover()) }func recoveryDemo() {//等效于下面的匿名延迟函数defer except()//延迟调用recover在函数内部defer func() {if err : recover(); err ! nil {fmt.Println(有效, err.(string))}}()//defer recover() //无效不是延迟调用nildefer fmt.Println(recover()) //无效空defer func() {func() {fmt.Println(defer inner)fmt.Println(defer inner, recover()) //无效}()}()panic(panic错误测试)//不会执行fmt.Println(End of test!) }func main() {recoveryDemo()fmt.Println(main) }总结需要recover捕获panic时defer延迟函数进行接受并且第一个有效的recover只能捕获最后一个painc(如果多个panic),之后有效的recover也返回nil。 defer的使用 defer延迟调用一般释放资源和连接、关闭文件、释放锁等等。类似于java的finally和c中析构函数不过defer一般跟在函数或方法中。 参考博客【Golang】Go语言defer用法大总结(含return返回机制)_golang defer return-CSDN博客 多个defer满足后进先出 defer跟无参、有参函数、方法 package mainimport fmt //无返回值 func test(a int) {defer fmt.Println(defer1 , a)//方法defer func(v int) {fmt.Println(defer2 , v)}(a)//有参函数defer func() {fmt.Println(defer3 , a)}()//无参函数a 100 }func main() {test(0) }defer满足后进先出其次有参情况下a会先传递进入最后等a100之后执行完了再输出。 可读取函数返回值return返回机制 先return结构写入返回值后defer收尾最后携带返回值退出. 无名返回值有名返回值的区别见下面demo 无名有名返回值defer的demo 函数返回值可以无名、有名这个是方便理解的不全代码有名res的话本质局部变量因此defer后会可能会影响res的返回值。而int这个返回值就直接定了。这个很容易引起bug因此看下面例子 package mainimport fmt// 无名返回值 func UnNamed(n int) int {n 100defer func() {n 100fmt.Println(UnNamed defer1, n)}()return n }// 有名返回值 func Named(n int) (res int) {res n 100defer func() {res 100fmt.Println(UnNamed defer1, res)}()// 返回res局部变量因此受defer中的res的逻辑影响return res }func main() {n : 0fmt.Println(main UnNamed return:, UnNamed(n))fmt.Println(main Named return:, Named(n)) }对于第一无名返回值先执行return保存返回值100之后defer输出200最后返回到main函数为100. 第二有名返回值先执行return知道返回的是res(此时100)之后defer修改输出res200,最终返回到main为200. 同理可以更复杂defer可以传入形参的无名有名函数可以进行分析。 package mainimport fmt// 无名返回值 func UnNamed(n int) int {n 100defer func(n int) { //传入100输出110n 10fmt.Println(UnNamed defer2, n)}(n)defer func() { //200n 100fmt.Println(UnNamed defer1, n)}()return n //100 }// 有名返回值 func Named(n int) (res int) {res n 100 //100defer func(res int) { //传入100并且注意是值拷贝并且入栈,110res 10fmt.Println(UnNamed defer2, res)}(res)defer func() { //入栈res 100fmt.Println(UnNamed defer1, res)}()return res //100-200 }func main() {n : 0fmt.Println(main UnNamed return:, UnNamed(n)) //100fmt.Println()fmt.Println(main Named return:, Named(n)) //200 }因此传入指针等等defer函数有无名返回值均会影响main函数中接收到的最终return的值请注意。 调用os.Exit时defer不会被执行defer与panic进行配合处理异常 nil相关 nil代表某些数据类型的零值 不同类型0值 bool false number 0 string slice、map、channel、pointer、interface{} nil 如果是结构体那么它的零值是内部所有属性的零值的集合 nil 和empty的区别 这里分析了slice、map中的nil和empty的区别。 package mainimport fmttype Student struct {name stringage int }func main() {// nil slice,其实可以创建append对nil slice进行了处理但是map就不行var s1 []Student//s1 append(s1, Student{Bob, 19})fmt.Println(s1)if s1 nil {fmt.Println(s1nil)}// 不是nil slice其实本质上是创建了内部ptr指向一个空间为0的数组var s2 make([]Student, 0)if s2 nil {fmt.Println(s2nil)}// nil mapvar m1 map[int]Studentif m1 nil {fmt.Println(m1nil)}//可以查询,但是无法添加键值对,panic(assignment to entry in nil map)//m1[1] Student{hhh, 123}//if val, ok : m1[1]; ok {// fmt.Println(ok, val)//} else {// fmt.Println(not ok)//}fmt.Println(m1)//不是nil map已经初始化了0个空间的mapvar m2 make(map[int]Student, 0)//可以查询插入数据了m2[1] Student{hhh, 123}if val, ok : m2[1]; ok {fmt.Println(ok, val)} else {fmt.Println(not ok)}fmt.Println(m2)}
http://www.zqtcl.cn/news/54573/

相关文章:

  • 做网站分为竞价和优化ui设计灵感网站
  • 个人网站怎么建立流程齐家网装修怎么收费
  • 厦门建站服务网站建设实施计划
  • wordpress 注册邮件设置aso优化注意什么
  • 怎样做一个购物型的网站番禺区手机版网站建设
  • 商城网站制作需要多少费用东莞建网站的公
  • 兰州网站建设多少钱系统开发人员有哪几类
  • 购物网站 购物车界面如何做pc端ui设计
  • 盐城网站设计公司自动生成设计图
  • seo爱站网网页制作和网页制作
  • 陕西省建设厅官方网站百度收录有什么用
  • 自己做的博客网站站长之家app
  • 佛山新网站建设服务公司网站备案没公司名称
  • 深圳制作网站的公司简介wordpress外贸
  • 网站项目的工作流程运营网站开发工作招聘
  • 汤原建设局网站温州网站制作建设
  • 网站制作珠海公司国家商标注册查询官网入口
  • 咸阳做网站托管qq是腾讯还是阿里
  • 做app和做网站那个难门户网站含义
  • 家居网站建设费用企业建设网站的
  • HTML5网站建设案例诸城企业网站建设
  • 能做SEO优化的网站建设凡客诚品官方商城
  • 甘肃省城乡城乡建设厅网站首页以net结尾的网站
  • 电子商务网站建设 大纲wordpress 皮主题
  • 在线制作网站系统静态网站
  • 电商网站改版思路企业如何 建设好自己的网站
  • 建筑设计地图网站电子商务网站建设与管理 技能实训
  • 怎样为企业设计网站微信公众号和网站建设
  • 静态网站设计怎么做宏润建设集团股份有限公司网站
  • 服务器网站建设实训报告商丘专业做网站公司