回答:程序源碼被翻譯成機(jī)器碼之后才能被電腦執(zhí)行。通過匯編和反匯編,匯編語(yǔ)言和機(jī)器碼可以相互轉(zhuǎn)換。我的回答中就只說機(jī)器碼了。按照?qǐng)?zhí)行方式大致可將程序語(yǔ)言分成三類: 編譯方式 將源代碼翻譯成機(jī)器碼后執(zhí)行的方式。這種方式執(zhí)行速度快,但對(duì)操作系統(tǒng)有依存性。 混合方式 將源代碼翻譯成中間碼(如,字節(jié)碼)后,在有各OS上的虛擬機(jī)翻譯成其他語(yǔ)言或命令執(zhí)行?;蛘?,使用實(shí)時(shí)編譯(JIT)轉(zhuǎn)換成機(jī)器碼后執(zhí)行。 解釋方式 將...
回答:反匯編程序。匯編語(yǔ)言絕對(duì)有用。如果能讀懂匯編語(yǔ)言的話,那程序反匯編之后,你也讀不懂。我曾經(jīng)自學(xué)過匯編語(yǔ)言,而學(xué)習(xí)匯編語(yǔ)言的目標(biāo)很簡(jiǎn)單,就是反匯編動(dòng)態(tài)跟蹤游戲,然后找到游戲的所謂的call。然后用其他的高級(jí)語(yǔ)言程序編寫外掛??梢酝瓿捎螒蛑械囊恍﹦?dòng)作,這種外掛被稱為內(nèi)存掛,效率要遠(yuǎn)遠(yuǎn)高于像按鍵精靈一樣的游戲外掛。如果您玩游戲的話又想自己寫外掛的話,這一個(gè)是必須學(xué)習(xí)的,不然的話你沒法做一個(gè)好的游戲輔助。...
回答:自從智能圍棋程序AlphaGo采用深度學(xué)習(xí)方法擊敗人類天才棋手,孤獨(dú)求敗之時(shí),注定了人工智能的風(fēng)口到來(lái)了??萍冀绱罄卸伎春萌斯ぶ悄艿奈磥?lái)發(fā)展。AI(人工智能)為應(yīng)用程序開發(fā)人員打開了一個(gè)充滿可能性的世界。 通過利用機(jī)器學(xué)習(xí)或深度學(xué)習(xí),可以生成更好的用戶畫像、個(gè)性特征和適當(dāng)?shù)耐扑],或者包含更智能的搜索、語(yǔ)音接口或智能輔助,或者以其他方式改進(jìn)您的應(yīng)用程序。 甚至可以構(gòu)建能看、會(huì)聽并響應(yīng)的應(yīng)用程序。人工...
回答:不能。原因很簡(jiǎn)單,圖形化語(yǔ)言對(duì)于問題的描述能力比不上文本型編程語(yǔ)言。最直觀的理解就是數(shù)學(xué)中幾何圖形一定程度上可以描述客觀世界的數(shù)量關(guān)系,但它永遠(yuǎn)都只是文字化數(shù)學(xué)語(yǔ)言的輔助手段。編程語(yǔ)言也一樣,它是數(shù)學(xué)化語(yǔ)言的升級(jí),圖形化編程語(yǔ)言的底層都是文本型編程語(yǔ)言實(shí)現(xiàn)的,所以圖形化編程語(yǔ)言也只能在特定的領(lǐng)域發(fā)揮作用,不能從根本上取代文本型編程語(yǔ)言。但圖形化編程語(yǔ)言也有自己的優(yōu)勢(shì),就是直觀易于理解。這里就給大家...
回答:作為一名從業(yè)多年的程序員,同時(shí)也是一名計(jì)算機(jī)領(lǐng)域的教育工作者,我來(lái)回答一下這個(gè)問題。首先,并不是每個(gè)程序員都需要掌握C語(yǔ)言,程序員需要掌握何種編程語(yǔ)言往往取決于其具體的開發(fā)場(chǎng)景,比如做Web開發(fā)需要掌握PHP,做大數(shù)據(jù)開發(fā)需要掌握J(rèn)ava,做機(jī)器學(xué)習(xí)需要掌握Python等。雖然C語(yǔ)言并不是每個(gè)程序員都需要掌握的,但是掌握C語(yǔ)言對(duì)于理解計(jì)算機(jī)系統(tǒng)結(jié)構(gòu)還是具有較大意義的,一個(gè)重要的原因就是操作系統(tǒng)往往...
...速有效,通過散列函數(shù),數(shù)據(jù)元素將被更快定位。 直接定址法:取關(guān)鍵字或關(guān)鍵字的某個(gè)線性函數(shù)值為散列地址。即 $$ hash(k)=k $$ 或 $$ hash(k)=a cdot k+b $$ , 其中ab為常數(shù)(這種散列函數(shù)叫做自身函數(shù)) 數(shù)字分析法:假設(shè)關(guān)鍵字...
...希表定義:根據(jù)設(shè)定的hash函數(shù)和處理沖突的方式(開放定址、公共溢出區(qū)、鏈地址、重哈希...)將一組關(guān)鍵字映射到一個(gè)有限的連續(xù)的地址集上(即bucket數(shù)組或桶數(shù)組),并以關(guān)鍵字在地址集中的像作為記錄在表中的存儲(chǔ)...
...希沖突方案有以下四種:(詳細(xì)細(xì)節(jié)見下篇講解) 開放定址法:為產(chǎn)生沖突的地址H(key)求得一個(gè)新的地址序列: Hi =(H(key)+ di)% m (i=1,2,3,...,m-1) 其中H(key)為哈希函數(shù),m為表長(zhǎng),di稱為增量序列。(其中增量di的取值方...
...機(jī)的地址,從而減少?zèng)_突。 減少?zèng)_突的方法: 開放定址法開放定址法就是產(chǎn)生沖突之后去尋找下一個(gè)空閑的空間。函數(shù)定義為:其中,hash(key)是哈希函數(shù),di是增量序列,i為已沖突的次數(shù)。 鏈表法散列到同一位置的元素...
... 留 鍵樹(數(shù)字查找樹) 留 哈希表 哈希表的構(gòu)造方法 直接定址法:取關(guān)鍵字或關(guān)鍵字的某個(gè)線性函數(shù)值為散列地址。即H(key)=key或H(key) = a·key + b,其中a和b為常數(shù)(這種散列函數(shù)叫做自身函數(shù))。若其中H(key)中已經(jīng)有值了,就往...
... 留 鍵樹(數(shù)字查找樹) 留 哈希表 哈希表的構(gòu)造方法 直接定址法:取關(guān)鍵字或關(guān)鍵字的某個(gè)線性函數(shù)值為散列地址。即H(key)=key或H(key) = a·key + b,其中a和b為常數(shù)(這種散列函數(shù)叫做自身函數(shù))。若其中H(key)中已經(jīng)有值了,就往...
...一個(gè)整數(shù),可以通過這些常見方法來(lái)獲取映射地址。直接定址法直接根據(jù)key來(lái)映射到對(duì)應(yīng)的數(shù)組位置,例如1232放到下標(biāo)1232的位置。數(shù)字分析法取key的某些數(shù)字(例如十位和百位)作為映射的位置平方取中法取key平方的中間幾位...
...種方法。 分離鏈表法。即用鏈表來(lái)保存沖突的K。 開放定址法。當(dāng)位置被占用時(shí),通過一定的算法來(lái)試選其它位置。hash(i) = (hash(key) + d(i)) % N,i代表第i次試選。常用的有平方探測(cè)法,d(i) = i^2。 再散列。如果沖突,就再用hash函...
...哈希沖突如何解決呢?哈希沖突的解決方案有多種:開放定址法(發(fā)生沖突,繼續(xù)尋找下一塊未被占用的存儲(chǔ)地址),再散列函數(shù)法,鏈地址法,而HashMap即是采用了鏈地址法,也就是數(shù)組+鏈表的方式 HashMap實(shí)現(xiàn)原理 HashMap的主干...
...原理及源碼分析注意:哈希沖突的解決方案有多種:開放定址法(發(fā)生沖突,繼續(xù)尋找下一塊未被占用的存儲(chǔ)地址),再散列函數(shù)法,鏈地址法,而HashMap即是采用了鏈地址法,也就是數(shù)組+鏈表的方式 3.截短流 流支持limit(n)方法...
...突的問題。常用的兩種哈希沖突的解決方案有兩種:開放定址法與鏈地址法。redis使用的是后者。通過這個(gè)next指針,我們就可以將哈希值相同的元素都串聯(lián)起來(lái),解決哈希沖突的問題。注意在redis的源碼實(shí)現(xiàn)中,在往dict插入元素...
...是指在應(yīng)用源程序執(zhí)行之前,就將程序源代碼翻譯成匯編語(yǔ)言,然后進(jìn)一步根據(jù)軟硬件環(huán)境編譯成目標(biāo)文件。一般我們稱完成編譯工作的工具叫編譯器。而解釋型語(yǔ)言,在程序運(yùn)行時(shí)才被翻譯為機(jī)器語(yǔ)言。但是執(zhí)行一次...
ChatGPT和Sora等AI大模型應(yīng)用,將AI大模型和算力需求的熱度不斷帶上新的臺(tái)階。哪里可以獲得...
大模型的訓(xùn)練用4090是不合適的,但推理(inference/serving)用4090不能說合適,...
圖示為GPU性能排行榜,我們可以看到所有GPU的原始相關(guān)性能圖表。同時(shí)根據(jù)訓(xùn)練、推理能力由高到低做了...