我正在学习如何在内存中表示数字。我想知道如何在一些int和float变量的内存中打印实际表示(二进制或十六进制)。
我希望看到这些数字在添加或减去时会发生什么情况会导致溢出,例如。
如何访问内存并进行打印?
答案 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");
}