laixiaoshuai90 发表于 2012-7-10 22:21:01

C语言数组问题

一个8位的数组,能不能安16位来读。比如 const unsigned char pic[]={0x11,0x22,0x33,0x44},能不能定义一个指针unsigned short int *pic1=pic;一下子将0x11,0x22一块读出来,得到0x1122。

shark 发表于 2012-7-10 22:36:17

当然可以,不过得注意你的编译器的是大端还是小端.
如果是大端, 读出是0x1122, 如果是小端,读出的是0x2211

laixiaoshuai90 发表于 2012-7-10 22:49:06

shark 发表于 2012-7-10 22:36 static/image/common/back.gif
当然可以,不过得注意你的编译器的是大端还是小端.
如果是大端, 读出是0x1122, 如果是小端,读出的是0x2211 ...

哦 谢谢 我用的是MDK 芯片是stm32f07 不知是大端小端

sdyaojingwen 发表于 2012-7-10 22:53:40

const unsigned char pic[]={0x11,0x22,0x33,0x44},unsigned short int *pic1=(unsigned short int *)pic;这样保险一点

cheungman 发表于 2012-7-10 22:53:44

little endian

sunliezhi 发表于 2012-7-10 23:18:32

试试看吧,如果搞懂了“内存地址的长度”和“内存地址单元中的数据的长度”这两个概念,你就彻底明白了数组了。

happyhls 发表于 2012-7-10 23:29:22

我也觉得肯定可以,为了保险试了一下,结果如下,请教大家。
int main(void)
{
    constunsigned char data={0x11,0x22,0x33,0x44,0x55};
    unsigned short int *p;
    p=&(data);
    printf("Address data %p ,Address p %p ,Value %du\n",data,p,*p);
    printf("Size of unsigned char %d\n",sizeof(unsigned char));
    printf("Size of unsigned int %d\n",sizeof(unsigned short int));
    return 0;
}
使用Code Blocks ,GCC编译器编译运行后结果如下:

请教大家Value打印出的数值是怎么来的?

shark 发表于 2012-7-10 23:54:54

laixiaoshuai90 发表于 2012-7-10 22:49 static/image/common/back.gif
哦 谢谢 我用的是MDK 芯片是stm32f07 不知是大端小端

查了一下 , STM32为小端.

sunliezhi 发表于 2012-7-11 00:01:07

happyhls 发表于 2012-7-10 23:29 static/image/common/back.gif
我也觉得肯定可以,为了保险试了一下,结果如下,请教大家。使用Code Blocks ,GCC编译器编译运行后结果如 ...

0x2211的十进制值就是8721

sunliezhi 发表于 2012-7-11 07:36:54

将上面的代码稍稍扩展一下:
#include <stdio.h>


int main(void)
{
    constunsigned char data={0x11,0x22,0x33,0x44,0x55};
    unsigned char*p1;
    unsigned short *p2;
    unsigned int   *p3;
    unsigned long*p4;

    p1 = data;
    p2 = data;
    p3 = data;
    p4 = data;

    printf("Address data %p, Address p1 %p, p1Value %p\n", data, p1, *p1);
    printf("Address data %p, Address p2 %p, p2Value %p\n", data, p2, *p2);
    printf("Address data %p, Address p3 %p, p3Value %p\n", data, p3, *p3);
    printf("Address data %p, Address p4 %p, p4Value %p\n", data, p4, *p4);

    printf("\n");

    printf("Address data %p, Address p2+1 %p, (p2+1)Value %p\n", data, p2+1, *(p2+1));

    printf("\n");

    printf("Size of unsigned      char = %d byte\n",sizeof(unsigned      char));
    printf("Size of unsigned short int = %d bytes\n", sizeof(unsigned short int));
    printf("Size of unsigned       int = %d bytes\n", sizeof(unsigned       int));
    printf("Size of unsigned longint = %d bytes\n", sizeof(unsigned longint));

    printf("\n");

    return 0;
}


happyhls 发表于 2012-7-11 08:16:21

sunliezhi 发表于 2012-7-11 00:01 static/image/common/back.gif
0x2211的十进制值就是8721

哈哈,犯糊涂了,谢谢啦~

sunliezhi 发表于 2012-7-11 08:21:09

happyhls 发表于 2012-7-11 08:16 static/image/common/back.gif
哈哈,犯糊涂了,谢谢啦~

哈哈,这个帖子好,我也相当于重新温习了一下,理解又深了一些。

laixiaoshuai90 发表于 2012-7-11 10:22:50

本帖最后由 laixiaoshuai90 于 2012-7-11 10:24 编辑

shark 发表于 2012-7-10 23:54 static/image/common/back.gif
查了一下 , STM32为小端.

请问,有没有某个图片数组转化软件,可以设置数组的数据类型呀。Img2Lcd只能得到八位的数组,我想要16位的。stm32确实是小端存储,安以上方法读出来送到LCD中显示是乱码!

armstrong 发表于 2012-7-11 14:09:10

为了可靠考虑,最好使用__packed关键字进行指针的非对齐读写操作,如:
const unsigned char pic[]={0x11,0x22,0x33,0x44},指针定义为__packed unsigned short int *pic1=(__packed unsigned short int *)pic;
由于Cortex-M3内核在硬件上有非对齐访问的支持,所以你可以忽略这些知识;但非对齐访问的效率是很低的,即使是硬件支持也一样无法高效,这是存储器总线结构决定的。
所以,为了养成良好的编程习惯,你应该记住32位处理器有数据对齐问题,如果在arm7内核上,没有__packed关键字,并且如果pic[]被安排在奇数地址的话,你这个代码就会引发异常了!

armstrong 发表于 2012-7-11 14:11:15

想了解更详细的数据对齐知识,请谷歌一下:数据对齐,非对齐访问,等关键字。

shark 发表于 2012-7-11 19:44:15

laixiaoshuai90 发表于 2012-7-11 10:22 static/image/common/back.gif
请问,有没有某个图片数组转化软件,可以设置数组的数据类型呀。Img2Lcd只能得到八位的数组,我想要16位 ...

可以在程序中写两行代码进行转换,当然,效率要受一点影响.

catch2000 发表于 2012-7-12 09:12:07

这个自己测试过
理解会很深。
数据对齐,
非对齐访问的问题,
虽然存在,
但是很多时候,
还真没有去认真考虑。

cheungman 发表于 2012-7-13 18:01:27

shark 发表于 2012-7-11 19:44 static/image/common/back.gif
可以在程序中写两行代码进行转换,当然,效率要受一点影响.

加个宏就行...很多移植性好的算法都是这么做的.
页: [1]
查看完整版本: C语言数组问题