lizhendong
級(jí)別: 家園?
精華主題: 0
發(fā)帖數(shù)量: 608 個(gè)
工控威望: 800 點(diǎn)
下載積分: 1992 分
在線時(shí)間: 853(小時(shí))
注冊(cè)時(shí)間: 2016-10-12
最后登錄: 2025-01-13
查看lizhendong的 主題 / 回貼
樓主  發(fā)表于: 2023-07-27 18:25
C語(yǔ)言大俠們,如何詳細(xì)解讀這兩個(gè)函數(shù)???


char *b24e(char *buf, unsigned char *byst, size_t sizeOfBytes)
{
    int i = 0;
    unsigned char *p = byst;
    while ((size_t)(i = (p-byst)) < sizeOfBytes) {
        buf[2*i] = sel[((*p) >> 4)];
        buf[(2*i)+1] = sel[23 - ((*p) & 0x0f)];
        p++;
    }
    buf[(2*i)+1] = '\0';
    return buf;
}

unsigned char *b24d(unsigned char *buf, char *str, size_t countOfChars)
{
    size_t i;
    char *p = str;
    char *loc[2];
    unsigned char n[2];
    if (countOfChars % 2)
        return NULL;
    for (i = 0; i < (countOfChars>>1); i++) {

        loc[0] = strchr( sel, str[2*i] );
        loc[1] = strchr( sel, str[ ( 2*i ) + 1 ] );
        if (loc[0] == NULL || loc[1] == NULL)
            return NULL;
        n[0] = (unsigned char)( loc[0] - sel );
        n[1] = 23 - (unsigned char)( loc[1] - sel );
        buf = (unsigned char)((n[0] << 4) | n[1]);
    }
    return buf;
}
不小心遇見(jiàn)你
自動(dòng)項(xiàng)目、PLC、視覺(jué)、通訊等工控軟件開(kāi)發(fā)QQ3515716
級(jí)別: 工控俠客

精華主題: 3 篇
發(fā)帖數(shù)量: 2056 個(gè)
工控威望: 2975 點(diǎn)
下載積分: 25212 分
在線時(shí)間: 1447(小時(shí))
注冊(cè)時(shí)間: 2014-01-05
最后登錄: 2025-01-17
查看不小心遇見(jiàn)你的 主題 / 回貼
1樓  發(fā)表于: 2023-07-28 08:18
這個(gè)方法名為b24e,是加密,它的作用是將給定的字節(jié)數(shù)組編碼成Base24格式的字符串
這個(gè)方法名為b24d,是解密,它的作用是將給定的Base24格式的字符串解碼成字節(jié)數(shù)組
祝你好運(yùn)
項(xiàng)目、視覺(jué)、通訊QQ3515716
金蛇郎君czz
車(chē)到山前必有路 czz674613079@163.com
級(jí)別: 網(wǎng)絡(luò)英雄
精華主題: 0
發(fā)帖數(shù)量: 1928 個(gè)
工控威望: 7499 點(diǎn)
下載積分: 505 分
在線時(shí)間: 439(小時(shí))
注冊(cè)時(shí)間: 2019-05-22
最后登錄: 2024-12-22
查看金蛇郎君czz的 主題 / 回貼
2樓  發(fā)表于: 2023-07-28 11:14
跟大佬們學(xué)習(xí)一下
czz674613079@163.com
liuliangdt
liuliangdt
級(jí)別: 家園常客
精華主題: 0
發(fā)帖數(shù)量: 443 個(gè)
工控威望: 682 點(diǎn)
下載積分: 66148 分
在線時(shí)間: 989(小時(shí))
注冊(cè)時(shí)間: 2010-09-05
最后登錄: 2025-01-15
查看liuliangdt的 主題 / 回貼
3樓  發(fā)表于: 2023-07-29 12:39
//b24e是一個(gè)返回char類(lèi)型指針的函數(shù),函數(shù)帶3個(gè)參數(shù)。一個(gè)signed char類(lèi)型指針,一個(gè)unsigned char類(lèi)型指針,一個(gè)堆棧塊數(shù)量的參數(shù)
char *b24e(char *buf, unsigned char *byst, size_t sizeOfBytes)
{
    int i = 0;
    
    //指針p指向形參(*byst)
    unsigned char *p = byst;
    
    //第一次循環(huán)(i = p - byst) = 0強(qiáng)制轉(zhuǎn)換成(size_t)類(lèi)型跟參數(shù)sizeOfBtes比較。結(jié)果大概率是真
    while ((size_t)(i = (p-byst)) < sizeOfBytes) {
        
        //sel是數(shù)組。數(shù)據(jù)(*p)右移4位作為sel數(shù)組的標(biāo)號(hào)。(sel[((*p) >> 4)]是作32位數(shù)據(jù)處理,并且是在做類(lèi)似壓棧操作。buf[2 * i]是char類(lèi)型數(shù)組,搞不懂為什么這樣做?)
        buf[2*i] = sel[((*p) >> 4)];
        
        //((*p) & 0x0f)是上面右移了的4位,最小是0,最大是15。sel[8~23]中的一個(gè)字節(jié)數(shù)據(jù)賦值給buf[(2*i)+1]
        buf[(2*i)+1] = sel[23 - ((*p) & 0x0f)];
      
       //指針加一
        p++;
    }
    
    //數(shù)組byst處理完后在buf后面加0,數(shù)組bug[]現(xiàn)在存的是字符串?dāng)?shù)據(jù)
    buf[(2*i)+1] = '\0';
    
   //返回指針buf
    return buf;
}

太難了,我也不知道什么意思,歡迎大神指正錯(cuò)誤。