前言
这次朋友写代码时遇到解决不了的问题。让我帮忙看看。我觉得这个问题还挺好的,所以写下来记录一下,也算是给自己做一个笔记。
异常
- 引发了未经处理的异常:写入访问权限冲突。
- The variable ‘S’ is being used without being initialized.(使用了没有初始化的变量‘S’)
其中引发第一个问题的大部分情况可能是数组越界。遇到这个问题首先可以查看自己的代码是否有数组下标越界的情况出现。
出问题的代码:
int main()
{
stack* S;
S->top = 0; //报错处
char a[] = "{{{{}}}}" ;
if (Parentheses(S, a, 9))
printf("ok");
else
printf("no");
return 0;
}
stack是自己定义的一个结构体,用来模拟栈。
错误分析 : 这里定义了一个指向一个栈的指针S,然后给S指向的栈 的top赋0 。 问题是这里有了一个指向stack的指针。但是并没有实际指向一个结构体stack。
我们假设结构体是这样的。 那么我们创建一个结构体。就需要一部分内存来保存数组p和top部分。但是我们定义一个stack *类型的S变量时,此时S里存放的应该是一个结构体的地址。但是我们的代码并没有实际存在这么一个结构体的地址。所以当我们去访问S指向的地址时,就会出现这样的错误。
值得一提的是,这样模拟 栈 的结构体,定义的并不是很好我认为定义{ 栈顶指针 栈底指针 容量} 这样的方式会更方便理解一些。 但是为了方便讲解错误我就借用了这个代码。
解决方法
当我们使用指针来初始化这样的结构体,记得使用malloc函数为结构体分配内存。 修改后的代码:
int main()
{
stack* S=(stack *)malloc(sizeof(stack)); //动态分配内存
S->top = 0;
char a[] = "{{{{}}}}" ;
if (Parentheses(S, a, 9))
printf("ok");
else
printf("no");
return 0;
}