我想使一些成功的二維動態字符串數組,但由於某種原因兩個int變量,這實際上是行數(指針數組)和大小(可以多久),變成一個神祕的價值。Int變量神奇地改變從void返回後的值
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <time.h>
void write (char ***p, int size_r, int size_c)
{
int i;
for (i = 0; i < size_r; i++)
{
printf("%s", p[i]);
}
return;
}
void arr_of_p (char*** p, int size_r, int size_c)
{
int i;
for (i = 0; i < size_r; i++)
{
p[i] = "helo\n";
}
return;
}
int main(void)
{
int string_n; printf("How many strings: "); scanf("%d", &string_n);
int string_l; printf("How long are the strings: "); scanf("%d", &string_l);
char **s_p = (char**) malloc(string_n*sizeof(char*));
int i;
for (i = 0; i < string_n; i++)
{
s_p[i] = (char*) malloc(string_l*sizeof(char));
}
arr_of_p(&s_p, string_n, string_l);
printf("%d\n%d\n", string_n, string_l); // for debugging purpose, add breakpoint here.
//"string_n" and "string_l" will be identical to the value of "i" in "arr_of_p()" for some reason...
write(&s_p, string_n, string_l);
return 0;
}
如果'string_l'應該是您輸入字符串的最大長度,並且*符合*那個長度,那麼您的分配大小就會被忽略。你不會考慮終止nullchar房間。而Fyi,在這個代碼中我不需要三重間接,我可以看到。另外,這會像篩子一樣泄漏內存,並且會在'arr_pf_p'中孤立動態分配內存。最後(無關),[不要在C程序中投射'malloc'](https://stackoverflow.com/questions/605845/do-i-cast-the-result-of-malloc)。它可以毫不誇張地說,並可以很容易地隱藏不好。 – WhozCraig
您的'arr_of_p'函數將同一個靜態字符串'「helo \ n」'分配給's_p'中的所有指針。因此,在'main'循環中早些時候爲字符串分配空間並不重要 - 所有內存都在泄漏。另外,'arr_of_p'中的'char *** p'參數不是你想要的。所以'p [i] = ...'這一行也是錯誤的(你確定沒有編譯器的警告嗎?) –
實際上,這就是爲什麼你的int變量越來越小 - arr_of_p正在寫地址靜態字符串覆蓋它們的值。 –