关于在通用函数中进行转换的一些误解
我对班上的教程有一些误解.有一个名为print_Arr()的函数,它是泛型函数,它获取指向double或整数数组的指针并打印它.
这是代码: int main() { int a[] = { 2,7,6,4,1 }; double b[] = { 12.5,2.7,3.0,5.5,5.9,1.0 }; print_Arr(a,sizeof(a)/sizeof(a[0]),sizeof(int),print_int); print_Arr(b,sizeof(b)/sizeof(b[0]),sizeof(double),print_double); } void print_Arr(void* a,int size,int m,void (*print_func)(void* )) { for (int i = 0; i <= size-1; i++) { print_func((char*)a + m*i); } } void print_int(int* p) { printf("%dn",*p); } void print_double(double* num) { printf("%fn",*num); } 为什么我必须在此行中转换为(char *): print_func((char*)a + m*i); 我发送给print_Arr()泛型函数两种类型的数组整数或双精度数, 但为什么它会变成char *?我错过了什么? 解决方法
首先,要说明为什么需要演员:
指针算术利用所指向类型的大小. void是一个永远不完整的类型,无法完成,因此无法在指向void类型的指针上进行指针运算. 要为加法运算符添加引用C11,章节§6.5.6,约束:
并且,从第6.2.5章开始,
那说,为什么演员阵容是char *: 指针算术使用指向的类型.再次引用规范
在这里,看看你的构造: ((char*)a + m*i); 其中m是实际参数指向的实际对象类型的大小.因此,如果将指针强制转换为实际类型,则计算错误.为了进行比较,请说: > sizeof(char)为1,标准规定. 因此,对于数组int arr [] = {1,2,3,4},表达式 >(char *)a(sizeof(int)* 1) 是等价的. 最后,触及将另一种类型的指针转??换为char *并访问它的主题:
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |