Go標(biāo)準(zhǔn)庫本身沒有提供官方的圖形界面庫,但是Go語言社區(qū)有很多第三方GUI庫,如:fyne、walk、gotk3、ui、andlabs等。其禪喊中fyne比較輕量級,易于歲閉入門,支持跨平臺開發(fā);walk是一個Windows系統(tǒng)上比較流行的庫,提供豐富的UI控件和工具,支持Windows底層的開發(fā);gotk3是GTK+3的Go語言綁定庫,可以開發(fā)跨平臺的桌面應(yīng)用程序??傊m然Go標(biāo)準(zhǔn)庫沒有內(nèi)置圖形界面庫,但Go語言與乎襲裂其他語言的集成能力很強,可以使用C/C++的GUI庫進(jìn)行開發(fā),也可以使用其他語言的GUI庫進(jìn)行開發(fā)。
創(chuàng)新互聯(lián)建站長期為近千家客戶提供的網(wǎng)站建設(shè)服務(wù),團隊從業(yè)經(jīng)驗10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為建鄴企業(yè)提供專業(yè)的網(wǎng)站建設(shè)、成都網(wǎng)站制作,建鄴網(wǎng)站改版等技術(shù)服務(wù)。擁有10多年豐富建站經(jīng)驗和眾多成功案例,為您定制開發(fā)。
go 可以開發(fā)桌面應(yīng)用,但并不是很舒適。
可以使用的GUI庫有:
1、goqt,LiteIDE作者出品,Go和QT的綁定,還未發(fā)布
2、go.uik,純Go實現(xiàn)的并發(fā)UI工陸野游具
3、walk,Windows Application Library Kit
4、gform,Windows GUI framework
目前的話walk用得比較多
不過go的GUI庫用起來沒有C#、C/C++的那么順手。
這個問題不久之后應(yīng)該會有早銷所改善,畢竟用Go開發(fā)桌面的需求在不斷增加。
目前我采用的是用go http 做后端,Webkit+HTML5 做界面,表現(xiàn)力很好,前端不需要脊埋學(xué)習(xí)新知識,一般的管理類應(yīng)用都能搞定。
我喜歡jetbrains系列的IDE+go插件。不過我要說的是這個問題主要看你的觀點如何。
說eclipse:
構(gòu)建方式是使用go
install
命令,每一次編譯運行都是go
install。這樣的好處就是如果你有很困棗多的包,下載下來并沒有編譯,這樣每次編譯速度是很快的。廳寬而且(?。ゞo
install
符合go官方的項目結(jié)構(gòu),官方說過了,一個go的項目應(yīng)該是以個gopath,包含src,pkg,bin三個主要目錄。所以說go
install個人認(rèn)為才是主要的go編譯方式。
說eclipse的缺點:
其實eclipse插件的go編譯方式,還有目錄結(jié)構(gòu),項目結(jié)構(gòu),都是非常完美的?。。。≌娴暮芡昝?!可是,他的代碼提示,太差件!大括號都不能自動補全,gdb
32bit
64bit兼容問題,eclipseC++
沒有html
js插件,需要手動安裝,幾乎不能開箱即用。不過如果你是開發(fā)算法,數(shù)據(jù)處理,還是推薦eclipse的,畢竟其他都無關(guān)緊要。
說jetbrains:
說先說clione肯定不適合,新建項目沒有向?qū)В瑢?dǎo)致改成go項目各種不開心,比如圖標(biāo)對于我來說就無法接受go
lib
不是小耗子~這是次要的,重要的是各個文件都是灰色的(沒有在cmake中包含的結(jié)果),然后說剩下的,phpstorm這個不說了,估計很少有人插件按在這里,webstorm,體驗也不是很好,idea?體驗很好,可是畢竟比較重,尤其是現(xiàn)在加入了自家的K啥玩意(無意冒犯,沒記住單詞)~可是話說回來,go跟C系列IDE配合才是最佳,跟java系列一點不搭關(guān)系,用idea似乎有點格格不入,但是!idea支持新建項目向?qū)В琹ib的圖標(biāo)也很清晰,最后還是選擇idea吧,期待clion的強大起來!
再說jetbrains系列缺點:
插件的構(gòu)建方式是go
buiild
這個讓人很不爽,我們幾乎不確定會構(gòu)建到什么地方去,還要每次設(shè)置一下run配置。這個可能無關(guān)緊要,畢竟不是什么大的毛病,可是go
build不能緩存.a文件,直接構(gòu)建的結(jié)果就是很多第三方包的情況下很慢!所以建議安裝包的時候手動install
一下解決這個問題。自帶代碼格式化,這個格式化跟go
格格不入,總的來說就是蛋疼,心碎,菊花癢。
最后說liteIDE:
輕量級IDE,我可以說是國人GO偉大作品典范,然而默認(rèn)構(gòu)建也是go
build,項目管理方式不符合go官方標(biāo)準(zhǔn)。代碼提示不能自動導(dǎo)入(eclipse也不能),不過如果你的項目是以包為單位的,那么另當(dāng)別論。一定很不錯,畢竟是輕量級專門針對GO的IDE!
說這些,其實還有很大一部分取決于你的項目是用vendor機制管理,還是godeps機制管理依賴關(guān)系。go不像java擁有強大的幾乎天下一統(tǒng)的maven(無意冒犯,暫不評價其他構(gòu)建套件)。
go沒有官方包倉庫。
go沒有官方包管理工具。
go沒有官方自動化構(gòu)建套件。
上面三個沒有是致命要害。導(dǎo)致民間各種百汪伏拆花齊放。
說說我的項目怎么管理
gpm
一個shell工具(windows下你可以用git的bash,或者cygwin~)
我是嚴(yán)格艷照官方推薦方式管理go項目,一個go項目一個gopath。系統(tǒng)的gopath只是為了安裝go命令,我沒有配置gobin,意義不大。
項目的依賴跟我的代碼包都在src下(非vendor)
vendor用來存放包的特殊依賴,發(fā)布項目直接把依賴包發(fā)布上去(公網(wǎng)管理則只上傳依賴關(guān)系文件
godeps文件)
資源文件等都放在src目錄同級,編譯文件放在bin,引用直接../引用。