• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            無(wú)我

            讓內(nèi)心永遠(yuǎn)燃燒著偉大的光明的精神之火!
            靈活的思考,嚴(yán)謹(jǐn)?shù)膶?shí)現(xiàn)
            豪邁的氣魄、頑強(qiáng)的意志和周全的思考

            eSNACC對(duì)ASN.1 constructors的處理

            首先讓我們來(lái)學(xué)習(xí)一下ASN.1的Constructors類(lèi)型 。
            ASN.1 constructors 類(lèi)型可以將簡(jiǎn)單的預(yù)定義類(lèi)型封裝成復(fù)雜的數(shù)據(jù)類(lèi)型。而且,這種操作可以是嵌套的,比如,constructors中還可以包含其他的constructors類(lèi)型。ASN.1的constructors類(lèi)型有:

            SEQUENCE

            SEQUENCE是一個(gè)表示有序元素集合的數(shù)據(jù)類(lèi)型。集合可能為空,集合中的元素可以是任意ASN.1類(lèi)型,并且元素類(lèi)型可以不同。集合中的元素還可以被命名。這類(lèi)似于C/C++中的結(jié)構(gòu)體。

            SEQUENCE OF

            SEQUENCE OF 是一個(gè)表示有序元素集合的數(shù)據(jù)類(lèi)型,集合可以為空。集合中的元素可以是任意ASN.1類(lèi)型,但是要求所有元素為同一類(lèi)型。集合中的元素可以被命名。這很類(lèi)似于C/C++中的有序數(shù)組/鏈表。

            SET

            SET 是一個(gè)表示無(wú)序元素集合的數(shù)據(jù)類(lèi)型,集合可以為空。集合中的元素可以是任意ASN.1類(lèi)型,并且元素類(lèi)型可以不同。集合中的元素可以被命名。這同樣類(lèi)似于C/C++中的結(jié)構(gòu)體。

            SET OF

            SET OF 是一個(gè)表示無(wú)序元素集合的數(shù)據(jù)類(lèi)型,集合可以為空。集合中的元素可以是任意ASN.1類(lèi)型,但是要求所有元素為同一類(lèi)型。集合中的元素可以被命名。這很類(lèi)似于C/C++中的無(wú)序數(shù)組/鏈表。 

            一眼看上去似乎SEQUENCE 和SET是一樣的。其實(shí)不同就在于SEQUENCE是有序的,而SET不是。比如,在上面的例子中,SET在編碼時(shí),字段field2就可以比f(wàn)ield1先發(fā)送,而對(duì)SEQUENCE,我們希望field1必須在field2之前先處理。

            SEQUENCE OF 和SET OF的區(qū)別也就在這。

            總而言之,SEQUENCE 和SEQUENCE OF依賴(lài)順序來(lái)避免模糊。而SET 和SET OF就依賴(lài)數(shù)據(jù)類(lèi)型或者每個(gè)元素的標(biāo)簽來(lái)唯一區(qū)分每個(gè)元素。

            OPTIONAL

             SEQUENCE 等集合中出現(xiàn)的關(guān)鍵字OPTIONAL表示集合中的那個(gè)元素不是必須的:也就是可以存在也可以省略。  例如:

            這對(duì)SEQUENCE OF, SET 和SET OF都適用。

            DEFAULT

            在某些情況下,給指定類(lèi)型的某個(gè)元素設(shè)定一個(gè)默認(rèn)值在編碼時(shí)是非常有用的。

            CHOICE

            CHOICE類(lèi)型是一個(gè)定義一個(gè)或者多個(gè)類(lèi)型的聯(lián)合的數(shù)據(jù)類(lèi)型。這個(gè)聯(lián)合中的字段可以被命名。每一個(gè)CHOICE的實(shí)例,都必須指定為這個(gè)聯(lián)合中的一個(gè)類(lèi)型。例如: 

            以上內(nèi)容翻譯自http://www.lkn.ei.tum.de/arbeiten/faq/man/tau42_help/ttcncase8.html

             

            /*******************************************休息一下***************************************

            下面我們來(lái)研究eSNACC的C代碼生成和C運(yùn)行時(shí)庫(kù)對(duì)ASN.1 constructors的處理辦法:

            一、因?yàn)锳SN.1允許不命名集合中的字段,但是C語(yǔ)言要求變量必須有名字,所以eSNACC對(duì)SETs, SEQUENCEs, CHOICEs中的空字段都會(huì)自動(dòng)命名。名字依賴(lài)于該字段的類(lèi)型名。

            二、對(duì)SEQUENCE (of)SET (of)中用OPTIONAL指定的可選元素,大部分都以指針實(shí)現(xiàn)。當(dāng)指針不為NULL時(shí)那么就代表這個(gè)元素存在。不過(guò)當(dāng)元素是OCTET STRINGs, BIT STRINGs OBJECT IDENTIFIERs類(lèi)型時(shí)例外,因?yàn)檫@些類(lèi)型很小,而且底層實(shí)現(xiàn)還包含一個(gè)內(nèi)部的指針,利用那個(gè)指針就可以表明元素是否存在。具體請(qǐng)參加本系列前面的文章:對(duì)比特串、字節(jié)串、OBJECT IDENTIFIERs的編碼和解碼等。

            三、總結(jié):eSNACC對(duì)ASN.1 constructors->C類(lèi)型轉(zhuǎn)換規(guī)則:

            SEQUENCE —> C struct
            SET —> C struct

            SEQUENCE OF —> 雙向鏈表AsnList
            SET OF —> 雙向鏈表AsnList

            ENUMERATED  —> C enum
            CHOICE : 比較有意思,我們以后再專(zhuān)門(mén)討論。

            ASN.1到C struct和enum就是直接的對(duì)應(yīng)關(guān)系,很簡(jiǎn)單。這里我們主要看看eSNACC的雙向鏈表AsnList。

            看一下AsnList的定義:

            typedef struct AsnListNode
            {
                
            struct AsnListNode    *prev;
                
            struct AsnListNode    *next;
                
            void        *data;        /* this must be the last field of this structure  */
            }
             AsnListNode;

            typedef 
            struct AsnList
            {
                AsnListNode        
            *first;
                AsnListNode        
            *last;
                AsnListNode        
            *curr;
                
            int            count;        /* number of elements in list               */
                
            int            dataSize;    /* space required in each node for the data */
            }
             AsnList;

            要注意AsnList與我們一般寫(xiě)的鏈表可能不同的是:他專(zhuān)門(mén)設(shè)計(jì)了一個(gè)頭AsnList,而真正存放節(jié)點(diǎn)內(nèi)容的是AsnListNode。AsnList中包含了頭結(jié)點(diǎn)、尾節(jié)點(diǎn)、當(dāng)前節(jié)點(diǎn)指針,節(jié)點(diǎn)元素的數(shù)目和每一個(gè)節(jié)點(diǎn)元素的數(shù)據(jù)大小(也就是為data分配內(nèi)存時(shí)的值)。

            利用AsnList,我們就能很方便的得知包括鏈表頭尾指針、總數(shù)等的信息了。也能很方便的對(duì)整個(gè)鏈表進(jìn)行遍歷訪問(wèn)等操作了。

            要說(shuō)明的是:first節(jié)點(diǎn)的prev指針和last的next指針總是NULL。而且AsnList的dataSize字段必須在生成鏈表或者使用前初始化時(shí)就必須賦予明確的值,因?yàn)橹皇敲縿?chuàng)建一個(gè)AsnListNode時(shí)對(duì)data分配的內(nèi)存大小數(shù)。

            對(duì)AsnList的分析,我準(zhǔn)備就只講這些了。之所以不展開(kāi)函數(shù)實(shí)現(xiàn),是因?yàn)槔锩婢褪菙?shù)據(jù)結(jié)構(gòu)中的鏈表操作算法,想必大家都相當(dāng)熟悉,所以不怕老生常談,也擔(dān)心班門(mén)弄斧,就算了吧。

             

            不過(guò),你可能發(fā)現(xiàn)有些問(wèn)題:

            1、上文中提到過(guò):SEQUENCE OF是有序的,而SET OF無(wú)序的。那我們?cè)诰幾g成C語(yǔ)言時(shí)要怎么對(duì)應(yīng)呢?我們看看eSNACC:他絲毫沒(méi)有提這個(gè),壓根就無(wú)視這個(gè)性質(zhì)!這有問(wèn)題嗎?

            從ASN.1語(yǔ)義上來(lái)說(shuō),確實(shí)是沒(méi)有體現(xiàn),但是其實(shí)是沒(méi)有問(wèn)題的。因?yàn)锳SN.1中所要求的有序無(wú)序,是說(shuō)明數(shù)據(jù)編碼和傳輸?shù)膯?wèn)題:有序就是要保證數(shù)據(jù)定義的順序。而我們轉(zhuǎn)為C語(yǔ)言,本來(lái)就是按數(shù)據(jù)定義的順序而轉(zhuǎn)的,而編碼解碼自然就只能是C定義的順序了,也就是說(shuō)最后無(wú)論是對(duì)SEQUENCE OF還是SET OF,我們都保證了他是有序的,這當(dāng)然沒(méi)有問(wèn)題了。

            2、AsnList中存放數(shù)據(jù)的都是void*類(lèi)型,這就不知道數(shù)據(jù)的原始類(lèi)型了呀?

            是的,AsnList中確實(shí)只是存放了void*,這導(dǎo)致類(lèi)型丟失了。也就是你如果不小心存了不同類(lèi)型的數(shù)據(jù),他也一言不發(fā)的縱容了你。這是類(lèi)型不安全的。BTW,在eSNACC的C++庫(kù)中,就不存在這個(gè)問(wèn)題了,這個(gè)留待以后對(duì)eSNACC的C++運(yùn)行時(shí)庫(kù)剖析時(shí)再說(shuō)。

             

            好了,本篇就到此了。

             

            posted on 2012-04-25 15:01 Tim 閱讀(1695) 評(píng)論(2)  編輯 收藏 引用 所屬分類(lèi): eSNACC學(xué)習(xí)

            評(píng)論

            # re: eSNACC對(duì)ASN.1 constructors的處理[未登錄](méi) 2012-04-27 09:36 Tina

            不錯(cuò)的文章。。。  回復(fù)  更多評(píng)論   

            <2012年4月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            導(dǎo)航

            統(tǒng)計(jì)

            公告

            本博客原創(chuàng)文章,歡迎轉(zhuǎn)載和交流。不過(guò)請(qǐng)注明以下信息:
            作者:TimWu
            郵箱:timfly@yeah.net
            來(lái)源:www.shnenglu.com/Tim
            感謝您對(duì)我的支持!

            留言簿(9)

            隨筆分類(lèi)(173)

            IT

            Life

            搜索

            積分與排名

            最新隨筆

            最新評(píng)論

            閱讀排行榜

            久久中文字幕精品| 香蕉久久永久视频| 精品亚洲综合久久中文字幕| 国产Av激情久久无码天堂| 欧美亚洲国产精品久久蜜芽| 久久亚洲精品无码播放| 国产成人精品综合久久久久| 久久精品国产秦先生| 看全色黄大色大片免费久久久| 久久人人爽人人人人片av| 久久久国产精品福利免费 | 久久久久亚洲精品日久生情 | 久久996热精品xxxx| 久久久国产亚洲精品| 精品国产一区二区三区久久久狼 | 国产精品久久久99| 久久狠狠爱亚洲综合影院| 狠狠精品久久久无码中文字幕| 国产aⅴ激情无码久久| 欧美日韩中文字幕久久久不卡| 狠狠久久亚洲欧美专区| 国产成年无码久久久免费| 久久国产视屏| 88久久精品无码一区二区毛片| 无码精品久久久久久人妻中字| 热综合一本伊人久久精品| 国产成人久久久精品二区三区| 99国产精品久久| 久久久久亚洲精品天堂| 99久久夜色精品国产网站| 久久受www免费人成_看片中文| 2020最新久久久视精品爱| 国产精品久久久久aaaa| 久久久久人妻一区精品色| 久久久老熟女一区二区三区| 色狠狠久久AV五月综合| 欧美噜噜久久久XXX| 精品久久久久中文字幕日本| 国产91色综合久久免费| 91精品国产高清久久久久久io| 99久久人妻无码精品系列|