為什麼選擇.NETCore?

来源:https://www.cnblogs.com/xiaoliangge/archive/2018/01/29/8373100.html
-Advertisement-
Play Games

為什麼選擇.NETCore? 在開展話題之前先出一張ASP.NETCore VS Node.js的性能對比圖 ASP.NET Core VS node.js: 繼續正文: 學習新的開發框架是一項巨大的投資。您需要學習如何在新框架中編寫,構建,測試,部署和維護應用程式。作為開發人員,有許多框架可供選擇 ...


 為什麼選擇.NETCore?

在開展話題之前先出一張ASP.NETCore VS  Node.js的性能對比圖  ASP.NET Core  VS  node.js

繼續正文:

學習新的開發框架是一項巨大的投資。您需要學習如何在新框架中編寫,構建,測試,部署和維護應用程式。作為開發人員,有許多框架可供選擇,很難知道什麼是最適合的。即使您正在使用.NET開發軟體,.NET Core也不相同,您需要花時間學習使用它的工具和技術。為了理解為什麼.NET Core值得一看,這有助於知道你從哪裡開始。

.NETCore的開源協議

.NET Core從屬於.NET基金會,由微軟進行官方支持。使用最寬鬆的MIT和Apache 2開源協議,文檔協議遵循CC-BY。這將允許任何人任何組織和企業任意處置,包括使用,複製,修改,合併,發表,分發,再授權,或者銷售。唯一的限制是,軟體中必須包含上述版 權和許可提示,後者協議將會除了為用戶提供版權許可之外,還有專利許可,並且授權是免費,無排他性的(任何個人和企業都能獲得授權)並且永久不可撤銷,相較於oracle對java和mysql的開源協議微軟做出了最大的誠意

如果您是.NET Framework開發人員

