2016-08-08 2 views
2

мне нужно пройти предварительно выделен массив строк в качестве параметра функции, и зЬгсру() для каждой из строк в массиве строк, как в этом примере:С - Передать массив строк в качестве функционального параметра

static void string_copy(char * pointer[]) { 

    strcpy(pointer[0], "Hello "); 

    strcpy(pointer[1], "world"); 

} 

int main(int argc, const char * argv[]) { 

    char my_array[10][100]; 

    string_copy(my_array); 

    printf("%s%s\n", my_array[0], my_array[1]); 

} 

И получившаяся печатная строка будет «Hello world».

Как передать предварительно выделенный массив строк и заполнить каждую строку в функции, как показано выше?

+1

Используйте символ ** и цикл –

+0

Как и в «статическом аннулируются string_array (полукокс ** указатель [])»? Это не скомпилировалось. –

ответ

3

Когда вы делаете string_copy(my_array), вы передаете char (*)[100], то есть pointer to char[100] array к вашей функции. Но ваша функция ожидает char *[], т. Е. array of char pointers, потому что вы определили свою функцию таким образом.

Вы можете исправить это, внеся изменения, чтобы ваша функция (string_copy()) ожидала char (*)[100], а не char *[].

Для этого, вы можете изменить определение функции, как:

/* Your my_array gets converted to pointer to char[100] 
    so, you need to change your function parameter 
    from `char *pointer[]` to `char (*pointer)[100]` 
*/ 
/* static void string_copy(char *pointer []) */ 
static void string_copy(char (*pointer) [100]) 
{ 
    strcpy(pointer[0], "Hello "); 
    strcpy(pointer[1], "world"); 
} 

* Альтернативное решение *

Другой дизайн/решение было бы изменить в main() функции, так что вы фактически, проходящий char *[], который распадается на char ** - это штраф - до string_copy(). Таким образом, вам не придется менять функцию string_copy().

int main(int argc, const char * argv[]) { 

    char my_array[10][100]; 
    int tot_char_arrs, i; 
    char *char_arr_ptr[10]; 

    /* Get total number of char arrays in my_array */ 
    tot_char_arrs = sizeof(my_array)/sizeof(my_array[0]); 

    // Store all char * 
    for (i = 0; i < tot_char_arrs; i++) 
      char_arr_ptr[i] = my_array[i]; 

    /* Actually passing a char *[]. 
     it will decay into char **, which is fine 
    */ 
    string_copy(char_arr_ptr); 

    printf("%s%s\n", my_array[0], my_array[1]); 
} 
+0

О, я вижу. Извините, у вас две версии. – 2501

+0

@ 2501 Я отредактировал сообщение и подчеркнул, что есть две версии, так что это не смущает будущих читателей. Я думаю, что способ, которым я это поставил, мог смутить людей. – sps

1

Ваша функция может просто принять размеры матрицы и передать const char *, который хранит массив литер (предварительно выделенных) строк:

#include <stdio.h> 
#include <string.h> 

#define STRINGS_LENGTH 100 

static void string_copy(size_t n, size_t m, char pointer[n][m], const char *strings_to_copy[]) 
{ 
    for (size_t i=0; i< n; i++) 
    { 
     strcpy(pointer[i], strings_to_copy[i]); 
    } 
} 

int main(void) 
{ 
    const char *strings[] = { "hello", "World" }; 
    char my_array[sizeof(strings)/sizeof(strings[0])][STRINGS_LENGTH]; 

    string_copy(sizeof(strings)/sizeof(strings[0]), STRINGS_LENGTH, my_array, strings); 

    printf("%s %s\n", my_array[0], my_array[1]); 
} 

Вы также можете изменить структуру кода с использованием динамического распределения для вашего выходного массива:

#include <stdio.h> 
#include <string.h> 
#include <stdlib.h> 
#include <stdbool.h> 

static bool string_copy(char *pointer[], const char *strings_to_copy[], size_t strings) 
{ 

    for (size_t i=0; i< strings; i++) 
    { 
     pointer[i] = malloc(strlen(strings_to_copy[i])+1); 

     if (pointer[i] != NULL) 
      strcpy(pointer[i], strings_to_copy[i]); 
     else 
      return false; 
    } 

    return true; 
} 

int main(void) 
{ 
    const char *strings[] = { "hello", "World" }; 
    char *my_array[sizeof(strings)/sizeof(strings[0])] = {0}; 

    if (string_copy(my_array, strings, sizeof(strings)/sizeof(strings[0]))) 
    { 
     printf("%s %s\n", my_array[0], my_array[1]); 
    } 

    for (size_t i = 0; i<sizeof(strings)/sizeof(strings[0]); i++) 
     free (my_array[i]); 
} 
3

необходимо использовать указатель на массив. вот пример с 1 двухмерного массивом:

#include <stdio.h> 
#include <stdbool.h> 
#include <string.h> 

static void string_copy(char **pointer) { 

    strcpy(pointer[0], "Hello "); 

} 

int main(int argc, const char * argv[]) { 

    char my_array[10]; 
    char * p_array = my_array; 

    string_copy(&p_array); 

    printf("%s\n", my_array); 

} 
Смежные вопросы