[英]Difference between pointer address
我正在使用指针算法测试一些代码,但是我不明白我以什么格式得到大小。 我假设sizeof
给我以机器字为单位的大小(char == 1个机器字的大小),但是返回的指针地址之间的区别是什么?
我正在使用VS2008和x64 win7和x64编译器。
void test_pointer_delta()
{
int sum=0;
int n= 100000;
for(int i=0;i<n;++i)
{
char* p1= new char;
char* p2= new char;
sum += p2-p1;
}
double dp= (double)sum/n; //~64
int sz= sizeof(char);//1
int p_sz= sizeof(char*);//8
printf("diff: %f \n",dp);
}
什么是64? 64位? (那么x64系统上的字长是64位吗?)
编辑:我想使用此“技巧”来测试向量使用了多少内存,因为似乎不是释放所有内存(根据任务管理器剩余少量内存),这里是测试代码:
void test_containers()
{
int N=1000*1000;
int temp= 10;
clock_t t;
//for(int i=0;i<100;++i)
{
t= clock();
//vector
std::vector<int> vec;
for(int i=0;i<N;++i)
{
vec.push_back(temp);
}
t= clock()-t;
printf("vec: %d tics , %f sec \n",t, ((float)t)/CLOCKS_PER_SEC);
//clear vec
t= clock();
vec.clear(); //not frees memory of vector just makes size = 0
std::vector<int>(vec).swap(vec); //swap trick frees memory
t= clock()-t;
printf("vec clear: %d tics , %f sec \n",t, ((float)t)/CLOCKS_PER_SEC);
int c= vec.capacity();
int sz= vec.size();
}
}
//assume dp1 should be the same as dp2
char* p1 = new char;
char* p2 = new char;
int dp1= p2-p1;
test_containers();
char* p3= new char;
int dp2= p3-p2;
我认为,如果您尝试使用此代码,将会得到答案:
char s[10];
char *p1 = &s[0];
char *p2 = &s[1];
std::cout << p2 - p1;
减去两个指针的结果类型为: std :: ptrdiff_t 。 两个指针T *之差的单位是T个元素的数量。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.