指针到指针函数参数

Pointer to pointer function parameter

本文关键字:指针 参数 函数      更新时间:2023-10-16

该函数应该只读取一个矩阵。 为什么输入第一个字符后它会冻结?

#include "stdafx.h"
#include <iostream>
using namespace std;
void as(char **p,int n,int m)
{
int i, j;
for (i = 0; i < n; i++)
for (j = 0; j < m; j++)
{
cout << "p[" << i << "][" << j << "]=";
cin >> p[i][j];
}
}
int main()
{
char *a[100];
as(a, 3, 3);
return 0;
}

这是未定义的行为:您的数组是一个包含 100 个指向char的指针的数组。 但是您从未初始化过它们。 因此,当你解决p[i]时,它会得到一个未初始化的指针,可以指向任何地方,当你用p[i][j]取消引用它时,你可能会冻结或遭受任何其他未定义行为的症状。

如果你想学习使用指针和数组:

解决方案 1:将数组定义为char a[100][100];

解决方案 2:在 as(( 的外循环中,开始分配带有p[i] = new char[m];的字符

如果您想学习现代C++:

解决方案 3:忘记内存分配和释放,改用向量。 向量是完全动态的,因此不再有最多 100 行:

void as(vector<vector<char>> &p, int n, int m)
{
p.resize(n); 
int i, j;
for (i = 0; i < n; i++) {
p[i].resize(m); 
for (j = 0; j < m; j++)
{
cout << "p[" << i << "][" << j << "]=";
cin >> p[i][j];
}
}
}
int main()
{
vector<vector<char>>a;
as(a, 3, 3);
return 0;
}

如果您想在线尝试...

解决方案 4:你想要现代C++,但你想使用 你是a[]中的元素,因为它们是一个字符串,为了便于输出和操作,只需使用与上面相同的代码,但vector<vector<char>>替换为vector<string>

在这里,您可以在线查看稍微简化的代码。

我为您提供了关于 mallocs reallocs 和指针的简单伪数组。也许这对你来说会很有趣:

typedef struct arr_str_t{
size_t rows, columns;
char **table;
}dynamicStringTable_t;
int CreateStringTable(dynamicStringTable_t **ptr, int rows, int columns)
{
int result = 0;
*ptr = (dynamicStringTable_t *)malloc(sizeof(dynamicStringTable_t));
if (ptr == NULL) return - 1;
(*ptr)->rows = rows;
(*ptr)->columns = columns;
(*ptr) -> table = (char *)malloc(rows * columns * sizeof(char *));
if (*ptr == NULL)
{
free(*ptr);
return -1;
}
for (int i = 0; i < rows * columns; i++) (*ptr)->table[i] = NULL;
return 0;
}
char *getString(dynamicStringTable_t *ptr, int x, int y)
{
char *result = (ptr == NULL || x >= ptr->columns || y >= ptr->rows || !x || !y) ? NULL : "";
if (result != NULL)
{
result = ptr->table[x + y * ptr->rows];
}
return result;
}
int putString(dynamicStringTable_t *ptr, int x, int y, const char *str)
{
int result = (ptr == NULL || x >= ptr->columns || y >= ptr->rows || str == NULL || !x || !y) * -1;
if (!result)
{
char *tmp = (char *)realloc(ptr->table[x + y * ptr->rows], (strlen(str) + 1) * sizeof(char));
if (tmp == NULL) result = -2;
else
{
ptr->table[x + y * ptr->rows] = tmp;
strcpy(tmp, str);
}
}
return result;
}
int removeString(dynamicStringTable_t *ptr, int x, int y)
{
int result = (ptr == NULL || x >= ptr->columns || y >= ptr->rows || !x || !y) * -1;
if (!result)
{
free(ptr->table[x + y * ptr->rows]);
ptr->table[x + y * ptr->rows] = NULL;
}
return result;
}
int destroyStringTable(dynamicStringTable_t *ptr, int x, int y)
{
int result = (ptr == NULL || x >= ptr->columns || y >= ptr->rows || !x || !y) * -1;
if (!result)
{
if (ptr->table != NULL)
{
for (int i = ptr->rows * ptr->columns - 1; i >= 0; i--)
free(ptr->table[i]);
free(ptr->table);
}
free(ptr);
}
return result;
}

你的代码中有一个很大的问题。您面对的是以下地区的UB:

char *a[100]; // an array of 100 pointer to a character
// it is not initialized yet
  • 上面没有元素被初始化(甚至没有分配(。

要更正代码,请执行以下操作:

char *a[100];
// Allocating the array of 100 elements on the heap:
for(int i(0); i < 100; i++){
a[i] = new char[100]; // let's say your array is n = m
}
as(a, 3, 3);
for(int i = 0; i < 3; i++){
for(int j(0); j < 3; j++)
cout << a[i][j] << ", ";
cout << endl;
}

最后但并非最不重要的一点是,当您完成动态数组时,不要忘记释放内存:

for(int i = 0; i < 100; i++)
delete[] a[i];