lizhendong
級別: 家園?
精華主題: 0
發(fā)帖數(shù)量: 609 個
工控威望: 801 點
下載積分: 1994 分
在線時間: 854(小時)
注冊時間: 2016-10-12
最后登錄: 2025-01-22
查看lizhendong的 主題 / 回貼
樓主  發(fā)表于: 2023-07-27 18:25
C語言大俠們,如何詳細解讀這兩個函數(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;
}
不小心遇見你
自動項目、PLC、視覺、通訊等工控軟件開發(fā)QQ3515716
級別: 工控俠客

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

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