2016-05-22 4 views
-3

Я пытаюсь попасть в программирование на языке C, и у меня возникают проблемы с назначением и вытаскиванием данных из C-массивов (в этом случае в строки и из строк C-стиля).Trouble Understanding C Basics

Пожалуйста, укажите все ошибки, которые вы видите здесь.

Я в первую очередь программист на языке C++/python, поэтому, пожалуйста, держите объяснения использования и управления памятью как можно проще.

#include <stdio.h> 

typedef struct AuthorInfo { 
    char* firstName; 
    char* lastName; 
} AuthorInfo; 

typedef struct BookEntry { 
    char bookID; 
    char* bookName; 
    AuthorInfo author; 
} BookEntry; 

void assign_str(const char** from, char** to) { 
    int size = sizeof(from)/sizeof(char); 
    printf((char)size); 
    printf('\n'); 
    for (int i=0; i < size; i++) { 
    (*to)[i] = (*from)[i]; 
    }; 
}; 

BookEntry BookEntry_(const int id, const char* bName, const char* aF, const char*aL, BookEntry* ret) { 
    ret->bookID = id; 
    ret->bookName = (char*)malloc(sizeof(bName)); 
    ret->author.firstName = (char*)malloc(sizeof(aF)); 
    ret->author.lastName = (char*)malloc(sizeof(aL)); 
    assign_str(bName, &ret->bookName); 
    assign_str(aF, &ret->author.firstName); 
    assign_str(aL, &ret->author.lastName); 
} 

void display_book(BookEntry* entry) { 
    printf(entry->bookName); 
    printf('\n'); 
    printf(entry->author.firstName); 
    printf(' '); 
    printf(entry->author.lastName); 
    printf('\n'); 
}; 

int main(int argc, char** args) { 
    BookEntry book; 
    book.bookID = 0; 
    assign_str("Tom Sawyer", &book.bookName); 
    assign_str("Mark", &book.author.firstName); 
    assign_str("Twain", &book.author.lastName); 
    display_book(&book); 
    return 0; 
}; 

Компиляция кода с gcc goof.c -o goof -std=c11 приводит:

goof.c: In function ‘assign_str’: 
goof.c:16:10: warning: passing argument 1 of ‘printf’ makes pointer from integer without a cast [-Wint-conversion] 
    printf((char)size); 
     ^
In file included from goof.c:1:0: 
/usr/include/stdio.h:362:12: note: expected ‘const char * restrict’ but argument is of type ‘char’ 
extern int printf (const char *__restrict __format, ...); 
      ^
goof.c:16:3: warning: format not a string literal and no format arguments [-Wformat-security] 
    printf((char)size); 
^
goof.c:17:10: warning: passing argument 1 of ‘printf’ makes pointer from integer without a cast [-Wint-conversion] 
    printf('\n'); 
     ^
In file included from goof.c:1:0: 
/usr/include/stdio.h:362:12: note: expected ‘const char * restrict’ but argument is of type ‘int’ 
extern int printf (const char *__restrict __format, ...); 
      ^
goof.c:17:3: warning: format not a string literal and no format arguments [-Wformat-security] 
    printf('\n'); 
^
goof.c: In function ‘BookEntry_’: 
goof.c:25:26: warning: implicit declaration of function ‘malloc’ [-Wimplicit-function-declaration] 
    ret->bookName = (char*)malloc(sizeof(bName)); 
         ^
goof.c:25:26: warning: incompatible implicit declaration of built-in function ‘malloc’ 
goof.c:25:26: note: include ‘<stdlib.h>’ or provide a declaration of ‘malloc’ 
goof.c:28:14: warning: passing argument 1 of ‘assign_str’ from incompatible pointer type [-Wincompatible-pointer-types] 
    assign_str(bName, &ret->bookName); 
      ^
