0

Can someone tell me what's wrong with my code? I've looked extensively at the error messages VS gives me, but I'm at a loss. I've attaches error messages for more info.

//Inclusion of necessary header files
#include <stdio.h>
#include <string.h>

//String Removal function prototype
char str_check(char *, char *);
void str_remove(char*, char*);
int isPrefix(char* list1, char* list2);
//Entry point for header files, pre-processor directives, and function prototypes
int main()
{
    //Necessary variable declarations
    char list1[500];
    char list2[20];

    //Input prompt and input function for first string
    printf("Please enter a string of up to 500 characters for first array.\n");
    *list1 = getchar();

    //Input prompt and input function for second string
    printf("Please enter a string of up to 20 characters for second array.\n");
    *list2 = getchar();

    //String Removal function call assigns function output to a third array and uses string function to display output
    *list1 = str_check(list1, list2);
    puts(list1);

    //Exit sequence
    return 0;
}

//String check function definition
char str_check(char* list1, char* list2)
{
    //Temporary character pointer declarations and for loop control variables
    char *ptr1=list1, *ptr2=list2;
    int i, j, k;

    //Loop checks both array elements for concurrent characters using isPrefix function, checks for concurrent string segments if one is found, call string removal function
    for (i = 0; i < strlen(list1); i++)
    {
        if (isPrefix(ptr1+i, ptr2)==1)
        {
            str_remove(ptr1+i, ptr2);
        }

    }

    return;
}

//isPrefix function definition checks for string occurences
int isPrefix_1 (char* ptr1, char* ptr2){

    int i=0;

    while(*(ptr1 + i) != '\0')
    {
        if(*(ptr1 + i) != *(ptr2 + i))
        {
            return 0;
        }
        i++;
    }

    return 1; 
}


void str_remove(char* ptr1, char* ptr2)
{
    int offset = strlen(ptr2);
    int i=0;
    for(i=0;i<(strlen(ptr1)-strlen(ptr2));i++)
    {
        *(ptr1+i) = *(ptr1+i+offset);
    }
    *(ptr1+i+offset) ='\0';
}

ERROR MESSAGES:
: warning C4018: '<' : signed/unsigned mismatch
: warning C4033: 'str_check' must return a value
: warning C4101: 'k' : unreferenced local variable
: warning C4101: 'j' : unreferenced local variable
: warning C4018: '<' : signed/unsigned mismatch
: warning C4716: 'str_check' : must return a value
: fatal error LNK1120: 1 unresolved externals
4

1 回答 1

1
  1. 警告 C4018:“<”:有符号/无符号不匹配

我不知道这个警告到底在哪一行,但我认为它在这里:

for (i = 0; i < strlen(list1); i++)

strlen返回一个size_t变量,它是一个unsigned int. 您将其与有符号变量进行比较,这可能会给您带来一些麻烦。例如,考虑以下声明:

int a = -1;
unsigned int b = 100;

比较a < b将是错误的。这是因为 a 被强制转换为无符号并且由于负数的表示方式(通常是二进制补码)。但是,在您的情况下,这不是问题。为避免收到警告,请声明iunsigned int.

  1. 警告 C4033:“str_check”必须返回一个值

的声明str_check是:

char str_check(char* list1, char* list2);

但是,您不会char在此函数的定义中返回任何内容。要么你应该声明它void str_check(char* list1, char* list2);,要么你应该从它返回一些值。

  1. 警告 C4101:“k”:未引用的局部变量

这很简单:您已经声明了一个变量k并且您没有使用它。


其余部分与上述重复(最后一个除外)。除了第二个警告可能会导致您出现一些意外行为外,程序应该可以完美运行。

最后一个错误是你的问题。我将尝试为您提供有关错误含义的一些背景知识以及一些希望对您有所帮助的参考资料。

你有一个源代码。为了从中创建可执行文件,必须采取一些步骤:

  1. 预处理。

在此步骤中分析预处理器指令。在您的情况下,您使用该指令包含一些文件。#include当预处理器遇到这个指令时,它只是将该文件的内容复制到您的文件中。

  1. 汇编。

此步骤为您的程序(CPU 可以理解的代码)生成实际的目标代码。但是,有一些函数,例如getchar,您没有提供任何定义。它们已经在库中编译。

  1. 链接。

链接器的工作是将您在最后一步中生成的目标代码与所需的库链接,以便可以调用您使用的所有函数。此步骤会产生您的错误。它基本上说它找不到对某物的引用。在这里,您将找到有关此错误的一些文档:

“1个未解决的外部” C++ http://support.microsoft.com/kb/815650 http://www.dreamincode.net/forums/topic/22701-fatal-error-lnk1120-1-unresolved-externals/

于 2014-11-09T01:14:10.883 回答