毫無(wú)疑問(wèn),Marscode 能解決非常多基礎(chǔ)問(wèn)題,特別對(duì)于編程新手而言,它能相對(duì)準(zhǔn)確地生成各種代碼,完成編程任務(wù),但其底層并不神秘,本質(zhì)上就是在傳統(tǒng) IDE 基礎(chǔ)上,搭配足夠好的交互與足夠好的 LLM,從而超越傳統(tǒng) IDE。交互方面,它在 VS Code 基礎(chǔ)上,補(bǔ)充提供了:
- 提供了幾乎毫無(wú)門(mén)檻的代碼自動(dòng)補(bǔ)全能力,并且支持多行編輯,這在一些場(chǎng)景,如修改變量名時(shí),非常好用;
- 行內(nèi)、獨(dú)立問(wèn)答面板,可用于快速解答問(wèn)題;
在此基礎(chǔ)上,配合豆包模型,算得上是國(guó)內(nèi)最好的編程輔助工具了。但工具再好,錯(cuò)誤的用法下生成效果很可能不能達(dá)到預(yù)期,因此,這里根據(jù)我個(gè)人的使用經(jīng)驗(yàn),匯總一些最佳實(shí)踐技巧。
1. ?頻繁提交代碼
切記,LLM 始終是隨機(jī)的,無(wú)法保證下次執(zhí)行結(jié)果的正確性,在使用過(guò)程務(wù)必養(yǎng)成習(xí)慣頻繁提交代碼,方便出現(xiàn)問(wèn)題時(shí)隨時(shí)回滾。我個(gè)人的操作習(xí)慣大致是:
- 使用 Marscode 各類(lèi)面板生成代碼后,先做一遍簡(jiǎn)單的代碼 Review,修改變量名、循環(huán)結(jié)構(gòu)等基礎(chǔ)問(wèn)題;
- 在軟件上下文中集成調(diào)試,初步驗(yàn)證正確性后立即提交代碼;
- 審閱代碼設(shè)計(jì),重點(diǎn)關(guān)注:函數(shù)輸入輸出結(jié)構(gòu)、模塊導(dǎo)入導(dǎo)出內(nèi)容、邏輯與循環(huán)分支處理等等,在這個(gè)節(jié)點(diǎn)通常會(huì)持續(xù)讓 LLM 按我的想法優(yōu)化代碼,或者自己上手做些小修改,迭代多次持續(xù)提交代碼,這個(gè)過(guò)程通常耗時(shí)最多;
- 代碼初步穩(wěn)定后,繼續(xù)讓 LLM 幫我生成單測(cè)代碼,這個(gè)階段通常需要迭代多次,提交多次,直至單測(cè)通過(guò),覆蓋率達(dá)標(biāo)為止;
- 功能代碼、測(cè)試代碼均準(zhǔn)備就緒后,提交 PR 準(zhǔn)備合碼;
這個(gè)過(guò)程中,每次調(diào)用 LLM 都可能得到不符合預(yù)期的結(jié)果,但只要基本達(dá)標(biāo)我都會(huì)立即 Commit,后續(xù)遇到問(wèn)題隨時(shí) Revert 即可,雖然這會(huì)產(chǎn)生大量 Commit History ,但合碼前使用 Rebase 等操作調(diào)整歷史記錄即可。
2. ?重視 Code Review
其次,建議將更多時(shí)間精力放在 Code Review 上,因?yàn)?Marscode 生成的代碼可能是局部最優(yōu),但可能因?yàn)槿笔鄬?duì)抽象的全局架構(gòu)信息,而并不能做到全局最優(yōu),例如重復(fù)編寫(xiě)組件,或破壞某些約定俗成的架構(gòu)規(guī)則等,日積月累同類(lèi)代碼可能最終導(dǎo)致可維護(hù)性、可讀性都逐步劣化到無(wú)法繼續(xù)迭代的程度(公正點(diǎn)說(shuō),人類(lèi)智能也會(huì)導(dǎo)致這類(lèi)問(wèn)題)。
因此非常建議重視建立嚴(yán)謹(jǐn)?shù)?Code Review 文化,理想情況應(yīng)該是由 Marscode 生成盡可能多的代碼,盡可能代替人類(lèi)完成編碼工作,再由人類(lèi)智能負(fù)責(zé)驗(yàn)證、審查這些代碼的合理性,保證結(jié)果正確且長(zhǎng)期可維護(hù)。
3. ?更好的工程化體系
如前所述,Marscode,或者說(shuō) LLM 生成的結(jié)果是隨機(jī)的,無(wú)法保證每次都得到正確的結(jié)果,每次變更都有可能影響存量代碼的穩(wěn)定性,如果這些變更都必須由人類(lèi)手動(dòng)驗(yàn)證,那么測(cè)試成本會(huì)搞起不下,測(cè)試環(huán)節(jié)會(huì)成為工程中新的效率卡點(diǎn)。
更好的方式,應(yīng)該是投入更多精力建設(shè)更穩(wěn)健的工程化體系(這部分需求也可由 Marscode 輔助實(shí)現(xiàn)),使用自動(dòng)化工具代替人力完成諸多基礎(chǔ)質(zhì)檢任務(wù),例如引入 UT/E2E 完成運(yùn)行質(zhì)量測(cè)試,CI/CD 中加入 TS 類(lèi)型檢查、ESLint 風(fēng)格檢查等保證代碼質(zhì)量,等等。重點(diǎn)在于,使用更高效、成本更低的方式不斷驗(yàn)證 AI 產(chǎn)物質(zhì)量,更敏捷地應(yīng)對(duì)變化,具體策略可參考我之前的文章:
此處不再贅述。
4. ?使用 AI 友好的技術(shù)棧
在使用 Marscode 或其他同類(lèi)輔助編程工具時(shí),應(yīng)盡可能選用各類(lèi) AI 友好的技術(shù)棧,以前端為例,如:Tailwind 優(yōu)于原生 CSS/Less 等;Typescript 優(yōu)于 JavaScript、CoffeeScript 等;React 或 Vue 等 MVVM 框架優(yōu)于原生 JS + HTML + CSS;GraphQL 優(yōu)于 Restful 等。
為什么技術(shù)棧之間會(huì)出現(xiàn)這種差異呢?關(guān)鍵在于 LLM 底層是基于概率推導(dǎo)實(shí)現(xiàn)內(nèi)容生成的,結(jié)果好壞取決于模型質(zhì)量、訓(xùn)練語(yǔ)料、上下文完整度、Prompt 等諸多因素,單就輔助生產(chǎn)代碼這一任務(wù)而言,LLM 對(duì)技術(shù)棧的理解越充分必然效果越好;代碼結(jié)構(gòu)越聚焦,推導(dǎo)時(shí)信息噪音越低,結(jié)果也會(huì)越好;業(yè)務(wù)實(shí)現(xiàn)中的特化場(chǎng)景越少,通用規(guī)則越多,LLM 需要理解的內(nèi)容越少,效果通常也會(huì)越好;等等。
基于這些維度,我個(gè)人總結(jié)了幾類(lèi)簡(jiǎn)單規(guī)則可用于輔助評(píng)估某種技術(shù)棧是否更適用于 AIGC 場(chǎng)景,包括:
- 社區(qū)熱度:社區(qū)越繁榮,意味著使用者越多,相關(guān)的技術(shù)討論、技術(shù)資料也必然越豐富,LLM 訓(xùn)練或執(zhí)行時(shí)所能索引的信息就越完整,那么也就越容易推導(dǎo)出較好的結(jié)果。舉個(gè)例子,假設(shè)你工作中遇到了某個(gè)非常具體而棘手的問(wèn)題,若剛好有人也遇到過(guò),并將該問(wèn)題形成的底層原因、解決方案整理成文章并發(fā)布到互聯(lián)網(wǎng)上,若 LLM 運(yùn)行時(shí)能檢索到該文章,則可以基于文章內(nèi)容推導(dǎo)給出最終解決方案;若網(wǎng)絡(luò)上沒(méi)有這類(lèi)信息,考慮到 LLM 并不具備復(fù)雜邏輯推理能力,那么大概率無(wú)法給出有效的解決方案。
- 結(jié)構(gòu)化:技術(shù)棧本身的結(jié)構(gòu)化、模塊化水平越強(qiáng),則其信息表現(xiàn)形式越是聚焦,越容易被 LLM 正確推導(dǎo)。比如,原子 CSS(如 Tailwind) 就是一個(gè)很好的例子,原生 CSS 是通過(guò)具體的屬性的鍵值對(duì)表達(dá)頁(yè)面元素的視覺(jué)效果,而原子化 CSS 則是通過(guò)原子類(lèi)名表達(dá)某類(lèi)樣式規(guī)則集,信息更聚焦更容易被 AI 理解;并且受層疊規(guī)則影響,使用原生 CSS 時(shí),元素樣式可能受全局、祖先級(jí)元素、多種選擇器等層級(jí)的樣式規(guī)則影響,這對(duì) LLM 而言意味著具體信息分散在項(xiàng)目的多個(gè)角落,需要消費(fèi)、理解更多上下文才能推導(dǎo)出正確的結(jié)果,相對(duì)而言原子化 CSS 框架下,大部分樣式信息都聚焦在元素對(duì)應(yīng)的 Class 列表上,信息高度聚焦,推理成本更低,結(jié)果也會(huì)更可靠。
- 通用規(guī)則優(yōu)于特化設(shè)計(jì):技術(shù)棧的設(shè)計(jì)規(guī)范越是通用,則越容易被 LLM 理解,也就越是適用于 AIGC 場(chǎng)景。例如,GraphQL 明顯優(yōu)于 Restful,因?yàn)?GraphQL 提供了一套用于描述實(shí)體 + 實(shí)體關(guān)聯(lián)關(guān)系的通用語(yǔ)言規(guī)則,足夠用于表達(dá)絕大多數(shù)數(shù)據(jù)存、取、刪、改等常規(guī)業(yè)務(wù)操作,因而對(duì) LLM 而言只需理解這套通用語(yǔ)言規(guī)則,配合具體業(yè)務(wù)領(lǐng)域中的實(shí)體與實(shí)體關(guān)系即可基于 GraphQL 靈活編寫(xiě)出各類(lèi)數(shù)據(jù)操作邏輯;而 Restfull 規(guī)范則更多聚焦在實(shí)體上,除幾種基礎(chǔ)的數(shù)據(jù)操作外,涉及復(fù)雜數(shù)據(jù)結(jié)構(gòu)場(chǎng)景時(shí),出于實(shí)用性、性能等角度考慮,通常不得不特化設(shè)計(jì)、特化開(kāi)發(fā),而這些特化處理對(duì) LLM 而言會(huì)顯得過(guò)于具體,相應(yīng)的上下文復(fù)雜度與噪音也會(huì)更高,也就更難以推導(dǎo)出正確的答案。
- 自動(dòng)化質(zhì)檢:技術(shù)棧的質(zhì)檢工具越強(qiáng)大,則能夠越早、越全面地發(fā)現(xiàn)質(zhì)量問(wèn)題,進(jìn)而更能低效 LLM 隨機(jī)性帶來(lái)的質(zhì)量風(fēng)險(xiǎn),也就更適用于 AIGC 場(chǎng)景了。例如,Typescript 之于 JavaScript,前者具有更強(qiáng)的類(lèi)型聲明系統(tǒng),因此在靜態(tài)代碼分析階段即可找出諸多類(lèi)型不匹配問(wèn)題,那么即使 LLM 生成了類(lèi)型不匹配的代碼,也能夠在運(yùn)行代碼之前發(fā)現(xiàn)問(wèn)題,糾錯(cuò)成本要低很多。
當(dāng)然,上述規(guī)則僅僅是我的一家之言,隨著大模型的迭代發(fā)展,具體規(guī)則后續(xù)必然還會(huì)新增或刪改,這不重要,重要的是非常建議讀者后續(xù)在做技術(shù)選型時(shí),不要只是基于個(gè)人 or 團(tuán)隊(duì)喜好做決定,應(yīng)該更多考慮技術(shù)棧對(duì) AI 的適用性,甚至可以以此為首要原則,盡可能選用對(duì) AI 友好的技術(shù)與工具,使得 LLM 更好、更準(zhǔn)確地輔助完成各類(lèi)開(kāi)發(fā)任務(wù),充分融入到日常工作中,提升個(gè)體與團(tuán)隊(duì)的整體效率。
5. 降低預(yù)期
對(duì),標(biāo)題沒(méi)寫(xiě)錯(cuò),你需要降低預(yù)期!前面也說(shuō)過(guò)幾次,LLM 并不是魔法,它有幻覺(jué),有知識(shí)漏洞,有隨機(jī)性,不擅長(zhǎng)解決復(fù)雜問(wèn)題,有各種各樣的缺點(diǎn),從我的使用經(jīng)驗(yàn)來(lái)說(shuō),多數(shù)時(shí)候它還遠(yuǎn)沒(méi)有達(dá)到我預(yù)期的狀態(tài),需要我參與到各種代碼細(xì)節(jié)中。
例如,生成單測(cè)通常都跑不通,需要各種修改微調(diào)測(cè)試;生成的文檔可能也會(huì)缺失某些重要內(nèi)容,需要調(diào)整 Prompt 后多次重試,才有可能達(dá)到預(yù)期效果;生成的代碼,即使在 Marscode 各種上下文引用能力的加持下,也經(jīng)常會(huì)在細(xì)節(jié)處犯錯(cuò),導(dǎo)致執(zhí)行失敗。以 LLM 的底層實(shí)現(xiàn)邏輯來(lái)說(shuō),這些結(jié)果都太正常不過(guò)了。
因此,建議降低對(duì) Marscode 或者其他 LLM 工具的預(yù)期,它并不是魔法,無(wú)法完全代替人類(lèi)智能,當(dāng)下你還是需要認(rèn)真做好導(dǎo)演角色,引導(dǎo) Marscode 更準(zhǔn)確更好地解決你的問(wèn)題,認(rèn)真研讀理解倉(cāng)庫(kù)已有的代碼與 LLM 生成的代碼。更進(jìn)一步的說(shuō),你自身還是需要有比較強(qiáng)的技術(shù)能力,理解各類(lèi)技術(shù)底層細(xì)節(jié),才能及時(shí)發(fā)現(xiàn)、修復(fù)問(wèn)題。某種程度上,Marscode 就像一把刀,它的鋒利程度取決于你自身的功力。
總結(jié)
本文討論了 Marscode 作為編程輔助工具的優(yōu)勢(shì)、使用中的最佳實(shí)踐技巧以及需要注意的問(wèn)題。Marscode 在傳統(tǒng) IDE 基礎(chǔ)上,搭配良好的交互與 LLM,能為編程新手準(zhǔn)確生成代碼,但仍存在局限性。
關(guān)鍵要點(diǎn)包括:
- 頻繁提交代碼:使用 Marscode 生成代碼后,經(jīng)過(guò)簡(jiǎn)單 Review、調(diào)試、審閱設(shè)計(jì)等步驟,多次迭代并及時(shí)提交,方便回滾。
- 重視 Code Review:Marscode 生成的代碼可能局部最優(yōu)但非全局最優(yōu),應(yīng)重視人工審查以保證長(zhǎng)期可維護(hù)性。
- 建立更好的工程化體系:投入精力建設(shè)穩(wěn)健的工程化體系,用自動(dòng)化工具代替人力完成基礎(chǔ)質(zhì)檢任務(wù)。
- 使用 AI 友好的技術(shù)棧:選用社區(qū)熱度高、結(jié)構(gòu)化強(qiáng)、通用規(guī)則優(yōu)、自動(dòng)化質(zhì)檢好的技術(shù)棧,以提升 LLM 輔助效果。
- 降低預(yù)期:LLM 有諸多缺點(diǎn),無(wú)法完全替代人類(lèi)智能,使用者自身需具備較強(qiáng)技術(shù)能力。