完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
首先void *可以包容各种类型,所以图中两个强制类型转换(void*)去掉也不会有warning。
对于你的问题,其实也就是因为在rt_thread结构体中变量sp和entry都声明为(void *),所以问题就变为:为什么声明为void*? void *可以包容各种类型,这只是ANSI/GNU的规定,所以赋值时也可以不强制类型转换。指针变量大小与所用的机器有关,32位机中是32位,64位机中是64位,即等于大小等于其存储器的位宽。你可以自己sizeof一下char *、int *、void *等,在32位机中都等于4,64位机中都等于8。这也很好理解,指针保存的是地址,而指针的长度自然就等于CPU接的存储器的地址总线宽度。 这里看一个简单的例子: char a = 'a'; //void包容所有类型,所以(void*)&a前面的(void*)不加也不会有warning void *b = &a; //使用时需要转化为原来的类型 printf("%c",*(char*)b); 此时假设a的地址是0x10,则*(char*)b代表的就是0x10开始的sizeof(char)=1字节内容,*(*short)b代表的就是0x10开始的sizeof(short)=2字节(32位机)内容。所以要使用时根据原来变量的类型强制转换就行了。 对于rt_thread的成员sp和entry声明为(void *),可以理解为是为了兼容,比如rt_hw_stack_init函数中传的entry参数的类型为void (*)(*void),那么rt_thread中的的这一行void * entry完全可以声明为void (*entry)(*void),那如果以后想让这个函数不带参数呢,又要去rt_thread中将void (*entry)(*void)改为void (*entry)(void),又要改rt_hw_stack_init的参数,这样就不如直接声明为void *来得方便。使用这个函数的时候只需要强制类型转换即可使用: void (*func)(*void) = (void (*)(*parameter))rt_thread.entry; func(parameter);//即调用rt_hw_stack_init中设置的entry函数 这样可能不太好理解,所以一般用typedef typedef void (*fp)(*void); fp func = (fp)re_thread.entry; func(parameter); |
|
|
|
因为这里是一个变量赋值,entry是一个裸指针,定义应该就是 void *
而函数传入的参数是void (*entry)(),这是一个函数指针,因此在赋值的时候需要强行转化一下。 |
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
786 浏览 0 评论
4210 浏览 0 评论
如何使用python调起UDE STK5.2进行下载自动化下载呢?
2520 浏览 0 评论
开启全新AI时代 智能嵌入式系统快速发展——“第六届国产嵌入式操作系统技术与产业发展论坛”圆满结束
2926 浏览 0 评论
获奖公布!2024 RT-Thread全球巡回线下培训火热来袭!报名提问有奖!
31442 浏览 11 评论
72894 浏览 21 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-22 00:49 , Processed in 0.507572 second(s), Total 71, Slave 55 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号