指针的概念:
1.指针就是个变量,用来存放地址,地址唯一标识一块内存空间。
2指针的大小是固定的4/8个字节(32位平台/64位平台)。
3.指针是有类型,指针的类型决定了指针的+-整数的步长,指针解引用操作的时候的权限。
4.指针的运算。
例1(字符串实质上就是一个地址)
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
int main()
{
char arr[] = "abcdef";
char* p = arr;
printf("%s\n", p); //p代表指针变量,存储了arr 数组名arr首元素地址
printf("%s", arr); //字符串打印本来就是地址(字符串实质上就是一个地址),p也是地址.所以不需要解引用
}
例2 li常量字符串在指针中的存储
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
int main()
{
const char* p = "abcdef";
//"abcdef"是一个常量字符串 加上const 表示常量字符串不能被修改 const修饰*p
//修改例:*p='W'
printf("%c\n", *p); // *p表示单个字符
printf("%s", p); // 表示输出字符串
}
注意:代码char* pstr = "hel1o bit.";特别容易让同学以为是把字符串hello bit放到字符指针pstr里了,但是/本质是把字符串he11o bit.首字符的地址放到了pstr中。
例3:字符指针的应用
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
int main()
{
char arr1[] = "abcdef";
char arr2[] = "abcdef";
const char* p1 = "abcdef";
const char* p2 = "abcdef";
/* if (arr1 == arr2) //这里的arr1 和arr2 代表的是不同数组的首地址
{
printf("hehe\n"); //
else
printf("haha\n"); // 所以输出的是haha
}*/
if (p1 == p2)
//这里的p1 p2 表示的都是指针变量 并且赋的都是常量字符串
//常量字符串不能被改变于是系统为了节约空间就打印了一个空间
//所以p1、p2指针变量指向的是首地址的地址所以是一样的
{
printf("hehe\n"); // 所以输出的是hehe
}
else
printf("haha\n"); //
}
解释:
数组存放在栈区,不管保存的数组内容是否相同,声明arr1和arr2时开辟的的是两个独立的空间,所以两个数组地址是不同的。
字符串存放在常量区,地址系统为了节约空间就只保存一份,两个指针变量指向的是同一个地址,所以相等。