一.背景

1.1 mips32搭载32bit vxworks操作系统

1.2 x86搭载64bit windows10操作系统

二.大小端模式判定前的准备

2.1 先要知道各种架构上各种整型数占据的bit数,也就是通过范围来确定bit数

上一篇已经讲过,特奉上地址如下:

http://www.cnblogs.com/dakewei/p/7690847.html

2.2 mips32上的判定

代码如下:

#include <stdio.h>

void main(void)

{

  unsigned long int ul = 1;

  unsigned char *p = &ul;

  p += (sizeof(unsigned long) - 1); /*因为mips32上unsigned long 类型占据了32个bit,因此移动3个字节,以便到达最后一个字节*/

  printf("*p = %d,p = %p,ul = %d,&ul = %p\n",*p,p,ul,&ul);

}

运行结果如下:

*p = 1,p = 0x80cf3fcb,ul = 1,&ul = 0x80cf3fc8

对运行结果进行分析如下:

先回忆大小端的定义:

大端模式: 低位数据存储在高地址

小端模式:低位数据存储在低地址

那么内存中数据的存放情况如下:

-------------------

0x80cf3fc8  |    0x00         |

     --------------------

0x80cf3fc9  |    0x00         |

        --------------------

0x80cf3fca |      0x00        |

--------------------

0x80cf3fcb |     0x01         |

--------------------

由此可以判定:笔者的mips32机器是大端机器(笔者的这台mips32机器是可以设置大小端的)

2.3 x86上的判定

代码如下:

#include <stdio.h>

void main(void)

{

  unsigned long int ul = 1;

  unsigned char *p = &ul;

  p += (sizeof(unsigned long) - 1); /*因为x86上unsigned long 类型占据了64个bit,因此移动7个字节,以便到达最后一个字节*/

  printf("*p = %d,p = %p,ul = %d,&ul = %p\n",*p,p,ul,&ul);

}

运行结果如下:

*p = 0,p = 0xffffcc07,ul = 1,&ul = 0xffffcc00

对运行结果进行分析如下:

先回忆大小端的定义:

大端模式: 低位数据存储在高地址

小端模式:低位数据存储在低地址

那么内存中数据的存放情况如下:

-------------------

0xffffcc00  |    0x01         |

     --------------------

0xffffcc01 |    0x00         |

        --------------------

0xffffcc02 |      0x00        |

--------------------

0xffffcc03 |     0x00        |

--------------------

0xffffcc04  |    0x00         |

     --------------------

0xffffcc05 |    0x00         |

        --------------------

0xffffcc06 |      0x00        |

--------------------

0xffffcc07 |     0x00         |

--------------------

由此可以判定:笔者的x86机器是小端机器

mips32和x86下的大小端模式判定的更多相关文章

  1. CPU的大小端模式

    不同体系结构的CPU,数据在内存中存放的排列顺序是不一样的. 存储器中对数据的存储是以字节(Byte)为基本单位的,因此,字(Word)和半字(Half-Word)在存储器中就有两种次序,分别称为:大 ...

  2. 清晰讲解LSB、MSB和大小端模式及网络字节序

    时隔一个月又回到了博客园写文章,很开心O(∩_∩)O~~ 今天在做需求的涉及到一个固件版本的概念,其中固件组的人谈到了版本号从MSB到LSB排列,检索查阅后将所得整理如下. MSB.LSB? MSB( ...

  3. CPU大小端模式及转换

    通信协议中的数据传输.数组的存储方式.数据的强制转换等这些都会牵涉到大小端问题. CPU的大端和小端模式很多地方都会用到,但还是有许多朋友不知道,今天暂且普及一下. 一.为什么会有大小端模式之分呢? ...

  4. C/C++ 关于大小端模式

    大端模式:  数据的高字节存在低地址  数据的低字节存在高地址 小端模式:  数据的高字节存在高地址  数据的低字节存在低地址 如图,i为int类型占4个字节,但只有1个字节的值为1,另外3个字节值为 ...

  5. union关键字 与大小端模式

    union 关键字(主要用来压缩空间,如果一些数据不可能同一时间同时用到,可是考虑使用union) union关键字声明的变量称之为联合体变量: (1)联合体变量只配置一个足够大的空间来容纳最大长度的 ...

  6. C语言怎么简单测试为大小端模式

    作者:Slience_J 原文地址:https://blog.csdn.net/slience_j/article/details/52048267 1.什么是大小端模式? 大端模式,是指数据的高字节 ...

  7. 经典笔试题:用C写一个函数测试当前机器大小端模式

    “用C语言写一个函数测试当前机器的大小端模式”是一个经典的笔试题,如下使用两种方式进行解答: 1. 用union来测试机器的大小端 #include <stdio.h> union tes ...

  8. [Linux] Big-endian and Little-endian (大小端模式)

    Big-endian Little-endian 大小端模式   https://en.wikipedia.org/wiki/Endianness 大端模式,是指数据的高字节保存在内存的低地址中,而数 ...

  9. Linux大小端模式转换函数

    转自 http://www.cnblogs.com/kungfupanda/archive/2013/04/24/3040785.html 不同机器内部对变量的字节存储顺序不同,有的采用大端模式(bi ...

随机推荐

  1. PL/SQL EXCEPTION捕获抛出异常

    EXCEPTION抛出异常 处理除数为零异常 declare varA number; begin varA:=10/0; dbms_output.put_line('IT WILL NOT WORK ...

  2. flask 小入门知识点 2018.12.19

    今天听得一脸懵逼,主要因为自己英文底子太差了 不耽误时间了,少总结下,开始复习... 代码: # -*- encoding: utf-8 -*- # 导入重定向模块 , url_for简易寻址跳转,j ...

  3. Python开发【笔记】:what?进程queue还能生产出线程!

    进程queue底层用线程传输数据 import threading import multiprocessing def main(): queue = multiprocessing.Queue() ...

  4. servlet输出请求头

    1.参考 Enumeration headerNames = req.getHeaderNames(); while(headerNames.hasMoreElements()) { String h ...

  5. read 命令

    read 用来接收标准输入 #!/bin/bash read -t -p "Please input a number:" number echo $number //把键盘输入的 ...

  6. Dom最常用的API

    document方法: getElementById(id) Node 返回指定结点的引用 getElementsByTagName(name) NodeList 返回文档中所有匹配的元素的集合 cr ...

  7. 007-spring cloud gateway-GatewayAutoConfiguration核心配置-RouteDefinition初始化加载

    一.RouteDefinitionLocator 在Spring-Cloud-Gateway的GatewayAutoConfiguration初始化加载中会加载RouteDefinitionLocat ...

  8. 【剑指offer】从上往下打印二叉树

    一.题目: 从上往下打印出二叉树的每个节点,同层节点从左至右打印. 二.思路: 用队列,用根节点初始化队列,然后依次从队列中取出节点,先把当前节点输出,并把左右子树分别放入队列,直到队列为空.欧了. ...

  9. 混淆和加密.NET开发工具

    .NET开发的工具,可以用ILSpy等很轻松的反编译查看源码,为了保护自己写的软件,一般会对软件进行加密,不仅内部关键数据通过加密,软件开发完毕后,对软件也进行加密,防止别人很轻松的反编译和查看到比较 ...

  10. OpenCV Mat数据类型及位数总结(转载)

    OpenCV Mat数据类型及位数总结(转载) 前言 opencv中很多数据结构为了达到內存使用的最优化,通常都会用它最小上限的空间来分配变量,有的数据结构也会因为图像文件格式的关系而给予适当的变量, ...