1. <var id="fe6gj"></var>

    <rp id="fe6gj"><nav id="fe6gj"></nav></rp>

    <noframes id="fe6gj"><cite id="fe6gj"></cite>

    <ins id="fe6gj"><button id="fe6gj"><p id="fe6gj"></p></button></ins>
    1. <tt id="fe6gj"><i id="fe6gj"><sub id="fe6gj"></sub></i></tt>
        始創于2000年 股票代碼:831685
        咨詢熱線:0371-60135900 注冊有禮 登錄
        • 掛牌上市企業
        • 60秒人工響應
        • 99.99%連通率
        • 7*24h人工
        • 故障100倍補償
        您的位置: 網站首頁 > 幫助中心>文章內容

        7BIT壓縮編碼長度計算方法(C編程實現)

        發布時間:  2012/8/8 17:28:40
        大家都知道,ASCII(不包括擴展ASCII)的最高位是0,所以,我們可以利用這一空位來存儲數據,“7BIT壓縮編碼”就是這么做的。關于7BIT壓縮編碼的詳細算法,可以在網上找到(Simple)。這里,我說一下自己的一種關于計算7BIT編碼長度的C語言實現方法。(應該有更好的方法啦~)
         
        1。如果給出已經7BIT編碼的字符串,在不解碼的情況下,計算出解碼后的長度,也就是源碼(ASCII)的長度。
         
        pSrc -- 已經編碼的字符串地址
        nSrc -- 通過函數strlen(pSrc)計算出來的長度
        nLength -- 原編碼的長度(就是我們想知道的結果)
               
        if (nSrc%7 == 0)
        {
            if (*(pSrc+nSrc-1) >> 1)
                nLength = (nSrc/7)*8;
            else
                nLength = (nSrc/7)*8 - 1;
        }
        else
        {
            if (*(pSrc+nSrc-1) >> (8-nSrc%7))
                nLength = (nSrc/7)*8 + nSrc%7 + 1;
            else
                nLength = (nSrc/7)*8 + nSrc%7;
        }
         
        解釋:
            第一個判斷編碼后的長度是不是7的倍數,我們都知道,7BIT壓縮編碼可以將8字節ASCII壓縮成7字節。如果編碼后的長度恰好是7的倍數,那么就“很可能"源碼是8的倍數長度。這里只能說是“很可能”,因為 8*n-1 個ASCII編碼后也會占用 7*n 個字節(也有可能是 7*n-1 字節)。也就是說,160個ASCII編碼后為140字節,159個ASCII編碼后也為140字節(或者139字節),那么現在我們知道編碼后是140字節,原編碼ASCII到底是160個,還是159個呢?

            if (*(pSrc+nSrc-1) >> 1) 做出了判斷,如果結果為真,那么就是 8*n 個原編碼,如果為假,那么就是 8*n-1 個原編碼。這里,相信大家稍微思考一下就明白了;)嘻嘻,有不明白的,email問我啦~
           
            如果編碼后的長度,不是7的倍數,那么對最后一位的移位判斷稍微復雜一些,道理是和上面一樣的,只是移位的位數不一樣而已。計算長度的時候,先取出8位ASCII的整數倍(nSrc/7)*8,然后再取余數nSrc%7,然后根據對最后一位的移位判斷結果,判斷到底是否還得加一位。(這是為什么呢?為什么不是和上面7的整數被時的減一位呢?哈哈~思考一下就知道了)
           
        2。如果給出原ASCII字符串,在不編碼的情況下,計算出7BIT編碼后的長度。
         
        pSrc -- 源ASCII字符串地址
        nSrc -- 通過函數strlen(pSrc)計算出來的長度
        nLength -- 7BIT編碼后的長度(就是我們想知道的結果)
         
        if (nSrc%8 == 0)
        {
            nLength = (nSrc/8)*7;
        }
        else
        {
            if (*(pSrc+nSrc-1) >> nSrc%8-1)
                nLength = (nSrc/8)*7 + ((nSrc%8)*7)/8 + 1;
            else
                nLength = (nSrc/8)*7 + ((nSrc%8)*7)/8;
        }
         

        本文出自:億恩科技【www.endtimedelusion.com】

        服務器租用/服務器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質保障!--億恩科技[ENKJ.COM]

      1. 您可能在找
      2. 億恩北京公司:
      3. 經營性ICP/ISP證:京B2-20150015
      4. 億恩鄭州公司:
      5. 經營性ICP/ISP/IDC證:豫B1.B2-20060070
      6. 億恩南昌公司:
      7. 經營性ICP/ISP證:贛B2-20080012
      8. 服務器/云主機 24小時售后服務電話:0371-60135900
      9. 虛擬主機/智能建站 24小時售后服務電話:0371-60135900
      10. 專注服務器托管17年
        掃掃關注-微信公眾號
        0371-60135900
        Copyright© 1999-2019 ENKJ All Rights Reserved 億恩科技 版權所有  地址:鄭州市高新區翠竹街1號總部企業基地億恩大廈  法律顧問:河南亞太人律師事務所郝建鋒、杜慧月律師   京公網安備41019702002023號
          0
         
         
         
         

        0371-60135900
        7*24小時客服服務熱線

         
         
        av不卡不卡在线观看_最近2018年中文字幕_亚洲欧美一区二区三区_一级A爱做片免费观看国产_日韩在线中文天天更新_伊人中文无码在线