1

所以我有这段代码

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "hw09-header.h"

struct student
{
    char* name;
    char* course;
};

int main(int argc, char* argv[])
{
    int i = 0, init_size=10,x,z;
    char *value = "go";
    int key, count=0;
    char* del = ","; /*Uses comma sign as delimiter*/
    char *token=NULL;
    char *temp_stor;
    struct student *array;
    struct student *temp;

    if(argc != 2)
    {
        printf("  usage:  program_name positive_integern");
        printf("example:  ./example-hw09  123n");
        exit(1);
    }

    /**************  begin REQUIRED  **************/
    /*  put before logic.  DO NOT PUT IN A LOOP */
    key = atoi(argv[1]);
    initialize(key);
    /**************   end REQUIRED   **************/

    /*  example loop  */

    array=malloc((init_size)*sizeof(int));

    while(strcmp(value, "stop") != 0)
    {
        value = getString();
        token = strtok(value, del);
        while (token !=NULL)
        {
            if(i%4==0)
            {
                init_size=init_size*2;
                temp = realloc(array,init_size*sizeof(int)) ;
                if(temp != NULL)
                {
                    array = temp;
                }
                else
                {
                    printf("unable to reallocaten");
                    exit(1);
                }
            }

            array[i].name=malloc(sizeof(struct student)*10);
            strcpy(array[i].name,token);
            printf("%s %dn",array[i].name,i);
            token = strtok( NULL, del );
            array[i].course=malloc(sizeof(struct student)*11);
            strcpy(array[i].course,token);
            printf("%s n",array[i].course);
            i=i+1;
            token = strtok( NULL, del );
            x=i;
            for(x=0; x<i; x++)
            {
                if(strcmp(array[x].name,token)==0)
                    printf("Duplicate found n");
            }
        }
    }
}

现在,当我尝试执行 strcmp 时,它总是给我一个分段错误,我不知道为什么。

我不应该在这里使用链表,而且我想我已经完成了所有的工作,接下来的几部分我只需要比较和排序,我不断收到分段错误。

而且我的数组中确实有元素,我可以将它们全部打印出来,只是出于某种原因不比较它们。

4

2 回答 2

2

部分回答,指出没有意义的事情。您应该尝试了解原因,以便修复它们。但 SO 不是解释类似malloc工作原理的正确网站。


    array[i].name=malloc(sizeof(struct student)*10);
    strcpy(array[i].name,token);

您为 10 个结构分配空间student,然后将字符串复制到其中。这是没有意义的。既然namechar*你应该有malloc(<maximum size of string with terminating 0 included>)


    array=malloc((init_size)*sizeof(int));

然后稍后

    array[i].name= .....

您分配array为整数数组(由 表示sizeof(int)),但随后您将其用作结构,就像它们是结构一样。


然后建议:每次你有strcpy(dst, src),用这个替换它:

snprintf(dst, <how much space is allocated at dst>, "%s", src);

这将避免缓冲区溢出,并且还会迫使您考虑分配了多少空间dst(如果您不知道,那么您的第一个问题需要解决和理解)。

于 2013-04-17T06:23:27.240 回答
1

因为,很明显(你也说过)令牌为空。

if(strcmp(array[x].name,token)==0)

传递NULL参数是非法的strcmp
如果使用 NULL 作为参数调用字符串比较函数,则该进程将获得 SIGSEGV,
因为这些函数正在取消引用 NULL 指针。

于 2013-04-17T06:31:09.823 回答