摘要:和都是目前在各自領(lǐng)域最流行的開發(fā)語言之一。在機(jī)器學(xué)習(xí)數(shù)據(jù)分析領(lǐng)域成為必學(xué)語言。
Golang和Python都是目前在各自領(lǐng)域最流行的開發(fā)語言之一。
Golang其高效而又友好的語法,贏得了很多后端開發(fā)人員的青睞,最適用于高并發(fā)網(wǎng)絡(luò)編程的語言之一。
Python不用說,TIOBE排行榜的前十常駐居民,現(xiàn)在已經(jīng)穩(wěn)定在前五了。在機(jī)器學(xué)習(xí)、AI、數(shù)據(jù)分析領(lǐng)域成為必學(xué)語言。
兩門編程語言在語法上都有各自的特點(diǎn),而且都易學(xué)易用。
本文對(duì)比這兩門語言目的不是爭(zhēng)誰優(yōu)誰略,只是為了對(duì)比學(xué)習(xí),適合掌握Python想學(xué)Go或者掌握Go想學(xué)Python的同學(xué)們參考。
Go和Python,一個(gè)是靜態(tài)語言一個(gè)是動(dòng)態(tài)語言,從各個(gè)方面來看,都有根本性的差異,所以,文中很多內(nèi)容不進(jìn)行深入的比較了,我們只從程序員最直觀的語法面做對(duì)比。
為了便于閱讀,文中涉及代碼都采用盡量簡(jiǎn)單的語句呈現(xiàn)
字符編碼 PythonPython中默認(rèn)的編碼格式是 ASCII 格式,程序文件中如果包含中文字符(包括注釋部分)需要在文件開頭加上 # -*- coding: UTF-8 -*- 或者 #coding=utf-8 就行了
Golang原生支持Unicode
保留字(關(guān)鍵字) Python30個(gè)關(guān)鍵字
and exec not assert finally or break for pass class from print continue global raise def if return del import try elif in while else is with except lambda yieldGolang
25個(gè)關(guān)鍵字
break default func interface select case defer go map struct chan else goto package switch const fallthrough if range type continue for import return var注釋 Python
# 單行注釋 """ 多行注釋 多行注釋 """ """ 多行注釋 多行注釋 """Golang
//單行注釋 /* 多行注釋 多行注釋 */變量賦值 Python
Python是動(dòng)態(tài)語言,所以在定義變量的時(shí)候不需要申明類型,直接使用即可。
Python會(huì)根據(jù)值判斷類型。
name = "Zeta" # 字符串變量 age = 38 # 整數(shù) income = 1.23 # 浮點(diǎn)數(shù)
多變量賦值
a,b = 1,2 # a=1; b=2 c = d = 3 # c=3; d=3Golang
Go是靜態(tài)語言,是強(qiáng)類型的,但是Go語言也允許在賦值變量時(shí)確定類型。
因此Go有多種申明變量的方式
// 1. 完整的申明并賦值 var a int a = 1 // 2. 聲明變量類型同時(shí)賦值 var a int = 1 // 3. 不聲明類型,賦值時(shí)確定 var a = 1 // 4. 不用 var 關(guān)鍵字申明變量并賦值后確定類型 a := 1
注意,Go中的new關(guān)鍵字并不是聲明變量,而是返回該類型的指針
a := new(int) //這時(shí)候a是一個(gè)*int指針變量標(biāo)準(zhǔn)數(shù)據(jù)類型 Python 的標(biāo)準(zhǔn)數(shù)據(jù)類型有:
Boolean(布爾值)
Number(數(shù)字)
String(字符串)
List(列表)
Tuple(元組)
Set(集合)
Dictionary(字典)
Golangboolean(布爾值)
numeric(數(shù)字)
string(字符串)
數(shù)組(數(shù)組)
slice(切片:不定長(zhǎng)數(shù)組)
map(字典)
struct(結(jié)構(gòu)體)
pointer(指針)
function(函數(shù))
interface(接口)
channel(通道)
總結(jié)Python中的List列表對(duì)應(yīng)Go語言中的Slice切片
Python中的Dictionary字典對(duì)應(yīng)Go語言中的map
有一些值得注意的地方:
Go是支持函數(shù)編程的語言,所以在Go語言中函數(shù)是一個(gè)類型
Go語言不是面向?qū)ο蟮恼Z言,沒有定義類的關(guān)鍵字Class,要實(shí)現(xiàn)OOP風(fēng)格編程,是通過struct、interface類型實(shí)現(xiàn)的
Python中的元組和集合在Go中都沒有
channel是Go里獨(dú)有的類型,多線程之間的通信就靠它
數(shù)據(jù)類型轉(zhuǎn)換 PythonPython類型轉(zhuǎn)換非常簡(jiǎn)單,用類型名作為函數(shù)名即可。
int(n) # 將數(shù)字n轉(zhuǎn)換為一個(gè)整數(shù) float(n) # 將數(shù)字n轉(zhuǎn)換到一個(gè)浮點(diǎn)數(shù) str(o) # 將對(duì)象 obj 轉(zhuǎn)換為字符串 tuple(s) # 將序列 s 轉(zhuǎn)換為一個(gè)元組 list(s) # 將序列 s 轉(zhuǎn)換為一個(gè)列表 set(s) # 將序列 s 轉(zhuǎn)換為一個(gè)集合Golang
Go語言的基礎(chǔ)類型轉(zhuǎn)換和Python差不多,也是用類型名作為函數(shù)名
i := 1024 f := float32(i) i = float32(f)
另外,Python中可以直接轉(zhuǎn)換數(shù)字字符串和數(shù)字:
s = "123" i = 456 print(int(s), str(i))
但是Go是不可以的。
Go語言的字符串處理很不同,string()只能用于[]byte類型轉(zhuǎn)換成字符串,其他基礎(chǔ)類型的轉(zhuǎn)換需要用strconv包,另外,其他類型轉(zhuǎn)換成為string類型除了用strconv包,還可以用fmt.Sprintf函數(shù):
package main import ( "fmt" "strconv" ) func main() { s := "123" i, _ := strconv.Atoi(s) println(i) s2 := fmt.Sprintf("%d", 456) println(s2) }
Go中的interface類型是不能直接轉(zhuǎn)換成其他類型的,需要使用到斷言
package main func main() { var itf interface{} = 1 i, ok := itf.(string) println("值:", i, "; 斷言結(jié)果", ok) j, ok := itf.(int) println("值:", j, "; 斷言結(jié)果", ok) }
輸出為:
值: ; 斷言結(jié)果 false 值: 1 ; 斷言結(jié)果 true條件語句 Python
Python傳統(tǒng)的判斷語句如下
if name == "zeta": # 判斷變量是否為 zeta print("Welcome boss") # 并輸出歡迎信息 else: print("Hi, " + name)
Python不支持三元表達(dá)式,但是可以用一種類似的替代辦法
title = "boss" name = "zeta" if title == "boss" else "chow" print(name)
邏輯與用 and ,邏輯或用 or
GolangGo的if的語法類似Java,但是表達(dá)式不需要使用()
if a > b{ println("a > b") } else { println("a <= b") }
Go同樣沒有三元表達(dá)式,并且也沒有什么替代方法。
另外,Go允許在if的表達(dá)式里定義變量,定義并賦值的表達(dá)式與判斷的表達(dá)式用;隔開,常見的情況是獲取函數(shù)返回error,然后判斷error是否為空:
if err := foo(); err != nil { println("發(fā)生一些錯(cuò)誤") }
與Python不同,邏輯與用 &&, 邏輯或用||
循環(huán)語句 PythonPython中有while和for兩種循環(huán),都可以使用break跳出循環(huán)和continue立即進(jìn)入下一輪循環(huán),另外,Python的循環(huán)語句還可以用else執(zhí)行循環(huán)全部完畢后的代碼,break跳出后不會(huì)執(zhí)行else的代碼
while 條件循環(huán),
count = 0 while (count < 9): print("The count is:", count) count = count + 1 if count == 5: break # 可以比較以下break和不break的區(qū)別 pass else: print("loop over")
for 遍歷循環(huán),循環(huán)遍歷所有序列對(duì)象的子項(xiàng)
names = ["zeta", "chow", "world"] for n in names: print("Hello, " + n) if n == "world": break pass else: print("Good night!")
for循環(huán)中也可以用else,(注釋掉代碼中的break試試看。)
GolangGo語言只有一個(gè)循環(huán)語句for,但是根據(jù)不同的表達(dá)式,for有不同的表現(xiàn)
for 前置表達(dá)式; 條件表達(dá)式; 后置表達(dá)式 { //... }
前置表達(dá)式 在每輪循環(huán)前運(yùn)行,可以用于聲明變量或調(diào)用函數(shù)返回;
條件表達(dá)式 滿足該表達(dá)式則執(zhí)行下一輪循環(huán),否則退出循環(huán);
后置表達(dá)式 在循環(huán)完成后執(zhí)行
經(jīng)典的用法:
for i := 0; i < 10; i++ { println(i) }
我們可以忽略掉前置和后置表達(dá)式
sum := 1 for sum < 10 { sum += sum }
設(shè)置可以忽略掉全部表達(dá)式,也就是無限循環(huán)
for { print(".") }
Go的for循環(huán)同樣可以使用 break退出循環(huán)和continue立即進(jìn)行下一輪循環(huán)。
for除了配合表達(dá)式循環(huán),同樣也可以用于遍歷循環(huán),需要用到range關(guān)鍵字
names := []string{"zeta", "chow", "world"} for i, n := range names { println(i,"Hello, " + n) }函數(shù) Python
用def關(guān)鍵字定義函數(shù),并且在Python中,作為腳本語言,調(diào)用函數(shù)必須在定義函數(shù)之后。
def foo(name): print("hello, "+name) pass foo("zeta")
默認(rèn)參數(shù) Python定義函數(shù)參數(shù)時(shí),可以設(shè)置默認(rèn)值,調(diào)用時(shí)如果沒有傳遞該參數(shù),函數(shù)內(nèi)將使用默認(rèn)值,默認(rèn)值參數(shù)必須放在無默認(rèn)值參數(shù)后面。
def foo(name="zeta"): print("hello, "+name) pass foo()
關(guān)鍵字參數(shù) 一般函數(shù)傳遞參數(shù)時(shí),必須按照參數(shù)定于的順序傳遞,但是Python中,允許使用關(guān)鍵字參數(shù),這樣通過指定參數(shù)明,可以不按照函數(shù)定義參數(shù)的順序傳遞參數(shù)。
def foo(age, name="zeta"): print("hello, "+name+"; age="+str(age)) pass foo(name="chow", age=18)
不定長(zhǎng)參數(shù),Python支持不定長(zhǎng)參數(shù),用*定義參數(shù)名,調(diào)用時(shí)多個(gè)參數(shù)將作為一個(gè)元祖?zhèn)鬟f到函數(shù)內(nèi)
def foo(*names): for n in names: print("hello, "+n) pass foo("zeta", "chow", "world")
return 返回函數(shù)結(jié)果。
GolangGo用func定義函數(shù),沒有默認(rèn)值參數(shù)、沒有關(guān)鍵字參數(shù),但是有很多其他特征。
func main() { println(foo(18, "zeta")) } func foo(age int, name string) (r string) { r = fmt.Sprintf("myname is %s , age %d", name, age) return }
函數(shù)的定義和調(diào)用沒有順序的限制。
Go的函數(shù)不僅可以定義函數(shù)返回值類型,還可以申明返回值變量,當(dāng)定義了返回值變量時(shí),函數(shù)內(nèi)的return語句可以不需要帶返回值,函數(shù)會(huì)默認(rèn)使用返回值變量返回。
可變參數(shù)
使用…類型定義可變參數(shù),函數(shù)內(nèi)獲得的參數(shù)實(shí)際是該類型的slice對(duì)象
func main() { println(foo(18, “zeta”, “chow”, “world”)) } func foo(age int, names …string) (r string) { for _, n := range names { r += fmt.Sprintf(“myname is %s , age %d ”, n, age) } return }
defer句
defer語句后面指定一個(gè)函數(shù),該函數(shù)會(huì)延遲到本函數(shù)return后再執(zhí)行。
defer語句在Go語言中非常有用,詳細(xì)可以查閱本專欄的另一篇文章《Golang研學(xué):如何掌握并用好defer(延遲執(zhí)行)》
func foo() { defer fmt.Println("defer run") fmt.Println("Hello world") return }
運(yùn)行結(jié)果:
Hello world defer run
另外,在Go語言中函數(shù)也是類型,可以作為參數(shù)傳遞給別的函數(shù)
func main() { n := foo(func(i int, j int) int { return i + j }) println(n) } func foo(af func(int, int) int) int { return af(1, 2) }
上面這個(gè)例子直接在參數(shù)定義時(shí)使用函數(shù)類型,看上去有點(diǎn)混亂
再看來看一個(gè)清晰并完整的例子,說明全在注釋里。
package main type math func(int, int) int //定義一個(gè)函數(shù)類型,兩個(gè)int參數(shù),一個(gè)int返回值 //定義一個(gè)函數(shù)add,這個(gè)函數(shù)兩個(gè)int參數(shù)一個(gè)int返回值,與math類型相符 func add(i int, j int) int { return i + j } //再定義一個(gè)multiply,這個(gè)函數(shù)同樣符合math類型 func multiply(i, j int) int { return i * j } //foo函數(shù),需要一個(gè)math類型的參數(shù),用math類型的函數(shù)計(jì)算第2和第3個(gè)參數(shù)數(shù)字,并返回計(jì)算結(jié)果 //稍后在main中我們將add函數(shù)和multiply分別作為參數(shù)傳遞給它 func foo(m math, n1, n2 int) int { return m(1, 2) } func main() { //傳遞add函數(shù)和兩個(gè)數(shù)字,計(jì)算相加結(jié)果 n := foo(add, 1, 2) println(n) //傳遞multply和兩個(gè)數(shù)字,計(jì)算相乘結(jié)果 n = foo(multiply, 1, 2) println(n) }
結(jié)果
3 2模塊 Python
模塊是一個(gè).py文件
模塊在第一次被導(dǎo)入時(shí)執(zhí)行
一個(gè)下劃線定義保護(hù)級(jí)變量和函數(shù),兩個(gè)下劃線定義私有變量和函數(shù)
導(dǎo)入模塊習(xí)慣性在腳本頂部,但是不強(qiáng)制
Golang與文件和文件名無關(guān),每一個(gè)文件第一行用package定義包名,相同包名為一個(gè)包
包中的變量第一次引用時(shí)初始化,如果包中包含init函數(shù),也會(huì)在第一次引用時(shí)執(zhí)行(變量初始化后)
保重首寫字母大寫的函數(shù)和變量為共有,小寫字母為私有,Golang不是面向?qū)ο蟮模圆淮嬖诒Wo(hù)級(jí)。
導(dǎo)入模塊必須寫在package之后,其他代碼之前。
導(dǎo)入包 Python在Python中,使用import導(dǎo)入模塊。
#!/usr/bin/python # -*- coding: UTF-8 -*- # 導(dǎo)入模塊 import support support.print_func(“Runoob”)
還可以使用from import導(dǎo)入模塊指定部分
from modname import name1[, name2[, ... nameN]]
為導(dǎo)入的包設(shè)置別名用 as關(guān)鍵字
import datetime as dtGolang
也是使用import導(dǎo)入包,導(dǎo)入包指定的是包的路徑,包名默認(rèn)為路徑中的最后部分
import "net/url" //導(dǎo)入url包
多個(gè)包可以用()組合導(dǎo)入
import ( "fmt" "net/url" )
為導(dǎo)入的包設(shè)置別名, 直接在導(dǎo)入包時(shí),直接在報(bào)名前面添加別名,用空格隔開
import ( f "fmt" u "net/url" )錯(cuò)誤和異常 Python
Python中用經(jīng)典的 try/except 捕獲異常
try: <語句> #運(yùn)行別的代碼 except <異常名稱>: <語句> # except <異常名稱>,<數(shù)據(jù)>: <語句> #如果引發(fā)了指定名稱的異常,獲得附加的數(shù)據(jù)
還提供了 else 和 finally
如果沒發(fā)生異常的執(zhí)行else語句塊,finally塊的代碼無論是否捕獲異常都會(huì)執(zhí)行
Python內(nèi)建了很全面的異常類型名稱,同時(shí)能自定義異常類型
GolangGolang里沒有用經(jīng)典的 try/except捕獲異常。
Golang提供兩種錯(cuò)誤處理方式
函數(shù)返回error類型對(duì)象判斷錯(cuò)誤
panic異常
一般情況下在Go里只使用error類型判斷錯(cuò)誤,Go官方希望開發(fā)者能夠很清楚的掌控所有的異常,在每一個(gè)可能出現(xiàn)異常的地方都返回或判斷error是否存在。
error是一個(gè)內(nèi)置的接口類型
type error interface { Error() string }
通常,使用error異常處理類似這樣:
package main import "fmt" func foo(i int, j int) (r int, err error) { if j == 0 { err = fmt.Errorf("參數(shù)2不能為 %d", j) //給err變量賦值一個(gè)error對(duì)象 return //返回r和err,因?yàn)槎x了返回值變量名,所以不需要在這里寫返回變量 } return i / j, err //如果沒有賦值error給err變量,err是nil } func main() { //傳遞add函數(shù)和兩個(gè)數(shù)字,計(jì)算相加結(jié)果 n, err := foo(100, 0) if err != nil { //判斷返回的err變量是否為nil,如果不是,說明函數(shù)調(diào)用出錯(cuò),打印錯(cuò)誤內(nèi)容 println(err.Error()) } else { println(n) } }
panic可以手工調(diào)用,但是Golang官方建議盡量不要使用panic,每一個(gè)異常都應(yīng)該用error對(duì)象捕獲。
Go語言在一些情況下會(huì)觸發(fā)內(nèi)建的panic,例如 0 除、數(shù)組越界等,修改一下上面的例子,我們讓函數(shù)引起0除panic
package main func foo(i int, j int) (r int) { return i / j } func main() { //傳遞add函數(shù)和兩個(gè)數(shù)字,計(jì)算相加結(jié)果 n := foo(100, 0) println(n) }
運(yùn)行后會(huì)出現(xiàn)
panic: runtime error: integer divide by zero goroutine 1 [running]: main.foo(...) /lang.go:4 main.main() /lang.go:9 +0x12 exit status 2
手工panic可以這樣:
func foo(i int, j int) (r int) { if j == 0 { panic("panic說明: j為0") } return i / j }
運(yùn)行后,可以看到,錯(cuò)誤消息的第一句:
panic: panic說明: j為0面向?qū)ο?/b> Python
Python完全支持面向?qū)ο蟮摹?/p> Golang
盡管Go語言允許面向?qū)ο蟮娘L(fēng)格編程,但是本身并不是面向?qū)ο蟮?/p>
官方FAQ原文
Is Go an object-oriented language?
Yes and no. Although Go has types and methods and allows an object-oriented style of programming, there is no type hierarchy. The concept of “interface” in Go provides a different approach that we believe is easy to use and in some ways more general. There are also ways to embed types in other types to provide something analogous—but not identical—to subclassing. Moreover, methods in Go are more general than in C++ or Java: they can be defined for any sort of data, even built-in types such as plain, “unboxed” integers. They are not restricted to structs (classes).多線程 Python
使用thread模塊中的start_new_thread()函數(shù)
使用threading模塊創(chuàng)建線程
Golang用關(guān)鍵 go創(chuàng)建協(xié)程goroutine
在go關(guān)鍵字后指定函數(shù),將會(huì)開啟一個(gè)協(xié)程運(yùn)行該函數(shù)。
package main import ( "fmt" "time" ) func foo() { for i := 0; i < 5; i++ { fmt.Println("loop in foo:", i) time.Sleep(1 * time.Second) } } func main() { go foo() for i := 0; i < 5; i++ { fmt.Println("loop in main:", i) time.Sleep(1 * time.Second) } time.Sleep(6 * time.Second) }
Go語言中,協(xié)程之間的通信是通過channel實(shí)現(xiàn)的:
package main import ( "fmt" "time" ) //接受一個(gè)chan類型的參數(shù)c func foo(c chan int) { time.Sleep(1 * time.Second) //等待1秒 c <- 1024 //向c中寫入數(shù)字 } func main() { c := make(chan int) //創(chuàng)建chan變量c go foo(c) //在子寫成中運(yùn)行函數(shù)foo,并傳遞變量c fmt.Println("wait chan "c" for 1 second") fmt.Println(<-c) //取出chan "c"的值(取值時(shí),如果c中無值,主縣城會(huì)阻塞等待) }總結(jié)
Python和Go分別在動(dòng)態(tài)語言和靜態(tài)語言中都是最易學(xué)易用的編程語言之一。
它們并不存在取代關(guān)系,而是各自在其領(lǐng)域發(fā)揮自己的作用。
Python的語法簡(jiǎn)單直觀,除了程序員愛不釋手外也非常適合于其他領(lǐng)域從業(yè)者使用。
Go兼具語法簡(jiǎn)單和運(yùn)行高效的有點(diǎn),在多線程處理方面很優(yōu)秀,非常適合已經(jīng)掌握一定編程基礎(chǔ)和一門主流語言的同學(xué)學(xué)習(xí),不過,Go是不支持面向?qū)ο蟮模瑢?duì)于大多數(shù)支持面向?qū)ο笳Z言的使用者在學(xué)習(xí)Go語言的時(shí)候,需要謹(jǐn)記并且轉(zhuǎn)換編程思路。
后記文中還有許多應(yīng)該涉及的知識(shí)卻沒有能夠詳細(xì)說明,它是不完整的,甚至難免會(huì)有一些失誤。
如果,您覺得本文對(duì)您有所幫助,希望能夠得到您的點(diǎn)贊支持,如果文中有錯(cuò)誤的地方,也希望不吝賜教,通過評(píng)論或者公眾號(hào)和大家一起交流學(xué)習(xí)。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://specialneedsforspecialkids.com/yun/43765.html
摘要:在機(jī)器學(xué)習(xí)數(shù)據(jù)分析領(lǐng)域成為必學(xué)語言。不定長(zhǎng)參數(shù),支持不定長(zhǎng)參數(shù),用定義參數(shù)名,調(diào)用時(shí)多個(gè)參數(shù)將作為一個(gè)元祖?zhèn)鬟f到函數(shù)內(nèi)返回函數(shù)結(jié)果。showImg(https://user-gold-cdn.xitu.io/2019/5/13/16ab0b937e7329d4); Golang和Python都是目前在各自領(lǐng)域最流行的開發(fā)語言之一。 Golang其高效而又友好的語法,贏得了很多后端開發(fā)人員的青...
摘要:生態(tài)周報(bào)內(nèi)容主要包含我所接觸到的生態(tài)相關(guān)的每周值得推薦的一些信息。歡迎訂閱知乎專欄生態(tài)。更多詳細(xì)信息請(qǐng)閱讀發(fā)布常規(guī)版本,詳細(xì)內(nèi)容可閱讀正式發(fā)布是一個(gè)基于和支持部署平臺(tái)。本次的發(fā)布增加了版本的,這其實(shí)也是項(xiàng)目趨向穩(wěn)定的一個(gè)信號(hào)。 「K8S 生態(tài)周報(bào)」內(nèi)容主要包含我所接觸到的 K8S 生態(tài)相關(guān)的每周值得推薦的一些信息。歡迎訂閱知乎專欄「k8s生態(tài)」。 kind v0.0.3 正式發(fā)布 ki...
摘要:所以與多線程相比,線程的數(shù)量越多,協(xié)程性能的優(yōu)勢(shì)越明顯。值得一提的是,在此過程中,只有一個(gè)線程在執(zhí)行,因此這與多線程的概念是不一樣的。 真正有知識(shí)的人的成長(zhǎng)過程,就像麥穗的成長(zhǎng)過程:麥穗空的時(shí)候,麥子長(zhǎng)得很快,麥穗驕傲地高高昂起,但是,麥穗成熟飽滿時(shí),它們開始謙虛,垂下麥芒。 ——蒙田《蒙田隨筆全集》 上篇論述了關(guān)于python多線程是否是雞肋的問題,得到了一些網(wǎng)友的認(rèn)可,當(dāng)然也有...
摘要:編程書籍的整理和收集最近一直在學(xué)習(xí)深度學(xué)習(xí)和機(jī)器學(xué)習(xí)的東西,發(fā)現(xiàn)深入地去學(xué)習(xí)就需要不斷的去提高自己算法和高數(shù)的能力然后也找了很多的書和文章,隨著不斷的學(xué)習(xí),也整理了下自己的學(xué)習(xí)筆記準(zhǔn)備分享出來給大家后續(xù)的文章和總結(jié)會(huì)繼續(xù)分享,先分享一部分的 編程書籍的整理和收集 最近一直在學(xué)習(xí)deep learning深度學(xué)習(xí)和機(jī)器學(xué)習(xí)的東西,發(fā)現(xiàn)深入地去學(xué)習(xí)就需要不斷的去提高自己算法和高數(shù)的能力然后...
閱讀 2831·2021-09-28 09:45
閱讀 1506·2021-09-26 10:13
閱讀 897·2021-09-04 16:45
閱讀 3661·2021-08-18 10:21
閱讀 1083·2019-08-29 15:07
閱讀 2632·2019-08-29 14:10
閱讀 3146·2019-08-29 13:02
閱讀 2458·2019-08-29 12:31