標(biāo)題: 如何把0x20015ca8這個數(shù)轉(zhuǎn)化為C語言數(shù)組? [打印本頁]

作者: yxyxyxyx    時間: 2022-10-12 09:48
標(biāo)題: 如何把0x20015ca8這個數(shù)轉(zhuǎn)化為C語言數(shù)組?
能不能把這個數(shù)轉(zhuǎn)化為a[len]={a,b,c,d,e,f.........l,m,n................}這種形式,長度不限,都可以的。


作者: coody_sz    時間: 2022-10-12 10:54
一個整型數(shù),你是要拆分幾個字節(jié)放數(shù)組里?
作者: yzwzfyz    時間: 2022-10-12 11:06
先按你的想法建立一個數(shù)組。
再將0x20015ca8按你的想法拆解開來。
最后放入你建立的數(shù)組中。

作者: Y_G_G    時間: 2022-10-12 14:11
你還不如說你要干嘛,直接問問題本身
而不是想當(dāng)然的覺得,一個問題應(yīng)該要"這樣"解決,然后就問怎么做
0x20015ca8是一個數(shù)
數(shù)組是一堆數(shù)
這兩者之間沒有等號關(guān)系,或者是說一點(diǎn)關(guān)系都沒有,那要怎么轉(zhuǎn)換呢?
100塊錢你要換一堆錢,你總得說是要五毛的還是一塊的吧?
作者: 名字不是重點(diǎn)    時間: 2022-10-12 15:46
unsigned int arr16[2];        雙字節(jié)數(shù)組
unsigned char arr8[4];單字節(jié)數(shù)組
unsigned char arr4[8];半字節(jié)數(shù)組
void main()
{         
unsigned long num;
unsigned char i;

num=0x20015ca8;       
for(i=0;i<2;i++)
{
arr16[1-i]=(int)num ;
num>>=16;
}       
       
num=0x20015ca8;       
for(i=0;i<4;i++)
{
arr8[3-i]=(char)num ;
num>>=8;
}       

num=0x20015ca8;
for(i=0;i<8;i++)
{
arr4[7-i]=(char)num&0x0f;
num>>=4;
}       
        while(1);
}


作者: 名字不是重點(diǎn)    時間: 2022-10-12 15:47
就這么簡單。

作者: 我未曾來過    時間: 2022-10-12 16:59
我按照你的字面意思來理解,你是想把0x20015ca8,轉(zhuǎn)換成{0x20,0x01,0x5c......}這種的對嗎,你用先按位與,再位移的辦法就行。0xAABB>>8得到0xAA,0xAABB&0xFF得到0xBB,更長的也是同理的
作者: Hephaestus    時間: 2022-10-12 19:51
樓主另一個帖子已經(jīng)說明了是想把這個數(shù)拆成字節(jié)經(jīng)由iic收發(fā),把地址賦值給一個字符指針char*,然后操作這個指針就行了。位移運(yùn)算是沒有必要的,也浪費(fèi)時間。
作者: 我未曾來過    時間: 2022-10-13 07:58
我以為他是想轉(zhuǎn)化出一個數(shù)組,不知道后續(xù)還要干什么
作者: 624353765    時間: 2022-10-13 08:49
本來就是數(shù)組,何必要去拆分呢
long num=0x20015ca8;
char*str=&num;
char a=str[0];
作者: 624353765    時間: 2022-10-13 08:53
更直接的操作
long num=0x20015ca8;
char a=((char*)num)[1];
作者: 624353765    時間: 2022-10-13 09:05
結(jié)構(gòu)體用法
union str{
long num;
char c_num[4];
}
num n;
n.num=0x20015ca8;
char a=n.c_num[0];
作者: 624353765    時間: 2022-10-13 09:29
qq624353765 發(fā)表于 2022-10-13 08:53
更直接的操作
long num=0x20015ca8;
char a=((char*)num)[1];

