曉查 發自 凹非寺
量子位 報導 | 公眾號 QbitAI
MacBook換成ARM晶片後,它還是程式設計師的開發利器嗎?
經過國外程式設計師半個多月來的嘗試,一些常見開發工具的兼容狀況也得到披露。
Xcode、VS Code、Homebrew……等常用工具能夠完美運行嗎?如果你還在因為這些問題猶豫要不要買,那麼看了這篇文章或許能得到答案。
代碼編輯器
Vim是通用二進位文件,因此它已經能在M1上直接運行。
VS Code可以通過Rosetta 2轉換來運行,而insider版已經原生支持ARM平臺的MacBook,相信正式版也不會太遙遠。
Xcode
蘋果第一方開發工具Xcode自然不必擔心兼容性,而且它在M1晶片上的運行效率很高。
編譯PSPDFKit PDF SDK,在2019年16英寸MacBook Pro上耗時7分31秒,在M1版MacBook Air上則耗時8分49秒,而後者是無風扇的。
不過Xcode在測試低於iOS 14版的應用程式時,會出現一些問題。WebKit會在內存分配器中崩潰,Xcode有時會定期卡死。
因此如果你要測試較低iOS版本程序,還是在Intel版的MacBook上運行,或者希望下一次Xcode更新時,蘋果能解決這個問題。
Docker
現在Docker無法在M1晶片上運行,也無法通過Rosetta 2轉換的方式使用Docker Desktop。
但是同樣使用ARM晶片的樹莓派卻能做到。
所以在MacBook上運行Docker最好的方法是:運行ARM版Linux虛擬機,在虛擬機中運行Docker。
具體操作方法請參照這篇教程:
https://finestructure.co/blog/2020/11/27/running-docker-on-apple-silicon-m1
至於Docker官方何時將提供支持,可以註冊Docker ID來獲取最新進展。
Homebrew
Homebrew可以通過Rosetta 2轉換的方式進行安裝,方法也很簡單,只需在過去的安裝命令前加上arch -x86_64即可。
$ arch -x86_64 /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install.sh)"
這種通過轉制的Homebrew在某些軟體上可能有一些兼容性問題,因此建議安裝另一個手動編譯版:
$ sudo mkdir -p /opt/homebrew
$ sudo chown -R $(whoami):staff /opt/homebrew
$ cd /opt
$ curl -L https://github.com/Homebrew/brew/tarball/master | tar xz --strip 1 -C homebrew
第一種方式安裝的Homebrew在/usr/local/bin目錄下,而第二種方式安裝的在/opt/homebrew目錄下,後者不會自動添加到PATH環境變量中,因此需要手動設置:
export PATH="/opt/homebrew/bin:$PATH"
這樣,你的Mac裡就有了兩個Homebrew:一個是Rosetta轉換的,一個是原生的。原生的目錄在前面,那麼brew命令將默認運行這個版本。
如果想運行Rosetta轉換版怎麼辦?我們可以單獨設置一個ibrew命令:
alias ibrew='arch -x86_64 /usr/local/bin/brew'
目前,Homebrew尚未提供用於ARM Mac的預編譯軟體包,因此最好使用brew install -s 命令進行安裝。
具體有哪些軟體包不兼容,可以到GitHub項目頁的issue中查詢:
https://github.com/Homebrew/brew/issues/7857
其他常用軟體
說到編程必備,怎麼能少得了Chrome,現在Chrome 87版已經開始支持M1版的MacBook。
還有微軟的Office三件套,若使用Rosetta 2轉譯,啟動時間可能需要20秒。官方建議安裝針對macOS Big Sur優化的16.43版。
微軟官方表示,已經開始將Mac應用程式遷移到通用二進位文件,未來Office三件套的兼容性不成問題。
如果是基於Electron的應用程式,經過Rosetta 2轉譯後速度會變得很慢。原因可能是V8 JavaScript編譯器似乎阻止了提前翻譯。
現在最新版的Electron(Version 11)已經支持了M1晶片,還需要等其他開發者更新軟體。
由於Rosetta 2轉譯的程序會變成只讀文件,因此自動更新將被禁止,此類程序需要用戶手動更新。
虛擬機和Windows
雖然VMware和Parallels可以在M1晶片的MacBook上使用,但是所有Mac虛擬化解決方案均不支持Apple Silicon。免費開源的虛擬機Virtualbox更是無法運行。
現在ARM版Windows可以仿真x86應用程式,而微軟正在研究x64仿真。
最近模擬器軟體CrossOver展示了,但這只是運行單個程序,而非運行虛擬機和整個系統。
而且M1最高只支持16GB內存,對虛擬機來說顯得有些捉襟見肘。
在運行並行測試時,Mac開始大量在硬碟和內存之間進行數據交換,性能確實下降了。對於運行的虛擬機,這會帶來更多的問題。
結論
新款搭載M1晶片的MacBook速度快、運行安靜,但是在軟體方面還需要做很多工作,才能趕上搭載Intel晶片的MacBook。
你可以拿它作為第二臺開發電腦使用,如果作為主力開發機,可能會遇到這樣那樣的問題。想要更好的兼容性需要等到明年軟體廠商更新,或者是M2發布。
另外,最高16GB的內存對程式設計師來說可能還是不夠,希望未來的Mac有32GB內存可選。
參考連結:
https://news.ycombinator.com/item?id=25238608
https://steipete.com/posts/apple-silicon-m1-a-developer-perspective/
https://soffes.blog/homebrew-on-apple-silicon
https://github.com/mikelxc/Workarounds-for-ARM-mac
— 完 —
本文系網易新聞•網易號特色內容激勵計劃籤約帳號【量子位】原創內容,未經帳號授權,禁止隨意轉載。
原標題:《搭載M1晶片的MacBook能不能當開發主力機?程式設計師半個月的親身體驗都在這裡》
閱讀原文