#include<stdio.h>
typedef struct treelist
{
char data;
int left;
int right;
}tree,*leaf;
int main()
{
tree* creat(int N);
leaf x,y;
int N;
int M;
int i;
scanf("%d",&N);
x=creat(N);
M=8;
M=9;
for(i=0;i<N;i++)
{
printf("%d",x[i].data);
}
scanf("%d",&M);
y=creat(M);
}
tree* creat(int N)
{
tree a[10];
int i;
for(i=0;i<N;i++)
{
scanf("%c%d%d",&a[i].data,&a[i].left,&a[i].right);
}
return a;
}
以上是一段很有问题的代码,creat函数是为了建一棵静态的二叉树。但是在creat中,我所定义的tree[10]是一个自动的存储类。
C定义了5种存储类,分别是自动,寄存器,具有外部链接的静态,具有内部链接的静态,空连接的静态。如果稍微用心看下的话,不难区分:
自动和寄存器我觉得可以归为一类,因为就算人为地申请了寄存器类,编译器也会根据情况来分配以至于此变量成为一个普通的自动变量;
静态顾名思义就是不会随意改变的变量,是内部还是外部链接主要区别为程序外部文件是否可以调用(此处程序与文件的问题以后会有探讨);
比较有意思的是这个空链接的静态,他会用到一个关键字static,这个static在上述的静态的内部链接也会用,但其含义大相近庭(链接与存储时期)。而这个空链接的
静态便是作用于与存储时期的关系比较特殊,它与其他静态的区别是没有链接,与其他自动的区别是存储时期为静态。
说实话,因为没怎么碰到空链接的静态,导致问题出现时有些无措,也是费了一番事的,(本来觉得应该很容易就查出来,但是稍微有点小问题)
参考C Primer Plus