指针的加减法计算
#include<stdio.h>
int?main()
{
int?arr[10]={1,2,3,4,5,6};
int?*p?=?arr;
p++;
printf("%d?%d\n",arr[0],arr[1]);
return?0;
}
?
(2)?指針加數字:指針加法需要調整,調整的權重為指針去掉一個*號,求sizeof。
例:#include<stdio.h>
int?main()
{
int?*p?=?(int*)1000;
printf("%d\n",(char??***)p+2);//1008
printf("%d\n",(short?*)p+2);//1004
printf("%d\n",(double?**)p+2);//1008
printf("%d\n",(unsigned?long?*)p+2);//1008
printf("%d\n",(char??*)p+2);//1002
printf("%d\n",(unsigned?long?long?)p+2);//1002//這里的unsigned?long?long是指強轉指針的類型
return?0;
}?
(3)指針+指針 ?(非法,無意義)
(4)指針-數字:需要調整,調整的權重位sizeof指針去掉一個*
注:和指針+數字算法相同
#include<stdio.h>
int main()
{
int *p = (int *)0x2010;//注意是十六進制
printf("%x\n",p-2);//2008
printf("%x\n",(float *)p-2);//2008
printf("%x\n",(double *)p-2);//2000
printf("%x\n",(short *)p-2);//200c
printf("%x\n",(unsigned long *)p-2);//2008
printf("%x\n",(long *)p-2);//2008
printf("%x\n",(long long)p-2);//200e
printf("%x\n",(char *)p-2);//200e
return 0;
}
(5)指針-指針:間隔的單元個數,需要調整,調整的權重位sizeof(指針去掉一個*)
注:指針-指針的計算:1、計算間隔的字節數,2、除以權重
#include<stdio.h>
int main()
{
int arr[10] = {0};
int *p = &arr[1];//x+4
int *q = &arr[7];//x+28
printf("%d\n",p-q);//-6
printf("%d\n",q-p);//6
printf("%d\n",(short *)q-(short *)p);//12
printf("%d\n",(long long*)q-(long long *)p);//3
printf("%d\n",(double *)q-(double *)p);//3
printf("%d\n",(unsigned long)q-(unsigned long)p);//24
printf("%d\n",(char **)q-(char **)p);//6
return 0;
}
總結
- 上一篇: mysql 几级缓存_Mysql中一级缓
- 下一篇: BugkuCTF-Crypto题affi