有個小錯誤
char a=((char*)&num)[1];
作者: 馮特洛夫斯基    時間: 2022-10-13 10:55
/*
十六進(jìn)制數(shù)據(jù)改寫為C語言數(shù)組形式
如:
0111
022222
03333333
生成:
{0x01,0x11},
{0x02,0x22,0x22},
{0x03,0x33,0x33,0x33},

如果第一個數(shù)為數(shù)據(jù)長度信息,第二個數(shù)為地址,其他為數(shù)據(jù)
如:
0111
022222
03333333
生成:
{0x01,0x01,0x11},
{0x02,0x02,0x22,0x22},
{0x03,0x03,0x33,0x33,0x33},

*/

#include <stdio.h>
#include <string.h>

int main(void)
{
        FILE *fp = NULL;
        int count = 0;
        int num = 0;
        int num2 = 0;
        int num3 = 0;
        int num4 = 0;
        char buf[16000] = {}; //存儲原來的數(shù)據(jù)
        char buf2[16000] = {}; //原來的數(shù)據(jù)加上每行的數(shù)據(jù)個數(shù)
        char result[16000] = {}; //改寫為C語言數(shù)組形式。
        fp = fopen("str.txt", "r");
        if  (fp == NULL) {     
                printf("open str.txt err!\n");
                return -1;
        }

        count = fread(buf, sizeof(char), sizeof(buf), fp);
        printf("read %d bytes\n", count);
        if (count < 0) {
                printf("read err!\n");
                return -1;
        }
        fclose(fp);
/* 每行前面兩個數(shù)據(jù)為該行有效16進(jìn)制數(shù)據(jù)的長度,不需要長度信息,可以把下面這段屏蔽掉 */
#if 1
        num2 += 2;
        num3 = 0;
        while(num < count) {
                while(buf[num] != '\n') {
                        buf2[num2] = buf[num];
                        num2++;
                        num++;
                }
                if (buf[num] == '\n') {
                        buf2[num2] = buf[num];
                        num4 = (num2 - num3 - 1) / 2 - 1;
                        if (num4 / 16 >= 10)
                                buf2[num3] = num4 / 16 % 10 + 'A';
                        else
                                buf2[num3] = num4 / 16 + '0';

                        if (num4 % 16 >= 10)
                                buf2[num3+1] = num4 % 16 % 10 + 'A';
                        else
                                buf2[num3+1] = num4 % 16 + '0';
                        
                        printf("num=%d, num2=%d, num3=%d, num4=%d\n", num, num2, num3, num4);
                        num3 = num2 + 1;
                        num2 += 3;
                        num++;
                }
        }
        memset(buf, 0, sizeof(buf));
        memcpy(buf, buf2, sizeof(buf));
        printf("buf = %s\n", buf);
        count = num2;
        num = 0;
        num2 = 0;
        num3 = 0;
        num4 = 0;
#endif

        result[0] = '{';
        result[1] = '0';
        result[2] = 'x';
        num2 = 3;
        while (num < count) {
                num3++;
                if (buf[num] == '\n') {
                        num3 = 0;
                        result[num2++] = '}';
                        result[num2++] = ',';
                        result[num2++] = buf[num];
                        result[num2++] = '{';
                        result[num2++] = '0';
                        result[num2++] = 'x';
                        num++;
                        continue;
                }
                if (num3 <= 2) {
                        result[num2++] = buf[num];
                }
                if (num3 == 2) {
                        if (buf[num+1] != '\n') {
                                result[num2++] = ',';
                                result[num2++] = '0';
                                result[num2++] = 'x';
                        }
                        num3 = 0;
                }
                num++;
        }
        fp = fopen("result.txt", "w+");
        if  (fp == NULL) {     
                printf("open result.txt err!\n");
                return -1;
        }
        count = fwrite(result, 1, num2+1, fp);
        printf("write %d bytes\n", count);
        if (count < 0) {
                printf("write result.txt err!\n");
                return -1;
        }
        fclose(fp);
        return 0;
}




歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1