嵌入式C语言自我修养基本概念考察(二)

一个sizeof(int)引发的思考

1.sizeof是函数,是关键字,还是预定义标识符?

sizeof 运算符用于获取一个数据类型或一个表达式的字节大小(或字节数),它返回一个无符号整数值,表示操作数占用的内存大小。 

2.在32位和64位的Windows 7环境下运行,结果分别是多少? 

在32位和64位的Windows 7环境下,sizeof(int) 的结果都是 4 字节

在C和C++中,sizeof 是一个运算符,用于计算类型或变量所占用的字节数。对于 sizeof(int),它返回的是 int 类型所占用的字节数。

3.在32位和64位的X86 CPU平台下运行,结果分别是多少? 

x86 CPU平台是一种常见的处理器架构,广泛应用于个人计算机和服务器。在x86平台上,`int` 类型的大小通常是 4 字节。这是因为在x86平台上,`int` 类型被定义为32位整数,占用4个字节的存储空间。

无论是在32位还是64位的x86 CPU平台下,`sizeof(int)` 的结果都是 4 字节。这是由于x86架构在这两种模式下都将 `int` 类型定义为32位大小。

需要注意的是,虽然在绝大多数情况下,`int` 类型在x86平台上都是4字节,但这并不是绝对的,因为具体的编译器和平台规范可能会有所不同。为了确保代码的可移植性,特别是涉及到跨平台开发时,建议使用标准的整数类型(如 `int32_t`、`int64_t` 等)来明确指定所需的大小。

4.在8位、16位、32位的单片机环境下运行,结果分别是多少? 

在8位、16位和32位的单片机环境下,`sizeof(int)` 的结果可能是不同的。

单片机是一种嵌入式系统,通常具有有限的资源和特定的指令集。在单片机环境下,`int` 类型的大小通常是根据编译器和单片机架构来确定的,而不是固定的。

对于一些常见的单片机平台:

- 在8位单片机环境下,`sizeof(int)` 的结果通常是 1 字节或 2 字节。由于8位单片机的数据总线宽度较窄,通常将 `int` 类型定义为 1 字节(8位)或 2 字节(16位)的整数。

- 在16位单片机环境下,`sizeof(int)` 的结果通常是 2 字节。16位单片机的数据总线宽度为16位,因此 `int` 类型通常被定义为 2 字节(16位)的整数。

- 在32位单片机环境下,`sizeof(int)` 的结果通常是 4 字节。32位单片机的数据总线宽度为32位,因此 `int` 类型通常被定义为 4 字节(32位)的整数。

需要注意的是,这些是一般情况下的规律,具体的单片机平台和编译器可能会有不同的规范和类型大小定义。在开发单片机应用程序时,应该参考所使用的单片机的文档和编译器的规范,以确定具体的类型大小。

5.在32位ARM和64位ARM下运行,结果分别是多少?

在32位ARM和64位ARM下,`sizeof(int)` 的结果通常是相同的,都是4字节

ARM是一种广泛使用的处理器架构,常见于移动设备、嵌入式系统和服务器。在ARM架构下,`int` 类型的大小通常被定义为4字节,无论是在32位还是64位的ARM平台上。

无论是在32位ARM还是64位ARM平台下,`sizeof(int)` 的结果都是4字节。这是由于ARM架构将 `int` 类型定义为32位大小的整数,占用4个字节的存储空间。

需要注意的是,虽然在大多数情况下,`int` 类型在ARM平台上都是4字节,但这并不是绝对的,因为具体的编译器和平台规范可能会有所不同。为了确保代码的可移植性,特别是涉及到跨平台开发时,建议使用标准的整数类型(如 `int32_t`、`int64_t` 等)来明确指定所需的大小。

 

6.分别在VC++6.0、Turbo C、Keil、32位/64位GCC编译器下编译、运行,结果一样吗? 

在不同的编译器和平台下,`sizeof(int)` 的结果可能是相同的,也可能是不同的。

- VC++ 6.0:在VC++ 6.0编译器下,`sizeof(int)` 的结果通常是4字节。这是因为VC++ 6.0是一个32位编译器,将 `int` 类型定义为32位大小的整数。

- Turbo C:在Turbo C编译器下,`sizeof(int)` 的结果通常是2字节。Turbo C是一种16位编译器,将 `int` 类型定义为16位大小的整数。

- Keil:Keil是一种嵌入式开发环境,用于开发各种单片机应用程序。在Keil编译器中,`sizeof(int)` 的结果可能会因为不同的目标平台和编译器设置而有所不同。通常情况下,对于32位ARM平台,`sizeof(int)` 的结果是4字节,对于8位单片机平台,`sizeof(int)` 的结果可能是1字节或2字节

- 32位/64位GCC编译器:在GCC编译器下,`sizeof(int)` 的结果通常是4字节。无论是在32位还是64位的GCC编译器中,`int` 类型通常被定义为32位大小的整数。

7.使用32位GCC编译器编译生成32位可执行文件,运行在64位环境下,结果如何?

使用32位GCC编译器编译生成的32位可执行文件在64位环境下运行时,`sizeof(int)` 的结果通常仍然是4字节。

在这种情况下,32位可执行文件在64位环境下运行时,操作系统会提供一种称为"兼容模式"的机制,以确保32位应用程序能够正常运行。在兼容模式下,32位应用程序仍然使用32位的数据模型和类型大小。

因此,即使在64位环境下运行32位可执行文件,`sizeof(int)` 的结果仍然是4字节,因为它遵循了32位数据模型。

8.使用64位GCC编译器编译生成64位可执行文件,运行在32位环境下,结果如何? 

使用64位GCC编译器编译生成的64位可执行文件在32位环境下运行时,通常会出现不兼容的情况,无法正常运行。

64位可执行文件是为64位环境下的操作系统和硬件架构所设计的,它使用64位的数据模型和类型大小。而32位环境下的操作系统和硬件架构只支持32位的数据模型和类型大小。

因此,当尝试在32位环境下运行64位可执行文件时,操作系统会无法解析和执行该文件,导致无法正常运行。

要在32位环境下运行程序,需要使用32位的编译器来编译生成32位的可执行文件,以确保与目标环境的兼容性。

  • 8
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值