goof.c:14:6: note: expected ‘const char **’ but argument is of type ‘const char *’ 
void assign_str(const char** from, char** to) { 
    ^
goof.c:29:14: warning: passing argument 1 of ‘assign_str’ from incompatible pointer type [-Wincompatible-pointer-types] 
    assign_str(aF, &ret->author.firstName); 
      ^
goof.c:14:6: note: expected ‘const char **’ but argument is of type ‘const char *’ 
void assign_str(const char** from, char** to) { 
    ^
goof.c:30:14: warning: passing argument 1 of ‘assign_str’ from incompatible pointer type [-Wincompatible-pointer-types] 
    assign_str(aL, &ret->author.lastName); 
      ^
goof.c:14:6: note: expected ‘const char **’ but argument is of type ‘const char *’ 
void assign_str(const char** from, char** to) { 
    ^
goof.c: In function ‘display_book’: 
goof.c:34:3: warning: format not a string literal and no format arguments [-Wformat-security] 
    printf(entry->bookName); 
^
goof.c:35:10: warning: passing argument 1 of ‘printf’ makes pointer from integer without a cast [-Wint-conversion] 
    printf('\n'); 
     ^
In file included from goof.c:1:0: 
/usr/include/stdio.h:362:12: note: expected ‘const char * restrict’ but argument is of type ‘int’ 
extern int printf (const char *__restrict __format, ...); 
      ^
goof.c:35:3: warning: format not a string literal and no format arguments [-Wformat-security] 
    printf('\n'); 
^
goof.c:36:3: warning: format not a string literal and no format arguments [-Wformat-security] 
    printf(entry->author.firstName); 
^
goof.c:37:10: warning: passing argument 1 of ‘printf’ makes pointer from integer without a cast [-Wint-conversion] 
    printf(' '); 
     ^
In file included from goof.c:1:0: 
/usr/include/stdio.h:362:12: note: expected ‘const char * restrict’ but argument is of type ‘int’ 
extern int printf (const char *__restrict __format, ...); 
      ^
goof.c:37:3: warning: format not a string literal and no format arguments [-Wformat-security] 
    printf(' '); 
^
goof.c:38:3: warning: format not a string literal and no format arguments [-Wformat-security] 
    printf(entry->author.lastName); 
^
goof.c:39:10: warning: passing argument 1 of ‘printf’ makes pointer from integer without a cast [-Wint-conversion] 
    printf('\n'); 
     ^
In file included from goof.c:1:0: 
/usr/include/stdio.h:362:12: note: expected ‘const char * restrict’ but argument is of type ‘int’ 
extern int printf (const char *__restrict __format, ...); 
      ^
goof.c:39:3: warning: format not a string literal and no format arguments [-Wformat-security] 
    printf('\n'); 
^
goof.c: In function ‘main’: 
goof.c:45:14: warning: passing argument 1 of ‘assign_str’ from incompatible pointer type [-Wincompatible-pointer-types] 
    assign_str("Tom Sawyer", &book.bookName); 
      ^
goof.c:14:6: note: expected ‘const char **’ but argument is of type ‘char *’ 
void assign_str(const char** from, char** to) { 
    ^
goof.c:46:14: warning: passing argument 1 of ‘assign_str’ from incompatible pointer type [-Wincompatible-pointer-types] 
    assign_str("Mark", &book.author.firstName); 
      ^
goof.c:14:6: note: expected ‘const char **’ but argument is of type ‘char *’ 
void assign_str(const char** from, char** to) { 
    ^
goof.c:47:14: warning: passing argument 1 of ‘assign_str’ from incompatible pointer type [-Wincompatible-pointer-types] 
    assign_str("Twain", &book.author.lastName); 
      ^
goof.c:14:6: note: expected ‘const char **’ but argument is of type ‘char *’ 
void assign_str(const char** from, char** to) { 
    ^

и запустить код причины Баш сказать:

Segmentation fault (core dumped) 
+0

Добавьте одну важную inlcude: '#include '. Обязательно прочитайте документ для 'printf'. Он работает со строками формата, например. печать номера выполняется следующим образом: 'printf (" Значение:% d \ n ", val);'. Существуют форматы для исправления в строковых аргументах, одиночных символах, числах, ... –

+0

'int size = sizeof (from)/sizeof (char);' не будет делать так, как вы хотите, с аргументами функции. Первый 'sizeof' даст размер указателя, который является единственным, что функция знает о' from'. –

+5

Ваше использование 'printf' совершенно неверно, пожалуйста, RTM. –

ответ

5

Там в много ошибок там и не массив, только структур.

  • первых, необходимо включить библиотеку STDLIB (#include <stdlib.h>)
  • во-вторых, функция Printf не может быть использована, как это. Эта функция нуждается в строке, чтобы знать, как печатать данные ex: printf("an int: %d",myInt); или printf("a string: %s",myString);. Обратите внимание, что% d или% s указывают, куда помещать данные.
  • -третьих, я думаю, что вы хотите, это void assign_str(const char* from, char** to)