Win11出世UWP卻慘遭棄用 Win軟件還會翻新嗎
實際上,這并不是錯覺。UWP 這個在 Win10 時代,曾經扛起微軟生態的大旗,在 Win11 時代已然倒了下去。
不久前,微軟在 Windows 應用程序的開發文檔中透露,主推 Windows App SDK 和 WinUI 3 開發,UWP 不再作為開發基礎。UWP 此后只會收到“錯誤、可靠性和安全修復”,不會再引入新功能。因此,UWP 事實上已被微軟棄用,這個曾經被寄予厚望的微軟新生態的引擎,已經成為了時代的棄子。
在 Win8 乃至 Win10 時代,人們詬病于 Windows 系統中殘留的老舊痕跡,老軟件乃至系統本身的風格和新設計格格不入,人們一度將 Windows 生態翻新的厚望寄予在 UWP 身上。然而事情的發展卻出乎人們的意料,UWP 被放棄的同時,Win11 卻成為了近年來改版力度最大的 Windows 桌面系統,很多系統組件例如文件資源管理器都紛紛用上了新設計。
除了 Win11 系統本身,大量微軟 App 也在 Win11 時代全面擁抱了 Fluent Design 等新設計。這似乎是 Windows 生態華麗轉身的一個好兆頭。但歸根到底,這仍是微軟自發的行為,除了系統自帶組件和第一方應用,更重要的是第三方軟件。在今后第三方的 Win 軟件還會源源不斷迎來翻新嗎?還是說 Win11 的改版仍只會是曇花一現、大量 Win 軟件仍舊積重難返?今天就來簡單談談吧。
為何微軟要放棄 UWP?
在展開話題之前,我們先來回顧一下微軟為何要放棄 UWP。實際上,UWP 生態萎靡,已非一朝一夕之事。早在 Win11 尚未公布之前,Win10 上的 UWP 生態就已經半死不活,大量知名 UWP 應用早在去年前年就已經停止更新,大廠的 UWP 產品更是被 Win32 轉制版軟件取而代之,例如 QQ、微信、網易云音樂都是其中典型。
開發者不青睞 UWP,是有其合理原因的。
首先,微軟在移動平臺上的折戟沉沙,令 UWP 應用價值大減。UWP 開發規范主打跨平臺,從其名字“Universal Windows Platform”中就可窺一斑。UWP 應用可以同時適配移動和桌面平臺,但隨著 WP/Win10M 宣告失敗,UWP 這座橋梁的意義就很值得懷疑了。
其次,UWP 應用存在諸多限制,能實現的功能相當有限。UWP 應用的 API 并不如傳統的 Win32 軟件來得豐富,收到諸多限制,例如 UWP 應用必須在 App Container 中以沙盒的形式運行,難以獲取很多常見的系統權限,不少功能受到限制,例如 UWP 應用如何使用系統代理就是個難題。和傳統軟件相比,UWP 應用功能沒有那么自由,能調用的資源更少,受到更嚴格的后臺限制,而且某些應用還很容易閃退。這帶來了很不好的用戶體驗。
再者,UWP 應用兼容性不理想,盡管支持跨平臺,卻無法兼容老平臺。Windows 一大優點在于兼容性,無論使用新老開發工具,所編寫的程序都能在最新的 Win10 中跑起來,這令很多開發者至今仍使用舊版本的開發工具,以同時兼容 Win7、Win10 等多個版本的系統,大家并沒有太多動力為了 UWP 就把開發工具時時保持在最新。
最后,UWP 應用還存在開發框架一直迭代不穩定、App 必須在應用商店中發布等問題,這都影響了開發者的開發意愿。
種種原因綜合之下,UWP 的發展長期處于低潮。而其中的很多問題,又是微軟無法解決的。例如 UWP 的定位在于跨設備跨平臺,要兼顧桌面和移動環境,這就意味著自由度高的桌面開發環境必須向存在種種限制的移動開發環境妥協,導致的結果就是 UWP 應用功能受限、向后兼容性受限。結合當前微軟在移動市場的表現,UWP 的確沒有太大存在的意義了。
Win11 時代 Win32 也能迎來翻新?
UWP 不再被視為 Windows 開發的重心,但 Windows 11 中,大量軟件應用反而煥然一新,這又作何解釋呢?事實上,UWP 盡管沒有取得什么大成功,但它的很多遺產,卻被繼承了下來,這讓 Windows 在此后的生態建設中,更加順風順水。
就如文章一開頭所提到的,微軟將會把 Windows 開發的重心轉向 Windows App SDK 和 WinUI 3,但這兩者又是什么來頭呢?其實它們的構成,和 UWP 是脫不開關系的。
在 Win10 時代,微軟推行 UWP,而 UWP 所用的控件和樣式庫則被稱為 WinUI 2。WinUI 2 和 Windows 10 SDK 集成,為 UWP 提供 Windows UI 控件以及其他 UI 元素。然而,WinUI 2 卻有僅僅適用于 UWP 開發,對于傳統的 Win32 軟件,它無能為力,無法為傳統的 Win32 軟件提供界面、樣式更新。
如此一來,如果軟件不轉向 UWP 開發,那么即使更新版本,那么往往也只會使用 WPF、MFC 等比較老舊的開發工具。軟件不使用 UWP 開發,就無法用上 WinUI 2,就沒法跟上 Windows 系統的界面更新,這讓 Win10 時代視覺效果極其割裂。這個情況,在 Win11 時代似乎要得以改觀了。
在開發 Windows 11 的同時,微軟也盤算起了整理軟件開發生態的路子。在去年的 Build 2020 開發者大會上,微軟公布了“Project Reunion”,這是一套整合 UWP 和 Win32 開發的方案。微軟試圖通過 Project Reunion,將 Win32 和 UWP API 與 Windows 10 脫鉤,并將 UWP 中出廠的 API 提供給 Win32 使用,以“彌合”兩個平臺之間的差距。現在,Project Reunion 已經取得了初步的成果,那就是新的 Windows App SDK 以及 WinUI 3。
全新的 Windows App SDK 融合了傳統 Win32 以及 UWP 應用關鍵技術,并使用 WinUI 3 作為 UI 框架。此后,開發者為 Windows 開發軟件,無論是開發 Win32 還是 UWP,只要使用 Windows App SDK,即可讓軟件用上新的界面 —— 沒有使用 UWP 重構的文件資源管理器得以翻新,就受益于此。
需要注意的是,Windows App SDK 并不會取代掉之前的 Windows SDK 或現有桌面 Windows 應用類型,例如 .NET(包括 Windows 窗體和 WPF)和桌面 Win32 等,而是使用一組通用 API 來補充這些現有工具和應用類型,開發人員可以在這些平臺上依賴這些 API 來執行操作。
換言之,Windows App SDK 通過拓展更多的 API 接口,讓 Win32 開發也如 UWP 一樣標準化,讓開發者可以輕松調用 WinUI 3 來構建新的軟件界面。為 Win32 軟件開發新版,不需要將 Win32 軟件重構為 UWP,傳統軟件也能用上新界面了。
未來 Windows 軟件會如何發展?
那么問題來了,Win10 時代開發者并不愿意使用 UWP,在 Win11 時代大家就會擁抱 Windows App SDK 和 WinUI 3 嗎?恐怕其中仍有一些疑慮。
首先需要肯定的是,Windows App SDK 的確解決了 UWP 力所不逮的一些問題。例如 UWP 應用功能受限,而 Windows App SDK 可以用于 Win32 開發,就減少了很多限制。Windows App SDK 打破了軟件開發在功能和 API 調用等方面的瓶頸,讓 Win32 軟件銜接最新 Windows 界面不再有功能方面的顧慮。
但與此同時,Windows App SDK 并沒有解決 UWP 開發的很多問題。
兼容性。UWP 向后兼容到 Win10 1703,而 Windows App SDK 的兼容性更差,只兼容到 Win10 1809。如果開發商打算讓軟件繼續兼容 Win7、Win8,那么必然不會選擇 Windows App SDK。
遷移成本。將老軟件遷移到 Windows App SDK,并不比將其重構為 UWP 簡單,很多歷史悠久的大型軟件,已經累積起了穩定生態和客源,并不一定愿意做這方面的工作。
成熟度。事實上,Windows App SDK 才剛剛發布 1.0 穩定版,很多開發框架尚未穩定,也遠稱不上成熟。根據微軟的規劃,Windows App SDK 在未來還會通過 XAML Islands 支持 WPF、WinForms 和其他帶有 WinUI3 的應用程序,但這些規劃是否能落實?微軟砍刀部會不會再次大發神威?恐怕很多人會選擇觀望。
當然,如果開發者迫切想要軟件跟上 Win11 的節奏,或者想要讓產品在 Windows 商店中上架,Windows App SDK 還是頗具吸引力的。Windows App SDK 提供了更多適配 Win11 新系統特性的接口,例如電源管理、應用窗口管理、進程周期管理等等,使用它來開發軟件,在 Win11 上的運行效果肯定會比傳統開發來得更好。
簡而言之,Windows App SDK 有其價值所在,它為 Win32 軟件提供了適配新系統的開發方案,并整合了 UWP。但與此同時,它并不成熟,也存在兼容性等問題。開發者是否會跟進 Windows App SDK 和 WinUI 3?恐怕還是得視實際情況而定了。
總結
Windows 軟件是否可以翻新?微軟的確已經給出了 Windows App SDK 和 WinUI 3 的方案。然而,Windows 系統的一大核心競爭力,在于強大的兼容,這既體現在新系統對老軟件的兼容,也體現在新軟件對老系統的兼容。而無論是 UWP 還是 Windows App SDK,都在試圖打破這一局面,因此新開發規范的推廣,也一定會遭遇障礙。
Windows 并非是一個封閉的系統,微軟很難讓大家都跟隨自己的腳步,擁抱應用商店和新的開發套件。這意味著,微軟必須在這些方面提供足夠多的吸引力,才有可能讓 Windows 的生態脫胎換骨。微軟能在 Win11 時代做到這一切嗎?我們拭目以待吧。