指针加减的例题代码:
#include<stdio.h>
int main(void)
{
int a[5] = {1,2,3,4,5} ;
int *ptr = (int *)(&a+1) ;
printf("%d\n",*(a+1)) ;
printf("%d\n",*(ptr-1)) ;
return 0 ;
}
解析:
这里主要是关于指针加减操作的理解。对指针进行加1操作,得到的是下一个元素的地址,而不是原有地址值直接加1,所以,一个类型为t的指针的移动,以sizeof(t)为移动单位。
(1)代码第5行,声明一个一维数组,并且a有5个元素。
(2)代码第6行,ptr是一个int型指针&a+1,即取a的地址,该地址的值加sizeof(a)的值,即&a+5*sizeof(int),也就是 a[5]的地址,显然当前指针已经超越了数组的界限。(int*)(&a+1)则是把上一步计算出来的地址,强制转换为int* 类型,赋值给ptr。
(3)代码第8行,a与&a的地址是一样的,但意思不一样,a是数组首地址,也就是a[0]的地址;&a是对象(数组)首 地址,a+1是数组下一元素的地址,即a[1];而&a+1是下一个对象的地址,即a[5]。因此这里输出为2.
(4)代码第9行,因为ptr指向a[5],并且ptr是int*类型,所以*(ptr-1)指向a[4],输出5。
指针的比较代码:
#include<iostream>
using namespace std ;
int main(void)
{
char str1[] = "abc" ;
char str2[] = "abc" ;
const char str3[] = "abc" ;
const char str4[] = "abc" ;
const char* str5 = "abc" ;
const char* str6 = "abc" ;
char * str7 = "abc" ;
char * str8 = "abc" ;
cout<<(str1 == str2)<<endl ;
cout<<(str3 == str4)<<endl ;
cout<<(str5 == str6)<<endl ;
cout<<(str6 == str7)<<endl ;
cout<<(str7 == str8)<<endl ;
return 0 ;
}
数组str1,str2,str3和str4都是在栈中分配的,内存中的内容都为“abc”加一个“\0”,但是它们的位置是不同的。因此代码第15行和第16行的输出都是0 ;
指针str5,str6,str7和str8也是在栈中分配,它们都指向“abc”字符串,注意“abc”存放在数据区,所以str5,str6,str7和str8其实指向同一块数据区的内存。因此第17,18和19行的输出是1。