引言
本文针对于碰到的指针做一些记录。详见下面的示例。
示例一
返回char类型指针,使用局部静态数组。
#include <stdlib.h>char * GetTestMemory(void)
{static char p[] = "hello world";printf("src=%x\n",p);//数组首地址printf("Move=%x\n", p+1);//数组的首地址+1printf("ArrMove=%x\n", &p + 1);//整个数组的地址+1printf("==src=>%s\n", p);//数组p中的字符串printf("==src=>%s\n", p+1);//数组p+1后的字符串printf("==========================\n");printf("p[0] = %c\n",p[0]);//第一个字符printf("*p = %c\n", *p);//第一个字符return p;
}
void Test(void)
{char *str = GetTestMemory(); printf("===>str= %s\n",str);
}
int main()
{Test();return 0;
}
输出结果:
示例二
返回char类型的指针,使用局部数组。
char * GetTestMemory(void)
{char p[] = "hello world";printf("src=%x\n",p);//数组首地址printf("Move=%x\n", p+1);//数组的首地址+1printf("ArrMove=%x\n", &p + 1);//整个数组的地址+1printf("==src=>%s\n", p);//数组p中的字符串printf("==src=>%s\n", p+1);//数组p+1后的字符串printf("==========================\n");printf("p[0] = %c\n",p[0]);printf("*p = %c\n", *p);return p;
}
void Test(void)
{char *str = GetTestMemory(); printf("===>str= %s\n",str);
}
int main()
{Test();return 0;
}
运行结果:
可以看出此时str输出的字符串为一串乱码。由于局部变量作为数组,其存储在栈区,返回数组的首地址p后赋值给char*指针str,局部变量在函数GetTestMemory()调用结束后生命周期结束,系统释放内存,此时str指针指向的内容(数组p的内存,已被释放)具有不确定性,故而输出乱码。
示例三
下面为一个常用但是很容易忽略的问题。在使用文件指针的时候,我们都记得需要打开,读写,关闭,但是关闭文件在调用fclose(FILE *)后就结束了嘛,没有,因为fclose()虽然关闭了文件句柄,但是文件句柄为一个指针,需要赋值为NULL,这里使用的是c语言,故而采用NULL。
FILE *fp = fopen(......);
if(fp != NULL)
{........fclose(fp);fp = NULL;//这里需要将fp赋空
}
16进制加减法参考链接:
https://blog.csdn.net/weixin_42108484/article/details/101380530