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

网站建设开发团队介绍上网站建设公司

网站建设开发团队介绍,上网站建设公司,承德微网站建设,企业做网站怎么做#x1f308;Don’t worry , just coding! 内耗与overthinking只会削弱你的精力#xff0c;虚度你的光阴#xff0c;每天迈出一小步#xff0c;回头时发现已经走了很远。 #x1f4d7;概念 在Go语言中#xff0c;泛型#xff08;Generics#xff09;允许你编写可以处理… Don’t worry , just coding! 内耗与overthinking只会削弱你的精力虚度你的光阴每天迈出一小步回头时发现已经走了很远。 概念 在Go语言中泛型Generics允许你编写可以处理不同数据类型的函数和数据结构。 Go在1.18版本中引入了泛型使得开发者能够更灵活地编写代码减少重复。 泛型允许你定义一个函数或类型使其能够接受任意类型的参数而不需要在定义时指定具体的类型。 代码 基本使用 package mainimport fmt// 定义一个泛型函数 func Print[T any](value T) {fmt.Println(value) }func main() {Print(123) // 打印整数Print(Hello Go!) // 打印字符串Print(3.14) // 打印浮点数 }定义泛型struct package mainimport fmt// 定义一个泛型结构体 type Pair[T any] struct {First TSecond T }func main() {// 创建一个整型的 PairintPair : Pair[int]{First: 1, Second: 2}fmt.Println(intPair)// 创建一个字符串的 PairstringPair : Pair[string]{First: Hello, Second: World}fmt.Println(stringPair) }使用约束类型 package mainimport fmt// 定义一个约束只接受数字类型 type Number interface {int | int32 | int64 | float32 | float64 }// 定义一个泛型函数 func Add[T Number](a, b T) T {return a b }func main() {fmt.Println(Add(1, 2)) // 整数相加fmt.Println(Add(1.5, 2.5)) // 浮点数相加 }切片、链表泛型 看不懂警告大片注释来袭 package mainimport fmt// 定义一个函数SlicesIndex输入一个切片 s 和一个值 v返回一个int类型 // 这里看不懂先别急下面我会好好解释 // S ~[]E这里 S 是一个类型参数表示它是一个切片类型[]E // 使用了类型约束 ~表示 S 可以是任何基于 E 的切片类型例如 []int、[]string 等。 // E comparableE 是另一个类型参数表示可以与其他值进行比较的类型如整型、字符串等 // comparable 是一个内置的约束表示该类型支持相等比较。 // s S函数的第一个参数 s 是一个切片类型为 S。 // v E函数的第二个参数 v 是要查找的值类型为 E func SlicesIndex[S ~[]E, E comparable](s S, v E) int {//在切片中查找值 v 的索引找不到时返回-1for i : range s {if v s[i] {return i}}return -1 }// type List[T any]定义一个名为 List 的泛型类型。 // T 是一个类型参数any 表示 T 可以是任何类型。 type List[T any] struct {head, tail *element[T]//head 和 tail 是两个字段分别指向链表的头部和尾部元素//*element[T] 表示这两个字段是指向 element[T] 类型的指针。}// element[T] 定义结构体类型类型是any数据为val 任意类型指向下一个节点的指针next *element[T] type element[T any] struct {next *element[T]val T }// 定义函数Push lst 是指向链表的指针注意写法是List[T]可以直接修改链表的内容。 // v T 是要插入链表中的值类型为 T即链表支持的任意类型。 func (lst *List[T]) Push(v T) {//判断链表的尾指针 tail 是否为 nilif lst.tail nil {//如果链表为空创建一个新的 element[T]并将其值设置为 v然后将这个新元素的内存地址赋值给链表的头指针 headlst.head element[T]{val: v}//将 tail 指向 head因为此时链表中只有一个元素lst.tail lst.head} else {//如果链表非空创建一个新的 element[T]并将其值设置为 v然后将这个新元素链接到当前 tail 的 next 指针上。lst.tail.next element[T]{val: v}//更新 tail 指针使其指向新添加的元素保持 tail 始终指向链表的最后一个元素。lst.tail lst.tail.next} }// 输入定义函数AllElementslst 是指向链表的指针 // 输出返回一个 []T 类型的切片包含链表中的所有元素。 func (lst *List[T]) AllElements() []T {//定义空的切片 elems用于存储链表中的所有元素。var elems []T//for循环从链表的头部开始遍历。//e 是当前节点的指针初始指向链表的头部 lst.head//循环条件是 e 不为 nil即未到达链表末尾//在每次循环中将当前节点 e 的值 e.val 添加到切片 elems 中for e : lst.head; e ! nil; e e.next {elems append(elems, e.val)}//循环结束后返回包含链表中所有元素的切片 elemsreturn elems }func main() {var s []string{foo, bar, zoo}fmt.Println(index of zoo:, SlicesIndex(s, zoo))_ SlicesIndex[[]string, string](s, zoo)//定义一个 List[int] 类型的变量 lst这是一个空的整型链表lst : List[int]{}//调用push向链表添加元素lst.Push(10)lst.Push(13)lst.Push(23)//打印链表中的全部元素fmt.Println(list:, lst.AllElements()) }//输出 //index of zoo: 2 //list: [10 13 23]泛型理解 代码中看到[T any]之类的字眼就表示这是泛型灵活性泛型使得函数和数据结构能够处理多种类型减少了代码重复。类型安全在编译时检查类型确保类型安全。简化代码通过泛型可以编写更简洁和可重用的代码。 链表、切片泛型还需要多加练习掌握。 无他唯手熟尔。 无人扶我青云志我自踏雪至山巅。
http://www.hkea.cn/news/14494709/

相关文章:

  • 免费外链网站seo发布淄博培训网站建设
  • 秦皇岛建设局官方网站沈阳建信建设工程有限公司位置
  • 网站后台管理代码下载免费素材库
  • 长沙医疗网站建设谷歌搜索入口365
  • 做个中英文网站多少钱互联网技术
  • 万网 网站建设合同网站建设总体方案设计
  • 深圳建设局官方网站网站设计建站
  • 什么网站做全景效果图好公司网站制作招聘
  • 广州建立网站如何绑定域名wordpress
  • 建什么样的网站好wordpress 购物 主题
  • 广西住房建设厅网站首页宣传片制作公司长沙
  • 网站编辑兼职wordpress简单网址导航模板
  • 下沙网站制作徐州人才网最新招聘
  • 国外的设计网站app吗福州大型网站建设
  • 旅游网站模块模板网站大全
  • 常德网站制作模板创作师
  • 做酒店销售上哪个网站好企业邮箱格式怎么注册
  • wordpress搭建实时聊天网站做网站从什么做起
  • c2c网站制作怎么看别人的wordpress
  • asp做微网站设计建设宁夏分行互联网站
  • 门户网站的基本特征信息与服务织梦 手机网站模板
  • 网站建设的7种流程图个人免费推广网站
  • 怎么做qq空间支付网站iis怎么加载网站
  • 怎么做多个网站单点登录外贸seo是什么意思啊
  • 互联网网站建设新闻咨询工程师
  • 网站国外空间空间做子网站
  • 网站关键词怎么做排名给家乡做网站
  • 新加坡网站制作形容网站开发的词
  • 怎么做360网站wordpress网页模板
  • 做网站需要代码吗网站seo优化方案策划书