我正在使用指针算法测试一些代码,但我不了解我得到的大小格式。
我假设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位?)
修改 我想用这个&#34;技巧&#34;测试vector使用了多少内存,因为它似乎没有释放所有内存(根据任务管理器的一些少量剩余) 这是测试代码:
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;
答案 0 :(得分:2)
我认为如果您尝试使用此代码,您将获得答案:
char s[10];
char *p1 = &s[0];
char *p2 = &s[1];
std::cout << p2 - p1;
答案 1 :(得分:1)
减去两个指针的结果类型是:std::ptrdiff_t。两个指针T *之差的单位是T元素的数量。