C++中函数传参时用指针传递数组

本文介绍了如何在C++中使用指针传递数组到函数,以及一个实际应用案例——`Electrickinematics`类中的`displacementToAngle`函数,该函数接收输入参数并处理电缸或电机位移数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

        在C++中,使用指针传递数组到函数是一种常见的做法,特别是当你需要修改数组的内容或者当数组的大小很大,不希望复制整个数组时。 

1、简介: 
#include <iostream>  
using namespace std;
  
//函数声明,接收指向double类型数组的指针和数组的大小  
void modifyArray(double* arrPtr, int size);  

//函数定义,接收指向double类型数组的指针和数组的大小  
void modifyArray(double* arrPtr, int size) 
{  
    //使用指针访问和修改数组元素  
    for (int i = 0; i < size; ++i) 
    {  
        arrPtr[i] *= 2; // 将数组中的每个元素乘以2  
    }
} 

int main() 
{  
    // 定义一个数组  
    double myArray[5] = {1.0, 2.0, 3.0, 4.0, 5.0};
    // 计算数组大小   
    int arraySize = sizeof(myArray) / sizeof(myArray[0]); 
  
    // 调用函数,传递数组指针和大小  
    modifyArray(myArray, arraySize);  
  
    // 输出修改后的数组  
    for (int i = 0; i < arraySize; ++i) 
    {  
        std::cout << "myArray[" << i << "] = " << myArray[i] << std::endl;  
    }  
  
    return 0;  
} 
2、项目实例中的用法:
//创建一个Electrickinematics类
class Electrickinematics
{
public:
    //displacementToAngle:电缸或电机位移输出到关节角度的转换;
    //参数类型为指针
    void displacementToAngle(double *parameter_input, double *theta_input);
};

//定义两个数组
double theta_input[7];
double parameter_input[7];

//定义函数displacementToAngle
void Electrickinematics::displacementToAngle(double *parameter_input, double*theta_input)
{
    //theta_input[]数组的第一个元素(即第一个角度值)设置为0,
    theta_input[0] = 0;
    theta_input[1] = parameter_input[1];
    theta_input[2] = parameter_input[2];
    theta_input[3] = parameter_input[3];
    theta_input[4] = parameter_input[4];
    theta_input[5] = parameter_input[5];
    theta_input[6] = parameter_input[6];

    //输出数组theta_input中索引为1到6的元素的值,并将它们与对应的索引一起打印出来
    for(int i=1;i<=6;i++)
    {
        std::cout<<"displacementToAngle theta_["<<i<<"]="<<theta_input[i]<<endl;
        //打印当前索引 i 和对应的 theta_input[i] 的值。
    }
}

//函数调用,利用指针传递数组
endPosture_temp.displacementToAngle(parameter_input,theta_input);

### C++ 中二维数组函数传递方法 在 C++ 中,可以通过多种方式将二维数组作为参数传递函数。以下是几种常见的方式: #### 方法1:传递数组并指定第二维度大小 当传递二维数组,必须显式声明第二个维度的大小。这是因为编译器需要知道每一行有多少列来计算内存偏移。 ```cpp #include <iostream> using namespace std; void fun1(int arr[][3], int iRows) { for (int i = 0; i < iRows; ++i) { for (int j = 0; j < 3; ++j) { cout << arr[i][j] << " "; } cout << endl; } } ``` 此代码展示了如何定义接受固定宽度(即每行有三个整数)的二维数组作为输入参数的方法[^1]。 #### 方法2:使用模板和引用传递整个数组 为了使函数更加通用化而不依赖于特定尺寸的数组,可以利用模板特性以及引用机制。这种方法允许调用者提供任意大小的二维数组而无需修改被调用方的接口设计。 ```cpp template<int n, int m> void func2(int (&ary)[n][m]) { // 可在此处操作 ary 数组... } ``` 这段程序片段说明了怎样创建一个能够处理不同规模矩阵的泛型版本函数[^3]。 #### 方法3:通过指针访问元素 如果希望更灵活地控制数据结构,则可以选择采用指向首地址的一级或多级指针形式来进行间接寻址;不过需要注意的是,在这种情况下通常还需要额外的信息比如行列数目才能正确遍历所有项。 ```cpp // 假设有一个动态分配或静态初始化好的二维数组 ptrToArr void processArray(int* p[], size_t rows, size_t cols); ``` 这里给出了一种基于指针的方式来接收外部提供的二维表单,并且强调对于多维情况而言仅限第一个下标的变体可选为星号(*)表示法[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值