.NET Core是為了重新啟動某些Framework組件而為其他人提供跨平臺工作的機會。由於.NET Framework主要以托管(C#)代碼為基礎構建,因此這些部分不需要更改代碼即可移至.NET Core。依賴於Windows特定組件的庫必須被移除或重構以使用跨平臺替代方案。這同樣適用於您的應用程式。

您的.NET應用程式可以是跨平臺的

您現有的.NET Framework應用程式可以在其他操作系統上工作。對於希望擴大類庫的受眾平臺,或者希望在分散式應用程式的其他領域使用相同代碼的開發人員來說,這是非常好的選擇。即使你想用你亮瞎眼的MacBook上開發.NET,而無需雙啟動到Windows。

並不是所有的框架都被移植到.NET Core,但主要的部分。存在一些API差異。例如,如果您使用了大量的反射,則可能需要重構代碼才能使用Core。有關更多信息,請看文章末尾的的兩者差異部分。

ASP.NETCore勝過框架ASP.NET

ASP.NET Core和ASP.NET之間的性能差異是幾個數量級大部分的ASP.NET被傳統的System.Web庫所限制。.NET Framework支持舊版本的ASP.NET項目,而且這個約束限制了ASP.NET的發展。微軟決定重寫整個架構。這意味著打破變化,但結果是值得的。

.NETCore是創新的焦點

向後相容性是一把雙刃劍。這意味著您的應用程式可以繼續得到新版本框架的支持,確保在新版本框架中所做的更改不會破壞現有的應用程式。

所有的努力避免變化都限制了框架的創新。框架的變化需要徹底的理由(通常來自客戶),詳盡的測試以及來自多個層次產品組的批准。

使用.NET Core,團隊可以更容易專註的在.net core上工作。比如核心類庫(如System.Collections)的更改仍然需要與.NET Framework相同的活力,但是ASP.NET Core或Entity Framework Core可以更輕鬆地進行實質性更改,而不受向後相容性的限制。這允許更大的創新。

.NET Framework作為一個整體產品發佈,但是.NETCore被分解成多個部分。現在開發人員可以選擇使用哪個版本的庫。只要它在.NET標準庫之外,.NET Core團隊就可以用較少的難度進行創新這就是為什麼在將來你只能看到錯誤修複的框架; .net core將獲得所有新功能。

發佈周期更快

如果您曾在框架中遇到錯誤,並將其報告給Microsoft,則您將知道發佈修複需要多長時間。這個框架有很長的發佈周期,通常至少要測量一年,而且在這些周期中還有很小的視窗用於特性工作。每個代碼更改都可能會導致框架中其他位置出現意外的問題。為了給每個團隊足夠的時間來測試框架,有很多時候代碼更改是受限制的或者嚴格審查的。如果您在.NET中發現了一個錯誤,最好找到一個解決方法,而不是等待更新(這也是.NETCore開源帶來的好處,您不需要完全依賴微軟支持才能解決問題,這對於大型企業更是有利,可以利用技術資源來對.NETCore進行本企業定製化,成為.NETCore的分支來運行)

.NET Core遵循更快的發佈步調。開發人員可以使用夜間構建來儘早測試。不屬於.NET標準庫的庫可以按自己的步調發佈。因為所有東西都是開源的,如果微軟沒有足夠快的響應,任何開發者都可以提出修補。如果解決方法不被接受,討論就會公開進行,所有人都可以看到為什麼做出這個決定


如果你是.NET新手

在Windows平臺上,.NET框架沒有太多的競爭。微軟可以對從操作系統內核層到高級.NET庫的所有內容進行更改。通過將.NET引入其他平臺,競爭環境發生了變化。.NET現在必須與其他所有的開發框架競爭。

C#是一個了不起的語言

.NET的旗艦語言C#具有許多獨特的功能,例如語言集成查詢和非同步構造,這使得它強大且易於使用。相較於保守的java(我們也看到Oracle旗下的老牌java已經已經越來越難推出新特性,這是歷史包袱所導致,在將來模塊化的開發中很難進行更新維護)C#也在不斷創新。C#團隊公開設計語言,因為他們希望任何人提出建議或參與討論。編譯器(Roslyn)完全是模塊化和可擴展的

ASP.NET Core性能與頂級Web平臺相當

如果您正在編寫Web應用程式或服務,那麼ASP.NET Core是一個很好的搭建平臺。它具有出色的性能和低記憶體占用。許多功能可以使您的應用程式更容易開發和維護。

.NET Core不是從頭開始的

.NET在2000年以前就已經出現了。框架代碼在過去幾年中已經得到了鞏固,開發人員也從中受益。已經被移植到Core的大部分Framework代碼都沒有改變。這使.NET Core在構建應用程式的可靠框架方面領先一步.NET Core也完全由Microsoft支持還有越來越活躍的開源社區例如紅帽組織這降低了為您的應用程式使用Core的風險。


什麼是.NETCore?

為了理解.NET Core,它有助於理解.NET Framework。微軟在21世紀初發佈了.NET Framework。.NET Framework是一個僅限於Windows的開發框架,它在最底層提供了記憶體管理,安全性,異常處理和許多其他功能。.NET框架附帶一大堆庫,可執行從XML解析到HTTP請求的各種功能。它還支持幾種語言,並將它們編譯成相同的通用中間語言; 任何語言都可以使用任何其他語言構建的庫。這些關鍵概念也出現在.NET Core中。

2016年,微軟收購了Xamarin併發布了.NET Core 1.0。之前Xamarin已經移植了.NET框架的大部分內容來運行在基於Linux / Unix的操作系統上。一些代碼可以在.NET Framework,Xamarin和新的.NET Core之間共用,但編譯後的二進位文件不能。.NET Core的一部分努力是創建一個標準化的平臺,允許所有.NET實現共用相同的庫。


                          metzgar_whynetcore_01

圖1 .NET框架,.NET Core和Xamarin都共用一個稱為.NET標準庫的標準化平臺


以前的Xamarin和.NET Framework之間是無法共用二進位文件的。隨著.NET標準庫和通用基礎架構的推出,這兩個框架現在成為統一的.NET生態系統的一部分。

什麼是.NETCore?在上圖中,似乎.NET Core是另一個包含UWP(通用Windows平臺)和ASP.NET Core的框架。為了使.NET Core成為現實,創建了.NET標準庫和通用基礎架構。


.NETCore的關鍵功能

.NET Core借鑒了.NET Framework的最佳實踐,並將軟體工程的最新進展結合在一起。這些是.NET Core的一些顯著特征。

擴大您類庫的覆蓋面

使用.NET Core,您可以使用.NET標準庫編寫應用程式或庫。

然後它可以在許多平臺上共用。


metzgar_whynetcore_02

圖2 .NETCore開發


同一個庫可以在後臺服務“本地”或雲中運行,也可以在手機,平板電腦或桌面上運行的客戶端應用程式中運行。與其為iOS,Android和Windows構建單獨的應用程式,您可以構建一個適用於所有平臺的應用程式。.NET Core是小型和完美的容器,可以輕鬆擴展並縮短開發時間。

.NET Core和.NET Standard Library建立了一個通用平臺。過去,當新版本的操作系統或新設備出現時,開發人員有責任重新構建新平臺的應用程式或庫,並分發更新。使用.NET Core,不需要重建和重新分配。只要新的平臺支持你所有的依賴庫,它就支持你的應用程式。

在任何平臺上簡單部署

Microsoft產品往往具有複雜的安裝過程。COM組件,註冊表項,特殊文件夾,GAC - 都是為了利用Windows的特性而設計的。.NET框架依賴於這些構造,這使得它不適合其他操作系統。

在發佈依賴於.NET Framework的應用程式時,安裝程​​序必須足夠聰明才能檢測是否安裝了錯誤的.NET Framework版本,併為用戶提供正確的方法。大多數現代Windows版本都包含.NET Framework。這使得某些應用程式更容易安裝,但是如果應用程式使用預設情況下未安裝的功能(如ASP.NET與IIS或WCF組件的集成),則可能會導致複雜的問題。

另一個複雜的問題來自補丁。包括錯誤修複或安全更新的修補程式可以通過Windows更新或通過Microsoft下載中心分發給客戶。您測試應用程式的.NET Framework可能與客戶使用的補丁程式不同。當您假定.NET Framework對於所有客戶都是一樣的時候,通常很難確定在應用程式中導致奇怪行為的原因。

.NET Core的模塊化設計意味著您只包含所需的依賴關係。所有這些依賴關係與您的應用程式進入相同的文件夾。部署應用程式與複製文件夾一樣簡單。這種方法的另一個優點是可以有多個版本並行運行。這個策略對於使所有平臺的部署體驗保持一致至關重要。

雲和容器

在雲系統中,用更少的硬體為更高密度的用戶提供服務是非常重要的。應用程式的占位面積越小,密度越高。虛擬機已經在雲端普遍存在多年,但是它們有幾個問題:

  • 大小 - 一個典型的虛擬機文件是千兆位元組,如果不是幾十千兆位元組。這使得它們跨網路傳輸非常耗時,並且對磁碟空間有很大的要求。
  • 啟動時間 - 啟動虛擬機意味著啟動操作系統。對於Windows來說,這是一個挑戰,因為啟動新機器需要花費時間。這可以使處理突發交通困難。
  • 記憶體 - 虛擬機需要將整個操作系統與應用程式一起載入到記憶體中。這意味著很多主機的記憶體被浪費了。
  • 不一致性 - 相同的虛擬機可以複製到多個主機,主機必須提供相同的虛擬化硬體,這可能依賴於物理硬體。無法保證虛擬機在任何給定的主機上運行相同的操作。

容器通過虛擬化操作系統來解決虛擬機的問題。容器只包含應用程式及其依賴項。文件大小要小很多倍,啟動時間以秒為單位,只有應用程式載入到記憶體中,容器保證在任何主機上工作。

內置於Windows的.NET Framework不能在容器上運行。鑒於容器的明顯優勢,.NET Core的設計決定之一就是使其成為模塊化這意味著你的.NETCore應用程式可以被“發佈”,使得它和它的所有依賴關係在一個地方,這很容易放入容器

ASP.NET性能

如果您不熟悉ASP.NET,則是.NET Framework中內置的Web應用程式平臺。ASP.NET被許多有影響力的組織所使用,包括Stack Overflow還有絕大多數的可靠性很高的金融證券行業領域ASP.NET是2002年發佈的第一個.NET Framework版本,並不斷發展。儘管ASP.NET取得了成功,但在ASP.NET團隊中卻感覺到他們正在失去開發人員,因為ASP.NET的性能沒有競爭力,只能在Windows平臺上運行。

一家名為TechEmpower的公司每隔幾個月就會運行一次Web應用程式平臺的基準測試,並提供一個分為幾類的排名。基準測試在Linux上運行,僅包含Windows平臺。對於ASP.NET團隊來說,這很麻煩。許多平臺都用於編寫跨平臺的Web應用程式,並且其性能數據令人印象深刻。此外,一些Java框架發佈了天文數字,例如每秒570萬個明文請求,或者490萬個。


metzgar_whynetcore_03

圖3  TechEmpower基準,第12輪


在TechEmpower基準測試的第十一輪中,Mono平臺上的ASP.NET MVC被納入測試。結果不好。Mono上的ASP.NET每秒產生一個微小的2000個明文請求。Mono不是由Microsoft創建的,它不會像普通的.NET Framework那樣得到相同數量的性能調整。為了獲得更公平的比較,ASP.NET團隊決定在與TechEmpower相同的硬體上運行.NET 4.6的基準測試。結果是每秒約50,000個請求。仍然沒有接近NodeJS(每秒320,000個請求),或TechEmpower列表上的其他任何頂級框架。

可憐的低分並不意外。如前所述,ASP.NET知道改變現狀只能通過重寫整個架構來清除障礙。這正是發生的事情。

ASP.NET團隊著手構建ASP.NET Core,幾個月後,該團隊慶祝asp.net core每秒超過100萬個請求。最新asp.netcore與node.js的性能對比更是讓asp.net core的性能優勢繼續擴大

ASP.NET Core   VS     Node.js

上圖中可看出asp.net core的性能優勢已經超過node.js數倍,性能對比鏈接==>       ASP.NET Core  VS  node.js

ASP.NET Core表明瞭微軟思維的轉變。微軟意識到它必須具有競爭力才能贏得開發者。它還必須在Windows以外的平臺上競爭。這是創建.NET Core的原動力。

開源

現代軟體開發人員並不滿足於尋求功能。當已經有一個滿足他們需求的開源項目的時候,尤其如此。當大公司熱衷於開源軟體時,即使是最忠實的微軟開發者也會轉向其他框架和庫,以便在預算內按時完成自己的項目。如果微軟關心“開發人員,開發人員,開發人員”,他們必須做出改變。

公開.NET Framework的源代碼是第一步。.NET Framework源代碼已經在referencesource.microsoft.com 和GitHub上公開了好幾年了。


metzgar_whynetcore_04

圖4 .NET Framework參考源


從單獨的開源代碼到接受外來的貢獻是完全不同的。.NET Core開發人員不僅希望獲得外部貢獻,還希望將社區納入設計和開發。這導致了更多的透明度。ASP.NET Core團隊每周都會在http:// live.asp.net上舉行一次社區直播會議.NET Core的代碼從一開始就在GitHub上公開,任何人都可以提出請求。社區成員可以在GitHub中創建錯誤和功能請求。.NET Core已經標志著微軟在開源方面的重大轉變。


與.NET Framework的差異

.NET Core不僅是Linux和Mac的.NET Framework。微軟並沒有移植所有的.NET Framework,對於ASP.NET客戶來說,ASP.NET團隊是.NET Core的驅動因素。MVC,Web API和SignalR都可以在.NET Core中找到,或者在路線圖上。

框架功能沒有移植到.NETCore

我給這個列表提供了可以改變的知識。某些功能不適用於非Windows平臺,其他某些功能也將不會由Microsoft在將來推出,因為有更好的替換或功能在某些方面有問題(不安全,難以維護等 )。

  • WPF / XAML - Windows Presentation Foundation僅適用於用戶界面。.NET標準庫不包括用戶界面庫,.NET Core不會提供跨平臺的UI框架。這意味著像Windows窗體和系統的東西。繪圖不會移植到.NET Core。
  • 事務 - 這個庫使創建分散式事務變得容易。它依賴於特定於Windows的組件,使其不易移植到.NET Core。
  • AppDomains - 這些對於隔離程式集來說是非常有用的,而且不會終止進程,這對於允許插件的應用程式來說非常有用。它們依賴於某些Windows特定的構造,這些構造在其他操作系統上不起作用。
  • .NET遠程處理 - 遠程對象已被REST服務成功。
  • ASMX - 編寫已被Web API取代的Web服務的舊方法。
  • Linq to SQL - 由實體框架取代。
  • WCF服務 - Windows Communication Foundation客戶端功能在.NET Core中可用,但不能創建服務。
  • WF - Windows Workflow Foundation依賴於XAML,WCF服務以及其他.NET Framework特性之間的事務。

.NET Framework開發人員的微妙變化

有經驗的.NET Framework開發人員可能會在.NET Core中遇到一些驚喜。編寫新的代碼應該是相對直接的,因為你不太可能使用像HashTableor 這樣的舊的結構ArrayListVisual Studio的Intellisense也指出.NET Core是否支持類型,方法,屬性等。


metzgar_whynetcore_05

圖5 Visual Studio IntelliSense指示.NET Core中是否有類或成員可用


NET可移植性分析器

如果您試圖將現有的.NET應用程式轉換為.NET Core,那麼最好的地方就是.NET可移植性分析器。它既可以作為命令行應用程式,也可以作為Visual Studio插件使用。有許多.NET平臺可供選擇:


metzgar_whynetcore_06

圖6 .NET可移植性分析器中提供的目標平臺


儘可能使用此工具創建一個詳細的報告,提供有用的建議:


metzgar_whynetcore_07

圖7.NET可移植性分析器報告


反射

.NET Core中的反射工作方式與.NET Framework中的不同。最明顯的區別是,Type類正常的許多操作不再存在。有些人已經被調到一個新的TypeInfo類其他操作在.NET標準庫中不可用,並且需要額外的依賴性。

  .NET Framework實現反射

PropertyInfo targetProperty = null;
foreach (var property in
         owningElement.GetType().GetProperties())
{
    if (property.Name == this.Name
        && property.PropertyType.IsGenericType)
    {

The .NET Core 實現反射.

PropertyInfo targetProperty = null;
foreach (var property in
owningElement.GetType().GetProperties()) 
{
if (property.Name == this.Name && property.PropertyType
.GetTypeInfo().IsGenericType)           
{

❶需要依賴於System.Reflection.TypeExtensions

❷ 許多類型操作移到了TypeInfo


概要

軟體開發行業正在不斷發展。從語言到框架,工具到方法論,一切都受到挑戰和改進。.NET框架已經到了b不得不做出改變的時候,以跟上競爭對手。.NETCore是.NET演進過程中必不可少的一步。它將最好的.NET Framework與現代軟體開發中使用的實踐相結合。諸如可移植性,簡單部署,高性能,開放源代碼和強大支持等特性使其值得一試。

Why Choose .NET Core?

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 離散存儲[鏈表] 1.定義: n個節點離散分配,彼此通過指針相連 每個節點只有一個前驅節點 只有一個後續節點 首節點沒有前驅節點,尾節點沒有後續節點 2.專業術語: 首節點:第一個有效節點 尾節點:最後一個有效節點 頭結點:並不存放有效數據,方便操作,頭結點的數據類型和首節點類型一樣 頭指針:指向頭 ...
  • 1.flask連接資料庫的四步: app.config["SQLALCHEMY_DATABASE_URI"] = "mysql://root:mysql@localhost/first_flask"app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = Fals ...
  • print的時候原來可以直接讓變數用加號來重組,那就省去了重寫的步驟(不知道我的理解對不對,捂臉)。變數和字元串之間也可以重組。 另外可以通過%來格式化數字,%d是整數,%f是小數,%s可以代替一段字元串。使用這三個的時候,都要在語句結束的時候單引號外加上%和轉換對象的名字 例如a=4 print' ...
  • 對於非數字數據類型的一些公共方法;一個小練手名片管理系統;pass TODO rename等實用的小技巧 ...
  • 正排索引與倒排索引 什麼是正排索引(forward index)? 由key查詢實體的過程,是正排索引. 在搜索引擎中每個文件都對應一個文件ID,文件內容被表示為一系列關鍵詞的集合(實際上在搜索引擎索引庫中,關鍵詞也已經轉換為關鍵詞ID。簡單的,正排索引可以理解為(文件內容會對應一個分詞後的集合li ...
  • 1 def name(para)def myabs(x): if x>0: return x else: return -x2 lambda表達式用於聲明匿名函數,既沒有名字的小函數f = lambda x,y,z:x+y+zprint(f(1,2,3)) #6L = [(lambda x:x**2... ...
  • 轉載請註明出處:http://www.cnblogs.com/zhishoumuguinian/p/8372337.html 四平方和定理,又稱為拉格朗日定理:每個正整數都可以表示為至多4個正整數的平方和。如果把0包括進去,就正好可以表示為4個數的平方和。比如:5 = 0^2 + 0^2 + 1^2 ...
  • 任何項目中都會使用到靜態類、靜態方法、靜態成員和實例成員了。那麼這幾個名詞到底有哪些區別呢? 1、靜態成員和實例成員 靜態成員:靜態成員通常和類是相關聯的。它可以作為類中公有的變數,不依賴特定對象的存在。通常我們在訪問它們的時候很簡單,直接通過類名加點操作符再加變數名來進行操作。 實例成員:實例成員 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...