• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

ios - 最好在 64 位中使用 long 或 long long

[复制链接]
菜鸟教程小白 发表于 2022-12-12 18:03:01 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

在 LP64 中,long 的大小和 long long 的大小相同(Apple DocsUnix Docs)。

那么,当限制自己理解你在 LP64 系统上运行时(就像 XCode 在编译 64 位时出现的那样),long 之间有什么区别吗? >很长很长?如果您的目标是 64 位整数,是否有任何性能原因使用 long 而不是 long long

这就是我问的原因。在 Xcode 上的 Objective C 中,NSString 的格式(如 printf)和 NSNumber 都使用 intlonglong long 等数据类型及其无符号变体在转换数字和文本而不是特定位长数字时,例如 int16_tint32。和 int64_t。当您想要将特定大小的数据存储到 NSNumber 中而不进行类型转换时,这将使需要特定最小大小(即网络或货币应用程序)或时间的东西变得难以编程。

对于 int32_t 使用 int 使用 long long 是否安全,仅限于任何 Intel Mac OS 或 iOS 设备int64_t 在与 NSString 的格式函数和 NSNumber 等交互时?



Best Answer-推荐答案


Is it safe, limiting to any Intel Mac OS or iOS device, to use int for int32_t and long long for int64_t when interacting with things like NSString's format functions and NSNumber?

根据 ILP32 和 LP64 约定,是的,但您应该真正证明您依赖这些尺寸。

一种方法是使用源自(据我所知)Linux 内核的聪明宏:

#define BUILD_BUG_ON(condition) ((void)sizeof(char[1 - 2*!!(condition)]))

如果其条件参数为真,该宏将产生编译时错误,因为在这种情况下,它会尝试确定负大小数组的大小。您可以在以下简单函数中使用它:

static __attribute__((unused)) void _compile_time_use_only_()
{
   BUILD_BUG_ON( (sizeof(int) != 4) );
   BUILD_BUG_ON( (sizeof(long long) != 8) );
}

将其添加到您的代码中,如果您尝试在 int 不是 32 位或 long long 不是 64 位的任何系统上进行编译,那么您将得到编译时错误。运行时基本上是零成本(未使用的函数只有几个字节)。

请务必评论说明它的功能!

你当然可以用同样的方式断言其他类型的大小。

HTH

关于ios - 最好在 64 位中使用 long 或 long long,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34601739/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap