寻址和字节顺序

当我们遇到跨多字节的程序对象时,这时候就需要判定清楚两个问题,一个是对象的地址,另外一个是存储器的字节排列情况。

int x=0x1234567,位于地址0x100处:

字节的排列不同的机器有着大端和小端之分,在不同类型的机器之间通过网络传送二进制数据时,接收程序字里的字节可能会出现反序排列,这时,网络应用程序的代码必须得遵守一定的字节顺序规则。

下面是一段字节表示的示例:

#include <stdio.h>

typedef unsigned char *byte_pointer;

void show_bytes(byte_pointer start,int len){

              int i;
              for(i=0;i<len;i++)
                 printf("%.2x",start[i]);
              printf("\n");
    }

void show_int(int x){
              show_bytes((byte_pointer)&x,sizeof(int));

   }



void show_pointer(void *x){
              show_bytes((byte_pointer)&x,sizeof(void *));

   }

void test_show_bytes(int val){
        int ival=val;
        int *pval=&ival;
        show_int(ival);
        show_pointer(pval);
  }
int main(){
      //test_show_bytes(12345);
      printf("\n");
      test_show_bytes(0x00003039);
      printf("\n");
      test_show_bytes(0x87654321);
  }

运行结果:

$ ./show-bytes

39300000
a43aecfeff7f0000

21436587
a43aecfeff7f0000

运行机器是在Linux 64上,最低有效字节值先输出,这说明是小端法机器。值得注意的是Linux 64不同于Linux 32的4字节地址,它是8字节地址,所以是8字节的输出。

这时候问题来了,为何不同的整型输入,得到的却是相同的指针地址。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值