1、下面的代码输出的结果是什么,并简单分析结果。
#include <stdio.h>
//无符号数与有符号数相加
int main(int argc, char **argv)
{
unsigned int a = 6;
int b = -12;
if(a+b > 0)
{
printf("dsds\n");
printf("a+b=%d\n" , a+b);
printf("a+b=%p\n" , (void *)(a+b));
}
else
{
printf("ssss\n");
printf("a+b=%d\n" , a+b);
printf("a+b=%p\n" , (void *)(a+b));
}
return 0;
}
答案:dsds
a+b=-6
a+b=0xFFFFFFFA
原因:当无符号数与有符号数相加时,将相加后的结果转化为无符号数,为什么第一个结果是-6呢,因为%d输出的时候是按照有符号数输出的。第二个输出语句就是按照内存里的内容输出的。为什么是0xFFFFFFFA,-6的补码就是0xFFFFFFFA,计算机在内存中存储数据的格式是补码的格式,所以打印出来的结果就是一个大于0的数。这就充分说明了a+b>0了。
2、下面的函数有什么错误:
int square(volatile int *ptr)
{
return *ptr * *ptr;
}
编译器将产生类似下面的代码:
int square(volatile int *ptr)
{
int a,b;
a = *ptr;
b = *ptr;
return a * b;
}
答案:由于*ptr的值可能被意想不到的改变,因此a和b可能是不同的。结果,这段代码可能返不是你所期望的平方值!正确的代码如下:
long square(volatile int *ptr)
{
int a;
a =*ptr;
return a * a;
}
3、malloc(0)你注意过吗?下面分析这段代码:
#include<stdio.h>
#include<stdlib.h>
//malloc(0)函数 返回值不空
int main(int argc, char **argv)
{
char *pointer;
if((pointer = (char *)malloc(0)) == NULL)
{
printf("is null pointer\n");
printf("pointer:%p\n",pointer);
*pointer = 'a';
printf("%c\n",*pointer);
free(pointer);
}
else
{
printf("is valited pointer\n");
printf("pointer:%p\n",pointer);
*pointer = 'b';
printf("%c\n",*pointer);
free(pointer);
}
return 0;
}
malloc(0)返回堆上的任意一个字节的地址,并且返回的地址空间可以对其进行操作。
运行结果:
is valited pointer
pointer:0x7f23adff
b
4、Typedef 在C语言中频繁用以声明一个已经存在的数据类型的同义字。也可以用预处理器做类似的事。例如,思考一下下面的例子,那个更好,为什么?
#define dPS struct s *
typedef struct s * tPS;
答案是:typedef更好。思考下面的例子:
dPS p1,p2;
tPS p3,p4;
第一个扩展为
struct s * p1, p2;
上面的代码定义p1为一个指向结构的指,p2为一个实际的结构,这也许不是你想
要的。第二个例子正确地定义了p3 和p4 两个指针。
5、C语言同意一些令人震惊的结构,下面的结构是合法的吗,如果是它做些什么?
int a = 5, b = 7, c;
c = a+++b;
上面的代码被处理成:
c = (a++) + b;
因此, 这段代码执行后的结果是 : a = 6, b = 7, c = 12。