1、指针 +- 整数
2、指针 - 指针(指针 + 指针没有意义,类似于日期+日期)
3、指针的关系运算
实例1:
实例2:
int main()
{
int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
int* pStart = arr;
int* pEnd = arr + 9;
while (pStart <= pEnd)
{
printf("%d ", *pStart);
pStart++;
}
printf("\n");
return 0;
}
实例3(指针-指针):
前提:两个指针指向同一块内存空间,得到的是两个指针之间元素的个数。
int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
printf("%d \n", &arr[9] - &arr[0]); // 9
//char c[5];
//printf("%d \n", &arr[9] - &c[0]); //err
实例3(指针-指针应用):求字符串的长度
计数器实现
//int my_strlen(char* str)
//{
// int count = 0;
// while (*str != '\0') // 字符串以 '\0' 为结束标志
// {
// count++;
// str++;
// }
// return count;
//}
int my_strlen(char* str)
{
char* start = str;
while (*str != '\0') // 字符串以 '\0' 为结束标志
{
str++;
}
return str - start;
}
int main()
{
int len = my_strlen("wakatipu"); //传递的是该字符串的首元素的地址
printf("%d\n", len);
return 0;
}
实例4(指针的关系运算):
注意:对于绝大部分的编译器 ,②的写法可顺利完成任务,但要避免这样写,因为标准并不保证其可行。
标准规定:
允许指向数组元素的指针与指向数组最后一个元素后面的那个内存位置的指针比较,但不允许与指向第一个元素之前的那个内存位置的指针进行比较。