【问题标题】:stackInit function is seg faulting and I'm not understanding whystackInit 函数出现段错误,我不明白为什么
【发布时间】:2023-03-28 22:49:02
【问题描述】:

我不熟悉使用结构和我们当前的分配,我们必须在字符串中读取

例如:“{{asdfd}}()()()(((())))”

每次我们看到一个 "{,[, (,

我知道我们必须在结构中至少包含三个变量(元素、堆栈大小、堆栈顶部)。

当我在 GDB 中运行我的程序时,它会在第一个“init”函数中出现段错误。我已经坚持了一段时间。有人可以向我解释我做错了什么。

谢谢!

编辑:让我知道是否还有其他需要发布的内容。再次感谢!

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

typedef struct dynArrStruct
{
    char *location;
    int length;
    int currSize;
}dynArr;

int checkFlag(int, char**); //checks for the -d flag
void init(struct dynArrStruct*, int);
void push(struct dynArrStruct*, char);
void printAll(struct dynArrStruct*);

int main(int argc, char** argv)
{
    int testFlag, i, size = 0;
    char line[300];
    dynArr* a1;

    printf("Enter a string to be checked: ");
    scanf("%s", line);

    init(a1, strlen(line));

    if(argc > 1)
        testFlag = checkFlag(argc, argv);

    for(i = 0; i < strlen(line); i++)
        if(line[i] == '(' || line[i] == '{' || line[i] == '[' || line[i] == '<')
        {
            size += 2;
            init(a1, size);
            //rest of code here
        }
     // stuff
}

void init(dynArr* a, int size)
{
    a->location = (char *)malloc(sizeof(char) * (size_t)(size));  //SEGFAULT
    a->length = size;
    a->currSize = 0;
}

【问题讨论】:

  • Please don't cast the return value of malloc() in C。此外,sizeof (char) 毫无意义;它永远是 1。
  • @unwind 我不太同意 sizeof(char) 毫无意义。即使它始终为 0,它也更容易看出您指的是 char 的大小而不是文字 1。

标签: c data-structures struct stack dynamic-arrays


【解决方案1】:

您没有为dynArr 分配内存。在堆上分配内存:

dynArr* a1 = malloc(sizeof(dynArr));

或者在堆栈上分配它并使用地址运算符将其作为指针传递给init函数:

dynArr a1;

/* ... */

init(&a1, strlen(line));

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-01-26
    • 1970-01-01
    • 2021-11-13
    • 2016-05-20
    相关资源
    最近更新 更多