欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

如何使用Go-Linq

本篇內(nèi)容主要講解“如何使用Go-Linq”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“如何使用Go-Linq”吧!

創(chuàng)新互聯(lián)建站成立十多年來(lái),這條路我們正越走越好,積累了技術(shù)與客戶資源,形成了良好的口碑。為客戶提供網(wǎng)站設(shè)計(jì)制作、做網(wǎng)站、網(wǎng)站策劃、網(wǎng)頁(yè)設(shè)計(jì)、主機(jī)域名、網(wǎng)絡(luò)營(yíng)銷、VI設(shè)計(jì)、網(wǎng)站改版、漏洞修補(bǔ)等服務(wù)。網(wǎng)站是否美觀、功能強(qiáng)大、用戶體驗(yàn)好、性價(jià)比高、打開(kāi)快等等,這些對(duì)于網(wǎng)站建設(shè)都非常重要,創(chuàng)新互聯(lián)建站通過(guò)對(duì)建站技術(shù)性的掌握、對(duì)創(chuàng)意設(shè)計(jì)的研究為客戶提供一站式互聯(lián)網(wǎng)解決方案,攜手廣大客戶,共同發(fā)展進(jìn)步。

坑爹的集合

go在進(jìn)行集合操作時(shí),有很不舒服的地方,起初我真的是無(wú)力吐槽,又苦于找不到一個(gè)好的第三方庫(kù),只能每次寫著重復(fù)代碼。舉個(gè)栗子

類 學(xué)生{
姓名 
年齡
性別
}

1、現(xiàn)在有10個(gè)學(xué)生的數(shù)組,如果我要統(tǒng)計(jì)所有年齡大于20歲的人,那我需要

一、遍歷

二、自定義條件

三、再append數(shù)組添加。

2、接著我又要統(tǒng)計(jì)性別為男的所有學(xué)生,我又要重復(fù)上面的步驟。

你說(shuō)坑爹不坑爹,那是真的坑!

吐槽之處

重點(diǎn)是95%的代碼都是一樣的,只是那百分之幾有點(diǎn)區(qū)別。對(duì)于一名合格的程序員,我是堅(jiān)決不能忍受這種情況的發(fā)生。

解決方法

群里尋求大神幫助

混跡各大論壇,博客尋找有效信息

終于在老夫的不懈努力下,發(fā)現(xiàn)了一個(gè)庫(kù)。它就是go-linq,使用它,能夠解決我對(duì)集合大部分的需求,讓編程更順手,讓工作更強(qiáng)經(jīng)勁。

什么是Linq呢?

LINQ(發(fā)音:Link)是語(yǔ)言級(jí)集成查詢(Language INtegrated Query)

?LINQ是一種用來(lái)進(jìn)行數(shù)據(jù)訪問(wèn)的編程模型,使得.NET語(yǔ)言可以直接支持?jǐn)?shù)據(jù)查詢

Linq 是C#編程的一個(gè)爽的飛起的語(yǔ)法糖,使用過(guò)的人無(wú)一不對(duì)其高級(jí)的特性,偏自然語(yǔ)義化的折服。

那么問(wèn)題來(lái)了

那么問(wèn)題來(lái)了,go有沒(méi)有類似的東西呢,答案是肯定的,這次是我們馬上要說(shuō)的庫(kù)Go-linq。通過(guò)這名稱你就知道他是做什么的了。不多說(shuō)了,直接開(kāi)Lu。

開(kāi)始使用Go-Linq

Go-Linq介紹

一個(gè)強(qiáng)大的語(yǔ)言集成查詢(LINQ)庫(kù)的Go。

沒(méi)有依賴!

使用迭代器模式完成延遲求值

對(duì)并發(fā)使用是安全的

支持泛型函數(shù),使您的代碼更干凈,并且沒(méi)有類型斷言

支持?jǐn)?shù)組、片、映射、字符串、通道和自定義集合

使用

go get gopkg.in/ahmetb/go-linq.v3
import . "gopkg.in/ahmetb/go-linq.v3"

import . 的意思是直接使用庫(kù)的方法,而不使用前綴。當(dāng)然你也可以添加,官方的寫法是這樣的。

案例

