1、選擇ASN.1 的原因是什么?
選擇ASN.1 的一些原因是:
ASN.1 允許實現(xiàn)者選擇最適合他們的任何編程語言,并在該語言中選擇最適合其應(yīng)用程序的數(shù)據(jù)類型的綁定。例如,如果 ASN.1將類型定義為項目的集合,您可以自由地將其表示為鏈表、數(shù)組等,這取決于最適合您的語言/應(yīng)用程序的方式。
ASN.1允許您以這樣一種方式定義消息,即如果將來向消息中添加新字段,您不理解新字段的舊應(yīng)用程序?qū)⒗^續(xù)與理解新字段的新應(yīng)用程序一起正常工作。這樣您就不必同時將所有實現(xiàn)切換到消息的新版本。對于此類消息,較舊的實現(xiàn)意識到他們應(yīng)該期望并忽略消息中的新字段。
ASN.1 允許您對消息中的字段施加約束。例如,您可以指示整數(shù)類型應(yīng)該只攜帶值1、2、7-10,或者字符串的長度應(yīng)該在20-30 個字節(jié)之間。
ASN.1 允許您表達消息字段之間的關(guān)系。例如,您可以指示如果給定字段包含 7,則必須存在另一個字段。
ASN.1 允許您定義OPTIONAL 字段,如果沒有數(shù)據(jù),則傳輸很少或不傳輸數(shù)據(jù)。
ASN.1 允許消息規(guī)范的作者(例如,標準編寫者)以清晰簡潔的方式向?qū)崿F(xiàn)者明確指出消息中字段的性質(zhì)。
ASN.1 讓協(xié)議設(shè)計人員能夠自由地描述消息的布局,而無需深入研究在兩臺機器之間傳輸?shù)臄?shù)據(jù)的位和字節(jié)細節(jié),從而提高了生產(chǎn)力。
通過使用正式的、可編譯的符號ASN.1 定義消息,可以通過使用將使用ASN.1 描述的消息轉(zhuǎn)換為C、C++或 Java等語言的工具以及編碼器/解碼器來提高生產(chǎn)力,以最小化或無需弄清楚如何序列化數(shù)據(jù)以進行傳輸。
2、使用可擴展性是否有任何權(quán)衡?
如果您希望中繼接收到的值(即,如果您希望解碼器將意外值返回給您,而不是被解碼器忽略),則使用可擴展性將導(dǎo)致生成稍微復(fù)雜的頭文件。在大多數(shù)情況下,它足以滿足“舊”版本忽略從“新”版本收到的擴展值,因為它通常不知道如何處理它們。
就您的應(yīng)用程序代碼而言,通常它不會導(dǎo)致更大或更復(fù)雜的代碼。
如果您使用PER,如果您使用類型可擴展性,則編碼會稍大一些。類型可擴展性對 BER 編碼的大小沒有影響。
除非您提前知道永遠不需要擴展給定類型,否則您應(yīng)該將其定義為可擴展的。
3、標記會影響PER 中的編碼數(shù)據(jù)嗎?
一般來說,無論標簽是什么,編碼數(shù)據(jù)看起來都是一樣的。
唯一的例外是選擇類型的編碼。在 PER 中,選擇類型的每個備選方案都由索引標識。這些索引以取決于每個備選方案的標簽的順序分配給備選方案。當(dāng)使用自動標記時,索引確實對應(yīng)于備選方案的定義順序。
4、PER中的開放類型值是如何編碼的?
在PER中開放類型的編碼與無約束的OCTETSTRING類型的值相同。這意味著長度可以是一個或兩個字節(jié),或者如果長度是>16K字節(jié),則編碼會被分割開來,等等。
審核編輯:劉清
-
解碼器
+關(guān)注
關(guān)注
9文章
1143瀏覽量
40774 -
JAVA
+關(guān)注
關(guān)注
19文章
2970瀏覽量
104814 -
編碼
+關(guān)注
關(guān)注
6文章
945瀏覽量
54853
原文標題:?OSS Nokalva:ASN.1問答時間(1)
文章出處:【微信號:哲想軟件,微信公眾號:哲想軟件】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
評論