摘要: 我們前面已經(jīng)寫了一篇文章剖析eSNACC哈希結(jié)構(gòu)的設(shè)計(jì)和實(shí)現(xiàn) 剖析eSNACC哈希結(jié)構(gòu)的設(shè)計(jì)和實(shí)現(xiàn) ,而本篇我們專門剖析eSNACC中的hash函數(shù)。
閱讀全文
摘要: 本文剖析hash.h/c,從源代碼來剖析eSNACC哈希結(jié)構(gòu)的設(shè)計(jì)和實(shí)現(xiàn)。
為什么要在這里剖析hash呢?一個順理成章的理由是:我們準(zhǔn)備剖析eSNACC對ANY(s)類型的編碼和解碼,可是ANY的實(shí)現(xiàn)依賴于hash,所以我們就需要先把這條路打通了。O(∩_∩)O哈哈~是不是很有說服力呀?
好,閑話少述,言規(guī)正傳。我們知道hash對一個系統(tǒng)而言,一般都是一個很有價(jià)值的底層基礎(chǔ)設(shè)施。從作用上來說,他實(shí)現(xiàn)的優(yōu)劣極大的影響著整個系統(tǒng)的性能。從技術(shù)上來說,也是很能體現(xiàn)含金量的一個模塊。所以,對eSNACC實(shí)現(xiàn)的這個寶藏,我們下定決心要刨根問底、直搗黃龍!
閱讀全文
摘要: 本文內(nèi)容轉(zhuǎn)自于http://www.cse.yorku.ca/~oz/hash.html。因?yàn)樗麑o出了幾個非常好的hash函數(shù),而其中的sdbm就是我們將剖析的eSNACC用的hash的原型。文章是英文的,但是通俗易懂,就摘錄在此了。
閱讀全文
摘要: 首先讓我們來學(xué)習(xí)一下ASN.1的Constructors類型 。
然后我們來研究eSNACC的C代碼生成和C運(yùn)行時庫對ASN.1 constructors的處理辦法。
閱讀全文
摘要: 本文剖析asn-oid.h/c,從源代碼來學(xué)習(xí)eSNACC對OBJECT IDENTIFIER的編碼和解碼。
在研究代碼之前,我們先來說明什么是OBJECT IDENTIFIER。
閱讀全文
摘要: eSNACC運(yùn)行時庫直接支持各種各樣的ASN.1字符串定義。這包括PrintableString, BMPString, TeletexString, NumericString, IA5String, UniversalString, UTF8String, VisibleString。其做法也大同小異,所有這些字符串都是在eSNACC的字節(jié)串基礎(chǔ)上typedef過來的,只是根據(jù)各自特性的不同而在編碼解碼時有某些判斷,或者加了某些判斷函數(shù)等。只有UTF8String相對比較復(fù)雜一些。讓我們一起來分析一下吧。
閱讀全文
摘要: 本文剖析asn-octs.h/c,從源代碼來學(xué)習(xí)eSNACC對OCTET STRING的編碼和解碼。
eSNACC對字節(jié)串OCTET STRING的處理與上一篇描述的比特串的方法類似,而且字節(jié)串的處理更加簡單。所以在上一篇的基礎(chǔ)上,我們專門分析上一篇中對連接型串解碼時沒有展開講的函數(shù),也作為上一篇的補(bǔ)充。
閱讀全文
摘要: 本文剖析asn-bits.h/c,從源代碼來學(xué)習(xí)eSNACC對BIT STRING的編碼和解碼。
比特字符串的編碼和解碼比較復(fù)雜,而且我認(rèn)為還存在一些問題,我們來仔細(xì)分析一下代碼吧。
閱讀全文
摘要: 本文剖析asn-int.h/c,從源代碼來學(xué)習(xí)eSNACC對INTEGER的編碼和解碼。
eSNACC中的整形與上一篇所講的布爾型一樣,也很簡單,不過代碼中還是有一點(diǎn)有趣的地方。
閱讀全文