mips32和x86下的大小端模式判定
一.背景
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下的大小端模式判定的更多相关文章
- CPU的大小端模式
不同体系结构的CPU,数据在内存中存放的排列顺序是不一样的. 存储器中对数据的存储是以字节(Byte)为基本单位的,因此,字(Word)和半字(Half-Word)在存储器中就有两种次序,分别称为:大 ...
- 清晰讲解LSB、MSB和大小端模式及网络字节序
时隔一个月又回到了博客园写文章,很开心O(∩_∩)O~~ 今天在做需求的涉及到一个固件版本的概念,其中固件组的人谈到了版本号从MSB到LSB排列,检索查阅后将所得整理如下. MSB.LSB? MSB( ...
- CPU大小端模式及转换
通信协议中的数据传输.数组的存储方式.数据的强制转换等这些都会牵涉到大小端问题. CPU的大端和小端模式很多地方都会用到,但还是有许多朋友不知道,今天暂且普及一下. 一.为什么会有大小端模式之分呢? ...
- C/C++ 关于大小端模式
大端模式: 数据的高字节存在低地址 数据的低字节存在高地址 小端模式: 数据的高字节存在高地址 数据的低字节存在低地址 如图,i为int类型占4个字节,但只有1个字节的值为1,另外3个字节值为 ...
- union关键字 与大小端模式
union 关键字(主要用来压缩空间,如果一些数据不可能同一时间同时用到,可是考虑使用union) union关键字声明的变量称之为联合体变量: (1)联合体变量只配置一个足够大的空间来容纳最大长度的 ...
- C语言怎么简单测试为大小端模式
作者:Slience_J 原文地址:https://blog.csdn.net/slience_j/article/details/52048267 1.什么是大小端模式? 大端模式,是指数据的高字节 ...
- 经典笔试题:用C写一个函数测试当前机器大小端模式
“用C语言写一个函数测试当前机器的大小端模式”是一个经典的笔试题,如下使用两种方式进行解答: 1. 用union来测试机器的大小端 #include <stdio.h> union tes ...
- [Linux] Big-endian and Little-endian (大小端模式)
Big-endian Little-endian 大小端模式 https://en.wikipedia.org/wiki/Endianness 大端模式,是指数据的高字节保存在内存的低地址中,而数 ...
- Linux大小端模式转换函数
转自 http://www.cnblogs.com/kungfupanda/archive/2013/04/24/3040785.html 不同机器内部对变量的字节存储顺序不同,有的采用大端模式(bi ...
随机推荐
- PL/SQL EXCEPTION捕获抛出异常
EXCEPTION抛出异常 处理除数为零异常 declare varA number; begin varA:=10/0; dbms_output.put_line('IT WILL NOT WORK ...
- flask 小入门知识点 2018.12.19
今天听得一脸懵逼,主要因为自己英文底子太差了 不耽误时间了,少总结下,开始复习... 代码: # -*- encoding: utf-8 -*- # 导入重定向模块 , url_for简易寻址跳转,j ...
- Python开发【笔记】:what?进程queue还能生产出线程!
进程queue底层用线程传输数据 import threading import multiprocessing def main(): queue = multiprocessing.Queue() ...
- servlet输出请求头
1.参考 Enumeration headerNames = req.getHeaderNames(); while(headerNames.hasMoreElements()) { String h ...
- read 命令
read 用来接收标准输入 #!/bin/bash read -t -p "Please input a number:" number echo $number //把键盘输入的 ...
- Dom最常用的API
document方法: getElementById(id) Node 返回指定结点的引用 getElementsByTagName(name) NodeList 返回文档中所有匹配的元素的集合 cr ...
- 007-spring cloud gateway-GatewayAutoConfiguration核心配置-RouteDefinition初始化加载
一.RouteDefinitionLocator 在Spring-Cloud-Gateway的GatewayAutoConfiguration初始化加载中会加载RouteDefinitionLocat ...
- 【剑指offer】从上往下打印二叉树
一.题目: 从上往下打印出二叉树的每个节点,同层节点从左至右打印. 二.思路: 用队列,用根节点初始化队列,然后依次从队列中取出节点,先把当前节点输出,并把左右子树分别放入队列,直到队列为空.欧了. ...
- 混淆和加密.NET开发工具
.NET开发的工具,可以用ILSpy等很轻松的反编译查看源码,为了保护自己写的软件,一般会对软件进行加密,不仅内部关键数据通过加密,软件开发完毕后,对软件也进行加密,防止别人很轻松的反编译和查看到比较 ...
- OpenCV Mat数据类型及位数总结(转载)
OpenCV Mat数据类型及位数总结(转载) 前言 opencv中很多数据结构为了达到內存使用的最优化,通常都会用它最小上限的空间来分配变量,有的数据结构也会因为图像文件格式的关系而给予适当的变量, ...