0

我怎样才能使以下工作?这个想法是让函数分配一个外部指针,这样我就可以在另一个程序中使用这个概念,但我不能这样做,因为 gcc 一直告诉我参数来自不兼容的指针类型......应该很简单,但我没有看到它。

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

int allocMyPtr(char *textToCopy, char **returnPtr) {
    char *ptr=NULL;
    int size=strlen(textToCopy)+1;
    int count;

    ptr=malloc(sizeof(char)*(size));
    if(NULL!=ptr) {
        for(count=0;count<size;count++) {
            ptr[count]=textToCopy[count];
        }
        *returnPtr = ptr;
        return 1;
    } else {
        return 0;
    }
}

int main(void) {
    char text[]="Hello World\n";
    char *string;

    if(allocMyPtr(text,string)) {
        strcpy(string,text);
        printf(string);
    } else {
        printf("out of memory\n");
        return EXIT_FAILURE;
   }
   free(string);
   return EXIT_SUCCESS;
}
4

3 回答 3

2

这几乎是正确的,但是由于您的函数需要指向指针的指针,因此您必须使用 address-of 运算符将指针的地址传递给函数:

allocMyPtr(text, &string)
于 2012-11-27T13:00:51.867 回答
1

改用&string与此输入参数相关的类型来解决您的问题,char **而不是char *

if(allocMyPtr(text,&string)) {

只是关于您的源代码的评论:

allocMyPtr()函数已经从文本复制到字符串。

所以为什么你用 strcpy 复制 agian。没用的

strcpy(string,text); // this useless
于 2012-11-27T13:01:34.707 回答
1

你正在传递你应该使用 的stringusing以便指针应该匹配,否则编译器会不断告诉你,pass by valueallocMyPtr()pass by adress

char *不兼容的类型char **

做这个 :

if(allocMyPtr(text,&string)) { }
于 2012-11-27T13:03:21.740 回答