我正在尝试将表的地址传递给要在另一个函数中使用的指针,但得到不兼容的指针类型
I am trying to pass the address of a table to a pointer to be used in another function but am getting incompatible pointer type
下面是我试图测试的代码。我有一个大小为 2x4 的表,我正在尝试将地址传递给一个将由查找函数使用的指针。代码按预期工作,我收到正确的值,但我收到以下警告:
警告:来自不兼容指针类型 [-Win兼容指针类型] 的赋值
下面是代码:
#include <stdio.h>
float lookup(float const *lookuppointer, int lookupindexX)
{
float value;
value = lookuppointer[lookupindexX];
return(value);
}
int main()
{
float cal1[2][4] = {{0,1,2,3},{4,5,6,7}};
float value;
float *pointer[4];
*pointer = cal1;
printf("The address of pointer is %p n", pointer);
value = lookup(*pointer,6);
printf("The value is %f n", value);
printf("cal1 = %f", cal1[1][2]);
return 0;
}
同样出于某种原因,我需要在定义指针时添加一个大小,我可以输入任何数字并且它可以工作(例如 float *pointer[n](,我也不明白它背后的原因。
我正在尝试将地址传递给指针
float *pointer[4];
这不是指针。这是一个包含 4 个指向float
的指针的数组。这些指针不能指向float cal1[2][4]
元素,因为这些元素是float
数组,而不是单个float
对象。
float cal1[2][4]
的元素是一个由 4 个浮点数组成的数组。要指向这样的元素,你需要创建一个指向一个由 4 个浮点数组成的数组的指针:
float (*pointer)[4];
*pointer = cal1;
这会通过尚未初始化的指针进行间接处理,并尝试分配未指向的对象。如果程序不是格式不正确,则行为将是未定义的。
现在,如果指针指向数组,例如cal1
元素,这将不起作用,因为数组不可分配。
您可能打算指定指针而不是指向的对象。通过不通过指针进行间接操作来实现:
pointer = cal1;
相关文章:
- C++中的双指针类型转换
- C++默认情况下,指针类型数组的元素是否保证初始化为 nullptr?
- 将类指针类型转换为键时出错
- 错误:表达式必须具有算术、无作用域枚举或带有运算符重载的指针类型
- C++在一个映射中存储不同的指针类型(并处理销毁)
- 指针类型类成员的动态强制转换的恒定性是什么?
- 我正在尝试将表的地址传递给要在另一个函数中使用的指针,但得到不兼容的指针类型
- 在将派生类指针类型转换为派生类指针后,从基类指针调用派生类函数
- 如何使用静态多态性在 int 和指针类型之间进行转换?
- STL 函数和函数类型与函数指针类型
- 如何调用指针类型的方法(禁用多态性)?
- 为什么新表达式可以正确生成指针类型,即使它应该返回 void*?
- 对于非常量指针类型的参数,未调用具有常量指针模板类型参数的功能
- 是否允许调用方对我的 Builder 类使用任何指针类型(包括智能指针)?
- OPENCL 警告:不兼容的指针类型将'float __global[16]'传递给类型为 '__global float4 的参数 *
- 专门用于"direct"函数类型(与函数指针类型相对)
- 指向成员的指针类型和模板
- 返回对常量结构(指针类型)成员的引用:明显的左值到右值转换
- 在C++17中,为什么类模板和函数模板的指针类型推导明显不一致
- 为什么允许将整型、枚举和指向成员的指针类型reinterpret_cast到自身?