定義一個(gè)員工類

type Employee struct {
	Name     string
	Age      int
	Sex      int // 0 男 1 女
	WorkYear int //工齡
}

創(chuàng)建不同的列表

func initEmployeeData() []Employee {
	list := make([]Employee, 0)

	for i := 0; i < 10; i++ {
		list = append(list, Employee{
			Name:     "張" + strconv.Itoa(i%4),
			Age:      10 + i,
			Sex:      i % 2,
			WorkYear: 1 + i%3,
		})
	}
	return list
}

func initSameEployeeData() []Employee {
	list := make([]Employee, 0)

	for i := 0; i < 10; i++ {
		list = append(list, Employee{
			Name:     "張一",
			Age:      10,
			Sex:      i % 2,
			WorkYear: 1,
		})
	}
	return list
}

小試牛刀-distinct去除開(kāi)始

func distinct() {
	var manEmpRows []Employee
	rows := initSameEployeeData()
	fmt.Println("===性別是男的所有員工列表去重===")
	From(rows).Distinct().ToSlice(&manEmpRows)
	fmt.Println(manEmpRows)
}

===性別是男的所有員工列表去重=== [{張一 10 0 1} {張一 10 1 1}]

結(jié)果非常nice,本來(lái)我們需要的繁瑣步驟,一個(gè)linq就解決了,是不是戝Diao!

眾里尋他千百度-where過(guò)濾

//where 過(guò)濾條件
var manEmpRows []Employee
fmt.Println("===過(guò)濾性別是男的員工===")
From(rows).WhereT(func(e Employee) bool {
return e.Sex == 0
}).ToSlice(&manEmpRows)
fmt.Println(manEmpRows)

榮獲三甲-take+sort

//Take 選取從頭開(kāi)始的幾個(gè)元素
fmt.Println("===過(guò)濾性別是男的員工,只選擇前倆個(gè)===")
From(rows).WhereT(func(e Employee) bool {
return e.Sex == 0
}).Take(2).ToSlice(&manEmpRows)
fmt.Println(manEmpRows)

排序。單字段排序,多字段組合排序。

//where過(guò)濾+排序
fmt.Println("===過(guò)濾性別是女的員工,且按照工齡降序排序===")
From(rows).WhereT(func(e Employee) bool {
return e.Sex == 1
}).OrderByDescendingT(func(e Employee) int {
return e.WorkYear
}).ToSlice(&manEmpRows)
fmt.Printf("%+v\n", manEmpRows)

//where 過(guò)濾+雙重排序
fmt.Println("===過(guò)濾性別是女的員工,且按照工齡降序排序,再按照年齡升序排序===")
From(rows).WhereT(func(e Employee) bool {
return e.Sex == 1
}).OrderByDescendingT(func(e Employee) int {
return e.WorkYear
}).ThenByT(func(e Employee) int {
return e.Age
}).ToSlice(&manEmpRows)

弱水三千 只取一瓢-Select

//只獲取元素中的某些字段,list輸出
var outputRows []string
fmt.Println("===只獲取元素中的某些字段,list輸出===")
From(rows).SelectT(func(e Employee) string {
return e.Name
}).ToSlice(&outputRows)
fmt.Println(outputRows)

蜂合蟻聚-聚合

//聚合函數(shù)
query := From(rows).SelectT(func(e Employee) int {
return e.Age
})
fmt.Println(query.Average())
fmt.Println(query.Max())
fmt.Println(query.Min())
fmt.Println(query.Count())[]

其他

//獲取結(jié)構(gòu)體數(shù)組首個(gè)元素或者末個(gè)
firstItem := From(rows).First()
fmt.Println(firstItem)
lastItem := From(rows).Last()
fmt.Println(lastItem)

到此,相信大家對(duì)“如何使用Go-Linq”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

當(dāng)前文章:如何使用Go-Linq
當(dāng)前地址:http://www.chinadenli.net/article24/iigpce.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營(yíng)銷推廣移動(dòng)網(wǎng)站建設(shè)建站公司動(dòng)態(tài)網(wǎng)站服務(wù)器托管品牌網(wǎng)站制作

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

手機(jī)網(wǎng)站建設(shè)