不會(huì)的。生態(tài)無從建立。。。有五種以生態(tài)為核心的語言。。。C,C++,C#,JAVA,Python,你有沒有想過這五門語言為什么是主流?
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對(duì)這個(gè)行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長期合作伙伴,公司提供的服務(wù)項(xiàng)目有:主機(jī)域名、網(wǎng)站空間、營銷軟件、網(wǎng)站建設(shè)、福安網(wǎng)站維護(hù)、網(wǎng)站推廣。
是由于語法好嗎?如果這么認(rèn)為,那就太可笑了。是因?yàn)樗鼈儞碛凶约旱纳鷳B(tài)圈。
我舉三個(gè)例子。
C語言是單片機(jī)的標(biāo)準(zhǔn)開發(fā)語言,你家里用的電視,冰箱,洗衣機(jī),空調(diào),里面的主控芯片,全都是用C語言編寫的。由于偏底層,即便它空出位置來,Go也是勝任不了的,能替代它的只有匯編語言。
C#,你覺得它用的并不多?那就大錯(cuò)特錯(cuò)了,它的生態(tài)圈無比巨大,很多人只知道它是微軟的官方開發(fā)語言,Windows上的霸主。但卻常常被忽略的一點(diǎn)是,它還是唯一可以同時(shí)開發(fā)安卓和IOS的語言。有超過一半的3D手游都是用它寫的,比如《王者榮耀》。不僅如此,它還是云計(jì)算,人工智能,混合現(xiàn)實(shí)的重要組成部分,微軟未來還有一大波項(xiàng)目等著它。而且兩年前升級(jí)到了.NET CORE版本之后,它的速度比GO更快。
Python,很多人以為它是新興語言,但其實(shí)它從80年代就出現(xiàn)了。也是個(gè)老古董了。為什么這么多年都沒火,最近幾年卻突然火了?并不是因?yàn)樗旧?,而是因?yàn)長inux火了。Linux為什么火?因?yàn)榍度胧?,因?yàn)槲锫?lián)網(wǎng)。
GO是谷歌的親兒子沒錯(cuò),但谷歌為GO準(zhǔn)備了啥生態(tài)?在安卓上的重要性,咱都不好意思說跟JAVA比,太遙遠(yuǎn)。。。跟C#能比嗎?
在谷歌的平臺(tái)尚且如此,你還指望啥?
一、Kafka簡述
1. 為什么需要用到消息隊(duì)列
異步:對(duì)比以前的串行同步方式來說,可以在同一時(shí)間做更多的事情,提高效率;
解耦:在耦合太高的場景,多個(gè)任務(wù)要對(duì)同一個(gè)數(shù)據(jù)進(jìn)行操作消費(fèi)的時(shí)候,會(huì)導(dǎo)致一個(gè)任務(wù)的處理因?yàn)榱硪粋€(gè)任務(wù)對(duì)數(shù)據(jù)的操作變得及其復(fù)雜。
緩沖:當(dāng)遇到突發(fā)大流量的時(shí)候,消息隊(duì)列可以先把所有消息有序保存起來,避免直接作用于系統(tǒng)主體,系統(tǒng)主題始終以一個(gè)平穩(wěn)的速率去消費(fèi)這些消息。
2.為什么選擇kafka呢?
這沒有絕對(duì)的好壞,看個(gè)人需求來選擇,我這里就抄了一段他人總結(jié)的的優(yōu)缺點(diǎn),可見原文
kafka的優(yōu)點(diǎn):
1.支持多個(gè)生產(chǎn)者和消費(fèi)者2.支持broker的橫向拓展3.副本集機(jī)制,實(shí)現(xiàn)數(shù)據(jù)冗余,保證數(shù)據(jù)不丟失4.通過topic將數(shù)據(jù)進(jìn)行分類5.通過分批發(fā)送壓縮數(shù)據(jù)的方式,減少數(shù)據(jù)傳輸開銷,提高吞高量6.支持多種模式的消息7.基于磁盤實(shí)現(xiàn)數(shù)據(jù)的持久化8.高性能的處理信息,在大數(shù)據(jù)的情況下,可以保證亞秒級(jí)的消息延遲9.一個(gè)消費(fèi)者可以支持多種topic的消息10.對(duì)CPU和內(nèi)存的消耗比較小11.對(duì)網(wǎng)絡(luò)開銷也比較小12.支持跨數(shù)據(jù)中心的數(shù)據(jù)復(fù)制13.支持鏡像集群
kafka的缺點(diǎn):
1.由于是批量發(fā)送,所以數(shù)據(jù)達(dá)不到真正的實(shí)時(shí)2.對(duì)于mqtt協(xié)議不支持3.不支持物聯(lián)網(wǎng)傳感數(shù)據(jù)直接接入4.只能支持統(tǒng)一分區(qū)內(nèi)消息有序,無法實(shí)現(xiàn)全局消息有序5.監(jiān)控不完善,需要安裝插件6.需要配合zookeeper進(jìn)行元數(shù)據(jù)管理7.會(huì)丟失數(shù)據(jù),并且不支持事務(wù)8.可能會(huì)重復(fù)消費(fèi)數(shù)據(jù),消息會(huì)亂序,可用保證一個(gè)固定的partition內(nèi)部的消息是有序的,但是一個(gè)topic有多個(gè)partition的話,就不能保證有序了,需要zookeeper的支持,topic一般需要人工創(chuàng)建,部署和維護(hù)一般都比mq高
3. Golang 操作kafka
3.1. kafka的環(huán)境
網(wǎng)上有很多搭建kafka環(huán)境教程,這里就不再搭建,就展示一下kafka的環(huán)境,在kubernetes上進(jìn)行的搭建,有需要的私我,可以發(fā)yaml文件
3.2. 第三方庫
github.com/Shopify/sarama // kafka主要的庫*github.com/bsm/sarama-cluster // kafka消費(fèi)組
3.3. 消費(fèi)者
單個(gè)消費(fèi)者
funcconsumer(){varwg sync.WaitGroup? consumer, err := sarama.NewConsumer([]string{"172.20.3.13:30901"},nil)iferr !=nil{? ? ? fmt.Println("Failed to start consumer: %s", err)return}? partitionList, err := consumer.Partitions("test0")//獲得該topic所有的分區(qū)iferr !=nil{? ? ? fmt.Println("Failed to get the list of partition:, ", err)return}forpartition :=rangepartitionList {? ? ? pc, err := consumer.ConsumePartition("test0",int32(partition), sarama.OffsetNewest)iferr !=nil{? ? ? ? fmt.Println("Failed to start consumer for partition %d: %s\n", partition, err)return}? ? ? wg.Add(1)gofunc(sarama.PartitionConsumer){//為每個(gè)分區(qū)開一個(gè)go協(xié)程去取值formsg :=rangepc.Messages() {//阻塞直到有值發(fā)送過來,然后再繼續(xù)等待fmt.Printf("Partition:%d, Offset:%d, key:%s, value:%s\n", msg.Partition, msg.Offset,string(msg.Key),string(msg.Value))? ? ? ? }deferpc.AsyncClose()? ? ? ? wg.Done()? ? ? }(pc)? }? wg.Wait()}funcmain(){? consumer()}
消費(fèi)組
funcconsumerCluster(){? groupID :="group-1"config := cluster.NewConfig()? config.Group.Return.Notifications =trueconfig.Consumer.Offsets.CommitInterval =1* time.Second? config.Consumer.Offsets.Initial = sarama.OffsetNewest//初始從最新的offset開始c, err := cluster.NewConsumer(strings.Split("172.20.3.13:30901",","),groupID, strings.Split("test0",","), config)iferr !=nil{? ? ? glog.Errorf("Failed open consumer: %v", err)return}deferc.Close()gofunc(c *cluster.Consumer){? ? ? errors := c.Errors()? ? ? noti := c.Notifications()for{select{caseerr := -errors:? ? ? ? ? ? glog.Errorln(err)case-noti:? ? ? ? }? ? ? }? }(c)formsg :=rangec.Messages() {? ? ? fmt.Printf("Partition:%d, Offset:%d, key:%s, value:%s\n", msg.Partition, msg.Offset,string(msg.Key),string(msg.Value))? ? ? c.MarkOffset(msg,"")//MarkOffset 并不是實(shí)時(shí)寫入kafka,有可能在程序crash時(shí)丟掉未提交的offset}}funcmain(){goconsumerCluster()}
3.4. 生產(chǎn)者
同步生產(chǎn)者
packagemainimport("fmt""github.com/Shopify/sarama")funcmain(){? config := sarama.NewConfig()? config.Producer.RequiredAcks = sarama.WaitForAll//賦值為-1:這意味著producer在follower副本確認(rèn)接收到數(shù)據(jù)后才算一次發(fā)送完成。config.Producer.Partitioner = sarama.NewRandomPartitioner//寫到隨機(jī)分區(qū)中,默認(rèn)設(shè)置8個(gè)分區(qū)config.Producer.Return.Successes =truemsg := sarama.ProducerMessage{}? msg.Topic =`test0`msg.Value = sarama.StringEncoder("Hello World!")? client, err := sarama.NewSyncProducer([]string{"172.20.3.13:30901"}, config)iferr !=nil{? ? ? fmt.Println("producer close err, ", err)return}deferclient.Close()? pid, offset, err := client.SendMessage(msg)iferr !=nil{? ? ? fmt.Println("send message failed, ", err)return}? fmt.Printf("分區(qū)ID:%v, offset:%v \n", pid, offset)}
異步生產(chǎn)者
funcasyncProducer(){? config := sarama.NewConfig()? config.Producer.Return.Successes =true//必須有這個(gè)選項(xiàng)config.Producer.Timeout =5* time.Second? p, err := sarama.NewAsyncProducer(strings.Split("172.20.3.13:30901",","), config)deferp.Close()iferr !=nil{return}//這個(gè)部分一定要寫,不然通道會(huì)被堵塞gofunc(p sarama.AsyncProducer){? ? ? errors := p.Errors()? ? ? success := p.Successes()for{select{caseerr := -errors:iferr !=nil{? ? ? ? ? ? ? glog.Errorln(err)? ? ? ? ? ? }case-success:? ? ? ? }? ? ? }? }(p)for{? ? ? v :="async: "+ strconv.Itoa(rand.New(rand.NewSource(time.Now().UnixNano())).Intn(10000))? ? ? fmt.Fprintln(os.Stdout, v)? ? ? msg := sarama.ProducerMessage{? ? ? ? Topic: topics,? ? ? ? Value: sarama.ByteEncoder(v),? ? ? }? ? ? p.Input() - msg? ? ? time.Sleep(time.Second *1)? }}funcmain(){goasyncProducer()select{? ? ? }}
3.5. 結(jié)果展示-
同步生產(chǎn)打?。?/p>
分區(qū)ID:0,offset:90
消費(fèi)打印:
Partition:0,Offset:90,key:,value:Hello World!
異步生產(chǎn)打?。?/p>
async:7272async:7616async:998
消費(fèi)打?。?/p>
Partition:0,Offset:91,key:,value:async:7272Partition:0,Offset:92,key:,value:async:7616Partition:0,Offset:93,key:,value:async:998
物聯(lián)網(wǎng)中最常用的編程語言,即Java,C,C ++,Python,JavaScript和Go。
Java:物聯(lián)網(wǎng)技術(shù)最流行的編程語言
Java有多個(gè)應(yīng)用領(lǐng)域,從后端編程到Android的移動(dòng)應(yīng)用。根據(jù) Eclipse基金會(huì)執(zhí)行的2017年物聯(lián)網(wǎng)開發(fā)者調(diào)查,Java首次提供了用于物聯(lián)網(wǎng)開發(fā)的編程語言列表,專門用于網(wǎng)關(guān)和云。
使用Java進(jìn)行物聯(lián)網(wǎng)開發(fā)的一個(gè)主要好處是便攜性。Java沒有任何硬件限制,這意味著您可以在計(jì)算機(jī)上編寫和調(diào)試Java代碼,并將其部署到幾乎任何運(yùn)行Java虛擬機(jī)的設(shè)備上。出于這個(gè)原因,許多公司選擇聘請(qǐng)Java開發(fā)人員進(jìn)行物聯(lián)網(wǎng)項(xiàng)目。
C:嵌入式設(shè)備的關(guān)鍵編程語言
C編程語言接下來成為物聯(lián)網(wǎng)IoT堆棧最喜歡的語言。然而,根據(jù)Eclipse基金會(huì)的說法,它被認(rèn)為是受限設(shè)備開發(fā)的領(lǐng)先技術(shù)。
該編程語言提供對(duì)低級(jí)硬件API的直接訪問。由于其與機(jī)器語言的相似性,C非??焖偾异`活,使其成為處理能力有限的物聯(lián)網(wǎng)系統(tǒng)的完美選擇。
C ++:Linux的第一語言
與其前身C一樣,C ++已廣泛用于嵌入式系統(tǒng)開發(fā)。但是,C ++的主要優(yōu)勢在于處理能力,在任務(wù)更加復(fù)雜時(shí)使其成為C的有用替代方案。
C ++最適合編寫硬件特定的代碼。它可與Linux,第一大物聯(lián)網(wǎng)技術(shù)操作系統(tǒng)配合使用。但是,與Java相比,它具有有限的可移植性。
Python:面向數(shù)據(jù)的物聯(lián)網(wǎng)系統(tǒng)的解決方案
作為最受歡迎的網(wǎng)絡(luò)編程語言之一,以及科學(xué)計(jì)算的前沿技術(shù),Python在物聯(lián)網(wǎng)開發(fā)中也獲得了巨大的推動(dòng)力。 對(duì)于數(shù)據(jù)密集型應(yīng)用程序,Python是一個(gè)不錯(cuò)的選擇,特別是在管理和組織復(fù)雜數(shù)據(jù)時(shí)。
JavaScript:事件驅(qū)動(dòng)物聯(lián)網(wǎng)應(yīng)用的最佳解決方案
根據(jù)年度StackOverflow開發(fā)者調(diào)查顯示,JavaScript是過去五年來最流行的編程語言之一,是現(xiàn)代Web開發(fā)中的核心技術(shù)。
在許多其他應(yīng)用領(lǐng)域中,JavaScript是物聯(lián)網(wǎng)編程語言中最常用的構(gòu)建事件驅(qū)動(dòng)系統(tǒng)。它可以管理連接設(shè)備的大型網(wǎng)絡(luò),并且在需要處理多個(gè)任務(wù)而無需等待其他任務(wù)完成時(shí)可以勝任。JavaScript對(duì)IoT的主要優(yōu)勢之一是非常節(jié)約資源。
Go:堅(jiān)固的技術(shù)堆棧為復(fù)雜的物聯(lián)網(wǎng)網(wǎng)絡(luò)提供動(dòng)力
Go是一款開源編程語言,由Google創(chuàng)建。盡管它不能像語言那樣擁有同樣廣泛的用途,但我們之前專注于這一點(diǎn),它是在您的物聯(lián)網(wǎng)系統(tǒng)內(nèi)建立通信層的強(qiáng)大技術(shù)。
Go語言關(guān)于物聯(lián)網(wǎng)的主要優(yōu)勢是并發(fā)性和同時(shí)運(yùn)行多個(gè)進(jìn)程(數(shù)據(jù)輸入和輸出)的能力。這使得構(gòu)建由多個(gè)傳感器和設(shè)備組成的復(fù)雜IoT網(wǎng)絡(luò)變得更加容易。
影響物聯(lián)網(wǎng)IoT實(shí)施的最主要因素之一是人才缺口:現(xiàn)有市場供應(yīng)無法跟上擁有物聯(lián)網(wǎng)技術(shù)的工程師的需求。根據(jù)Canonical的研究,大約68%的公司正在努力為他們的物聯(lián)網(wǎng)項(xiàng)目雇傭開發(fā)人員。但技能短缺的另一面是,職業(yè)前景對(duì)于具有物聯(lián)網(wǎng)技術(shù)的專業(yè)人員來說是非常光明的。在這里,我們重點(diǎn)關(guān)注物聯(lián)網(wǎng)中最常用的編程語言,即Java,C,C ++,Python,JavaScript和Go,然后分析專門從事這些語言的專業(yè)人員可以獲得多少收入。我們還會(huì)考慮資歷和地點(diǎn)等因素。
作為一個(gè)技術(shù)強(qiáng)國,美國在IT 薪資標(biāo)準(zhǔn)方面常常成為世界其他國家的基準(zhǔn)。以下是根據(jù)Payscale的數(shù)據(jù)對(duì)美國頂級(jí)物聯(lián)網(wǎng)IoT編程語言以及相應(yīng)的開發(fā)者薪資數(shù)據(jù)的簡要統(tǒng)計(jì)。
美國最熱門的物聯(lián)網(wǎng)編程語言的平均工資統(tǒng)計(jì)
平均而言,Java和C開發(fā)人員可以獲得比物聯(lián)網(wǎng)中使用其他語言的開發(fā)人員更高的薪水,盡管高級(jí)Go編程人員的薪水潛力最高、盡管初級(jí)和中級(jí)Go開發(fā)人員與其他同行相比低調(diào),但Skilled Go的開發(fā)人員卻是業(yè)內(nèi)薪酬最高的開發(fā)人員之一。
從Java開始,我們來看看物聯(lián)網(wǎng)IoT中最流行的編程語言的平均薪水。
Java:物聯(lián)網(wǎng)技術(shù)最流行的編程語言
Java有多個(gè)應(yīng)用領(lǐng)域,從后端編程到Android的移動(dòng)應(yīng)用。根據(jù) Eclipse基金會(huì)執(zhí)行的2017年物聯(lián)網(wǎng)開發(fā)者調(diào)查,Java首次提供了用于物聯(lián)網(wǎng)開發(fā)的編程語言列表,專門用于網(wǎng)關(guān)和云。
使用Java進(jìn)行物聯(lián)網(wǎng)開發(fā)的一個(gè)主要好處是便攜性。Java沒有任何硬件限制,這意味著您可以在計(jì)算機(jī)上編寫和調(diào)試Java代碼,并將其部署到幾乎任何運(yùn)行Java虛擬機(jī)的設(shè)備上。出于這個(gè)原因,許多公司選擇聘請(qǐng)Java開發(fā)人員進(jìn)行物聯(lián)網(wǎng)項(xiàng)目。
根據(jù)Payscale的數(shù)據(jù),美國Java開發(fā)者的平均薪水約為8.8萬美元。瑞士的Java開發(fā)者的平均收入較高,每年約為96,000美元。與此同時(shí),英國和以色列的Java開發(fā)人員的平均薪水則明顯較低,分別為4萬5千美元和33萬美元。
Java開發(fā)人員的平均工資
但是,Java開發(fā)人員的平均工資可能不具代表性,因?yàn)楦鶕?jù)相關(guān)技術(shù)人員的經(jīng)驗(yàn)和資歷,個(gè)人薪酬差別很大。例如,從Java初級(jí)到高級(jí)Java開發(fā)人員的薪酬跳躍在美國是6.6萬美元到97萬美元,在英國是從41,000美元到61,000美元。
Java在美國和英國的平均初級(jí),中級(jí)和高級(jí)Java開發(fā)人員工資
我們對(duì)美國Java開發(fā)者工資的研究表明,不同州的平均薪水可能遠(yuǎn)高于全國平均水平。例如,加利福尼亞州的開發(fā)人員對(duì)美國開發(fā)人員的平均薪水最高(13.3萬美元)。這一事實(shí)在很大程度上是該州IT總體高技能需求的一個(gè)功能。
C:嵌入式設(shè)備的關(guān)鍵編程語言
C編程語言接下來成為物聯(lián)網(wǎng)IoT堆棧最喜歡的語言。然而,根據(jù)Eclipse基金會(huì)的說法,它被認(rèn)為是受限設(shè)備開發(fā)的領(lǐng)先技術(shù)。
該編程語言提供對(duì)低級(jí)硬件API的直接訪問。由于其與機(jī)器語言的相似性,C非常快速且靈活,使其成為處理能力有限的物聯(lián)網(wǎng)系統(tǒng)的完美選擇。
與Java類似,C開發(fā)人員的薪酬在世界各地差異很大。在美國,C開發(fā)人員每年可賺取約10萬美元,而在瑞士,C開發(fā)人員的平均年薪為92,000美元。在我們分析的國家中,C專家的最低工資在英國。據(jù)Payscale稱,英國年平均C開發(fā)人員薪水僅略高于4萬美元。
C開發(fā)人員的平均工資。來源:Payscale
C級(jí)初級(jí)和高級(jí)開發(fā)人員的薪酬差異也很大。高級(jí)C開發(fā)人員的收入幾乎是美國和英國入門級(jí)員工的兩倍。
C在美國和英國的初級(jí),中級(jí)和高級(jí)C開發(fā)人員的平均工資
C ++:Linux的第一語言
與其前身C一樣,C ++已廣泛用于嵌入式系統(tǒng)開發(fā)。但是,C ++的主要優(yōu)勢在于處理能力,在任務(wù)更加復(fù)雜時(shí)使其成為C的有用替代方案。
C ++最適合編寫硬件特定的代碼。它可與Linux,第一大物聯(lián)網(wǎng)技術(shù)操作系統(tǒng)配合使用。但是,與Java相比,它具有有限的可移植性。
與C開發(fā)人員相比,C ++工程師的薪水更低。我們的研究發(fā)現(xiàn),C ++開發(fā)人員在以色列和丹麥的預(yù)計(jì)收入約為82-86,000美元,而在美國,這個(gè)數(shù)字僅為71,000美元。
平均C ++開發(fā)人員工資統(tǒng)計(jì)。來源:Payscale
然而,盡管美國的C ++開發(fā)人員平均費(fèi)用較低,但經(jīng)驗(yàn)豐富的專家在職業(yè)生涯后期可以達(dá)到六位數(shù)。
美國和英國的初級(jí),中級(jí)和高級(jí)C ++開發(fā)人員的平均工資。
Python:面向數(shù)據(jù)的物聯(lián)網(wǎng)系統(tǒng)的解決方案
作為最受歡迎的網(wǎng)絡(luò)編程語言之一,以及科學(xué)計(jì)算的前沿技術(shù),Python在物聯(lián)網(wǎng)開發(fā)中也獲得了巨大的推動(dòng)力。 對(duì)于數(shù)據(jù)密集型應(yīng)用程序,Python是一個(gè)不錯(cuò)的選擇,特別是在管理和組織復(fù)雜數(shù)據(jù)時(shí)。
此外,由于語言的清晰語法,用Python編寫的源代碼非常緊湊且非常易讀。這對(duì)于計(jì)算能力和內(nèi)存有限的小型設(shè)備來說效果特別好,盡管速度不如C / C ++快。
美國的平均Python開發(fā)人員薪水約在71k美元左右,而擁有類似技能的開發(fā)人員則分別在以色列和瑞士分別可以獲得約68-67k的薪水。
Python開發(fā)人員的平均工資。來源:Payscale
與其他一樣,初級(jí)和高級(jí)Python開發(fā)人員之間的薪酬差距很大。
美國和英國的平均初級(jí),中級(jí)和高級(jí)Python開發(fā)人員薪水
仔細(xì)觀察數(shù)據(jù)顯示,盡管全國平均水平相對(duì)較低,但在美國,Python開發(fā)人員的薪水可能會(huì)非常高。由于開發(fā)商需求迫切,供應(yīng)量有限,某些州的薪酬可能高達(dá)14萬美元。傳統(tǒng)上,加利福尼亞州是為技術(shù)專家提供最高工資的州之一。當(dāng)?shù)氐腜ython開發(fā)人員平均賺取了大約13.5萬美元。
JavaScript:事件驅(qū)動(dòng)物聯(lián)網(wǎng)應(yīng)用的最佳解決方案
根據(jù)年度StackOverflow開發(fā)者調(diào)查顯示,JavaScript是過去五年來最流行的編程語言之一,是現(xiàn)代Web開發(fā)中的核心技術(shù)。
在許多其他應(yīng)用領(lǐng)域中,JavaScript是物聯(lián)網(wǎng)編程語言中最常用的構(gòu)建事件驅(qū)動(dòng)系統(tǒng)。它可以管理連接設(shè)備的大型網(wǎng)絡(luò),并且在需要處理多個(gè)任務(wù)而無需等待其他任務(wù)完成時(shí)可以勝任。JavaScript對(duì)IoT的主要優(yōu)勢之一是非常節(jié)約資源。
隨著IBM和三星等主要公司在他們的物聯(lián)網(wǎng)項(xiàng)目中積極采用JavaScript(即Node.js),對(duì)具有物聯(lián)網(wǎng)(IoT)體驗(yàn)的JavaScript開發(fā)人員的需求仍然很高。這意味著能夠全面的提高薪水。
瑞士的JavaScript開發(fā)者平均可以賺取約96k美元。令人驚訝的是,美國JavaScript專家的平均薪水要低得多,開發(fā)者可以得到6.9萬美元。
全球JavaScript開發(fā)人員的平均工資。來源:Payscale
不同州之間的薪資數(shù)據(jù)差別很大:例如,研究發(fā)現(xiàn),康涅狄格州,馬薩諸塞州,加利福尼亞州和紐約州是JavaScript開發(fā)者收入最高的美國州,平均薪資介于10萬美元至14萬美元之間。
同樣,根據(jù)經(jīng)驗(yàn),JavaScript開發(fā)人員的工資差別很大:美國的專業(yè)JavaScript開發(fā)人員平均可賺取10萬美元,英國則可賺取6萬美元左右。
美國和英國的平均初級(jí),中級(jí)和高級(jí)JavaScript開發(fā)人員工資
Go:堅(jiān)固的技術(shù)堆棧為復(fù)雜的物聯(lián)網(wǎng)網(wǎng)絡(luò)提供動(dòng)力
Go是一款開源編程語言,由Google創(chuàng)建。盡管它不能像語言那樣擁有同樣廣泛的用途,但我們之前專注于這一點(diǎn),它是在您的物聯(lián)網(wǎng)系統(tǒng)內(nèi)建立通信層的強(qiáng)大技術(shù)。
Go語言關(guān)于物聯(lián)網(wǎng)的主要優(yōu)勢是并發(fā)性和同時(shí)運(yùn)行多個(gè)進(jìn)程(數(shù)據(jù)輸入和輸出)的能力。這使得構(gòu)建由多個(gè)傳感器和設(shè)備組成的復(fù)雜IoT網(wǎng)絡(luò)變得更加容易。
雖然它已被評(píng)為美國最高收入技術(shù)(根據(jù)最新的StackOverflow開發(fā)者調(diào)查),但美國的Go平均薪水相當(dāng)平穩(wěn) - 約為73,000美元,而英國則為43,000美元。
根據(jù)最近的調(diào)查顯示,由于全球Go開發(fā)者工資數(shù)據(jù)不足,我們將重點(diǎn)關(guān)注美國和英國這些Go開發(fā)者人數(shù)最多的國家的薪水。
在美國和英國的平均Go開發(fā)者工資。來源:Payscale
高技能的Go開發(fā)者在美國可以獲得高達(dá)14萬美元的收入 - 幾乎是初級(jí)Go程序員的三倍,是英國高級(jí)Go開發(fā)者的兩倍。
在美國和英國的平均初級(jí),中級(jí)和高級(jí)Go開發(fā)人員工資
結(jié)論
正如我們所看到的,物聯(lián)網(wǎng)中最熱門編程語言的開發(fā)人員的工資差別很大,并且取決于許多關(guān)鍵方面。為了理解這些信息,重要的是要看到更大的空間,并能夠識(shí)別現(xiàn)有的市場趨勢。
以上由物聯(lián)傳媒提供,如有侵權(quán)聯(lián)系刪除