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 ...
随机推荐
- H5,PC网页屏幕尺寸相关整理(scrollLeft,scrollWidth,clientWidth,offsetWidth)
HTML:scrollLeft,scrollWidth,clientWidth,offsetWidth到底指的哪到哪的距离之完全详解scrollHeight: 获取对象的滚动高度. scrollLef ...
- RSA原理说明
长度,建议至少1024.模数n(常取默认65537)两边都要用. 指数e,和n一起就是公钥. 指数d,和n一起就是私钥. 质数p和q用于生成密钥对,然后就丢弃不公开. 一.密钥对的生成步骤 1.随机选 ...
- zabbix 报错汇总
打开zabbix web界面点击profile出现以下报错信息: scandir() has been disabled for security reasons [profile.php:198 → ...
- python 基础 特殊符号的使用
python语句中的一些基本规则和特殊符号: 1.井号# 表示之后的字符为python注释 Python注释语句从#号字符开始,注释可以在语句的任何一个地方开始,解释器会忽略掉该行#号之后的所有内容 ...
- dedecms自增标签[field:global.autoindex/]的运用
用bootstrap建站时用到幻灯片切换模块,里面有个active(下面代码中的data-slide-to="0"),其余的按顺序递增(1,2),如果用dedecms就可以用aut ...
- [py]字符串/列表
去除str首尾空格(切片) ## str长度 循环,判断 ### [:i] [i:] 记录位置点 ## 方法1 def trim2(s): s2 = "" start = 0 en ...
- 问题解决 -------- 解决YUM下Loaded plugins: fastestmirror Determining fastest mirrors 的问题
解决YUM下Loaded plugins: fastestmirror Determining fastest mirrors 的问题 (2012-09-02 13:09:25) 转载▼ 标签: 杂谈 ...
- iOS UI基础-4.2应用程序管理 Xib文件使用
Xib调整使用 1.新建xib文件 New File-->User Interface-->Empty 2.打开新建的xib文件,出现可视化窗口 (1)拖入一个UIView (不是UIVi ...
- 浅谈Android View的定位
引言 今天我们来介绍Android坐标系统和View的定位,当然也会介绍View的滑动相关话题.下面让我们开始介绍吧. View的基础知识 View是Android中所有控件的基类,无论是TextVi ...
- 剑指offer3
输入一个链表,从尾到头打印链表每个节点的值. 思路:首先借助一个栈,遍历链表中的每一个值,然后存储到栈中,利用栈的先进后出特点,然后添加到数组中返回. package demo3; import ja ...