1.假如在一个函数中有一下代码()
void fun()
{
int * p = (int*)malloc(sizeof(int));
int * q = p;
}
A. p指向的空间在堆上,q指向的空间在栈上
B. p指向的空间在栈上,q指向的空间在堆上
C. p指向的空间在堆上,q指向的空间在堆上
D. p指向的空间在栈上,q指向的空间在栈上
答案:D
解析:因为p指向的空间是由malloc开辟出来的,而我们又知道malloc函数是在堆上开辟的空间,所以p指向的空间在堆上,A. p指向的空间在堆上,而q和p指向了同一块儿空间,所以q指向的空间也在堆上.
2.给出下列程序的输出结果()
char *p = "helloworld";
char q[ ] = "helloworld";
printf("%d %d %d %d",sizeof(p),strlen(p),sizeof(q),strlen(q));
A 4 10 4 10 B 4 10 10 10 C 4 11 10 10 D 4 10 11 10
答案:D
解析: 首先p是一个指针,在32位下指针是4个字节,所以sizeof(p)是4,strlen求的是字符串的有效长度,所以两个都是10,求sizeof(q)就求的是