如何在c中打印内存位

时间:2016-02-12 14:15:58

标签: c memory bits

我正在学习如何在内存中表示数字。我想知道如何在一些int和float变量的内存中打印实际表示(二进制或十六进制)。

我希望看到这些数字在添加或减去时会发生什么情况会导致溢出,例如。

如何访问内存并进行打印?

6 个答案:

答案 0 :(得分:6)

您需要将指向相关变量的指针分配给char *,并将其视为长度为sizeof(variable)的字节数组。然后,您可以使用%X格式说明符将每个字节以十六进制打印到printf。

您可以定义如下函数:

void print_bytes(void *ptr, int size) 
{
    unsigned char *p = ptr;
    int i;
    for (i=0; i<size; i++) {
        printf("%02hhX ", p[i]);
    }
    printf("\n");
}

并称之为:

int x = 123456;
double y = 3.14;
print_bytes(&x, sizeof(x));
print_bytes(&y, sizeof(y));

答案 1 :(得分:2)

  

...打印实际表示(二进制......

任何变量/对象转换为编码二进制形式的字符串使用辅助函数将内存转换为“二进制”字符串。此方法还处理函数指针。使用C99或更高版本。

#include <stdio.h>
#include <assert.h>
#include <limits.h>

//                                    .... compound literal .......
#define VAR_TO_STR_BIN(x) obj_to_bin((char [sizeof(x)*CHAR_BIT + 1]){""}, &(x), sizeof (x))

char *obj_to_bin(char *dest, void *object, size_t osize) {
  const unsigned char *p = (const unsigned char *) object;
  p += osize;
  char *s = dest;
  while (osize-- > 0) {
    p--;
    unsigned i = CHAR_BIT;
    while (i-- > 0) {
      *s++ = ((*p >> i) & 1) + '0';
    }
  }
  *s = '\0';
  return dest;
}

int main(void) {
  int i = 42;
  double d = 3.1415926535897932384626433832795;
  printf("Sample\ndouble pi:%s\nint 42:%s\n", VAR_TO_STR_BIN(d), VAR_TO_STR_BIN(i) );
  return 0;
}

输出(注意:取决于字节顺序,结果可能会有所不同)

Sample
double pi:0100000000001001001000011111101101010100010001000010110100011000  
int 42:00000000000000000000000000101010

这种方法很容易适应十六进制形式。

答案 2 :(得分:1)

假设你有一个名为memory的int变量。确保你看到它有多少位;对于许多处理器,int是32位以及存储器地址。所以你需要遍历每一位,如下所示:

unsigned int memory = 1234;
for (int i = 0; i < 32; i++)
{
  printf("%d ", memory >> i & 1);
}

这个简单的方法将每个位与1进行或运算,并将每个位移1。

答案 3 :(得分:1)

#include <stdio.h>
#include <stdlib.h>

void print_bits ( void* buf, size_t size_in_bytes )
{
    char* ptr = (char*)buf;

    for (size_t i = 0; i < size_in_bytes; i++) {
        for (short j = 7; j >= 0; j--) {
            printf("%d", (ptr[i] >> j) & 1);
        }
        printf(" ");
    }
    printf("\n");
}

int main ( void )
{
    size_t n;
    scanf("%d", &n);
    print_bits(&n, sizeof(n));
    return 0;
}

这将使用指定的大小(以字节为单位)打印指定对象(此处为n)的位。

答案 4 :(得分:1)

致电print_bits(memory address of variable, size of variable in byte)

void print_bits(void *ptr, int size) //ptr = memory address of variable, size = size of variable in byte
{
    long long *ch = ptr;
    int size_bits = size * 8;
    for(int i = size_bits-1; i>=0; i--){
        printf("%lld", *ch >> i & 1) ;
    }
}

已成功测试,可以使用小于或等于64位的任何变量。这可能会与其他大小的变量(未测试)一起正常工作。

通话:

double d = -7.92282286274e+28;
print_bits(&d, sizeof(d));

输出:

1100010111110000000000000000000011100000000000000000000100010111

答案 5 :(得分:0)

@ dbush,@ Anton,我把你的代码混在一起。没关系?

#include <stdio.h>
#include <stdlib.h>

void print_bytes( void *ptr, size_t size ) ;

int main( void )
{
    int x = 123456 ;
    double y = 3.14 ;

    print_bytes( &x, sizeof(x) ) ;
    print_bytes( &y, sizeof(y) ) ;

    return 0 ;
}

void print_bytes( void *ptr, size_t size )
{
    //char *buf = (char*) ptr;
    unsigned char *p = ptr ;

    for( size_t i = 0; i < size; i++ )
    {
        printf( "%02hhX ", p[i] ) ;
    }
    printf( "\n" ) ;

    for( size_t i = 0; i < size; i++ )
    {
        for( short j = 7; j >= 0; j-- )
        {
            printf( "%d", ( p[i] >> j ) & 1 ) ;
        }
        printf(" ");
    }
    printf("\n");
}