一、加减运算
指针的加法(减法)运算,实际上加(减)的是一个单位,单位的大小即:sizeof(p[0])
。
int *p与char *p的p+1是不同的。
p+n:地址
p[n]:访问的是内容,取出标签中的内容值
p[n] = *(p+n) // [] 和 * 都可以取出指针中的内容值
p++/p--:把p改变了。
1、加减法就是让内存向上偏移或向下偏移的方式。
例1:
// 001.c
#include <stdio.h>
int main()
{
int a = 0x12345678;
int b = 0x99991199;
int *p1 = &b;
char *p2 = (char *)&b;
printf("p1+1 is %x, p1[1] is %x, *p1+1 is %x\n", *(p1+1), p1[1], *p1+1);
printf("p2+1 is %x\n", p2[1]);
}
2、越界访问
从语法角度,C语言对越界访问是允许的。因为C语言是标签化,至于访问哪里,C语言是不管的。
定义指针时,还必须定义大小,否则可以任意访问。有可能会导致内存泄漏。
例2:
// 002.c
#include <stdio.h>
int main()
{
int a = 0x12345678;
int *p1 = &a;
printf("p1[100] is %x\n", p1[100]);
}
越界访问:p1[100]越界了例3:
// 003.c
#include <stdio.h>
int main()
{
const int a = 0x12345678;
int b = 0x11223344;
a = 100;
printf("a is %x\n", a);
}
const定义常量,不能直接对其赋值
例4:
// 004.c
#include <stdio.h>
int main()
{
const int a = 0x12345678;
int b = 0x11223344;
int *p = &b;
*(p+1) = 0x100; // p+1:a的地址
printf("a is %x\n", a);
}
虽然a用const修饰,无法直接修改值;但通过越界,将a的值修改了
const只是建议,不是强制。只是编译时不会变,运行时如果通过越界访问,也可以改变。
二、逻辑运算
==、!=
-
跟一个特殊值进行比较:0x0(NULL),它表示地址的无效值,是结束标志。
if (p == 0x0) // p处理完了,没有有效的东西处理了。
-
指针必须是同类型的才能进行比较:
int *和char *不能进行比较。
网友评论