之前习惯于在主函数外面使用宏定义,但实际上主函数内也可使用,例:
#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<stdint.h>
#include<string.h>
#include<assert.h>
int main()
{
char g[9]={'9','8','7','2','1','5','6','3','4'};
#define min(x, y) ((x) < (y) ? (x) : (y))
char *const end_ptr=&g[8];
char *tmp_ptr=g;
char *tresh=min(end_ptr,tmp_ptr+12);
printf("%ld\n%ld\n",(intptr_t)(int *)(end_ptr),(intptr_t )(int *)(tmp_ptr+12));
printf("%c\n",*tresh);
return 0;
}
运行结果为
140730577384423
140730577384427
4
这段代码是找到两个指针中地址最小的那个并输出它所指向的元素,当然,tmp_ptr+12所指的位置早就超出char数组g的范围之外了。
那就改成不越界的:
#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<stdint.h>
#include<string.h>
#include<assert.h>
int main()
{
char g[9]={'9','8','7','2','1','5','6','3','4'};
#define min(x, y) ((x) < (y) ? (x) : (y))
char *const end_ptr=&g[8];
char *tmp_ptr=g;
char *tresh=min(end_ptr,tmp_ptr);
printf("%ld\n%ld\n",(intptr_t)(int *)(end_ptr),(intptr_t )(int *)(tmp_ptr));
printf("%c\n",*tresh);
return 0;
}
运行结果:
140737052257751
140737052257743
9
**注意:
printf("%ld\n%ld\n",(intptr_t)(int *)(end_ptr),(intptr_t )(int *)(tmp_ptr));
用于输出指针end_ptr和tmp_ptr的值,也就是地址;**