如何根据大小取消引用?

时间:2010-10-15 04:40:50

标签: c pointers dereference

我正在尝试打印地址指向的值,但问题是我需要根据传递给我的大小取消引用此指针。所以有类似的东西:

void print(Address addr, Int size) {
...
}

我对如何实现这一点感到有点困惑。有人能指出我正确的方向吗?

编辑: 好的,我在想:

char p[80];
memset(p, '\0', 80);
memcpy(p, addr, size);

然后解除引用为* p。如果有更好的方法或更正确的方式,请告诉我

3 个答案:

答案 0 :(得分:3)

你的问题很不清楚。如果您的意思是要从传递的地址转储任意二进制数据,则需要以下内容:

void print(const unsigned char *addr, size_t size)
{
    while (size--) printf("%.2x", *addr++);
}

或者,如果您的意思是要打印非空终止的字符数据,请尝试:

void print(const char *addr, int size)
{
    printf("%.*s", size, addr);
}

答案 1 :(得分:0)

如果它是一个数字,我认为它是,你需要这样的东西:

int n=0;
if (size>sizeof(int)) { return; //int is too small };
for (int i=0;i<size;i++) {
  ((char*)(&n))[sizeof(int)-(i+1)] = ((char*)addr)[size-(i+1)];
}
printf("%d",n);

答案 2 :(得分:0)

您可以在例程中使用switch语句:

switch (size) {
   case 1: print( *(char*)pointer); break;
   case 2: print( *(short*)pointer); break;
   case 4: print( *(long *)pointer); break;
   case 8: print( *(__int64*)pointer); break;
   default: puts( "unsupported);
}

(“print”是打印各种大小的整数的例程,可能使用C ++多态)

一个复杂的解决方案是使用C ++模板,例如使用参数类型Integer,它在调用时由实际变量类型替换。然后,此例程可以根据此Integer变量的大小(如果您自己实现更长的整数,则可以在1到8之间变化,或更多)。这种方法的缺点是编译器为每种类型的参数生成例程实例,并且依赖于大小的逻辑将导致某些测试的“始终为真”条件。一个简单的方法是始终使用您期望的最长类型的整数。