找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 317|回复: 0
打印 上一主题 下一主题

PHP和MySql中32位和64位的整形范围是多少

[复制链接]

2588

主题

2588

帖子

7694

积分

论坛元老

Rank: 8Rank: 8

积分
7694
跳转到指定楼层
楼主
发表于 2018-2-14 05:38:54 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            

一个字节有8位,所以32位int型占用32位/8位=4个字节,64位int型占用64位/8位=8个字节.
32位,64位无符号整型最大值:
2^64-1 = 18446744073709551615
2^32-1 = 4294967295
32位,64位有符号整型最大值:
(2^32)/2-1 = 2147483647
(2^64)/2-1 = 9223372036854775807
减1是因为整型包括0.
64位Ubuntu 14.04,PHP_INT_MAX的值为9223372036854775807,跟MySQL中有符号的bigint型的最大值一样.
32位Ubuntu 14.04,PHP_INT_MAX的值为2147483647,跟MySQL中有符号的int型的最大值一样.
echo date('Y-m-d H:i:s', PHP_INT_MAX); 返回 2038-01-19 11:14:07
echo strtotime('2038-01-19 11:14:07'); 返回 2147483647
echo strtotime('2038-01-19 11:14:08'); 32位下返回空
也就是说,32位系统上PHP的time()最大只能返回2038-01-19 11:14:07的时间戳.
字段类型: `posted` int(10) unsigned NOT NULL DEFAULT '0'
32位MySQL上(64位MySQL也是如此),插入一个比32位无符号int型最大值 2^32-1 = 4294967295 更大的数会发生错误:
UPDATE `punbb`.`pb_topics` SET `posted` = '4294967296' WHERE `pb_topics`.`id` = 1;
Warning: #1264 Out of range value for column 'posted' at row 1
不过,MySQL可以用8个字节的bigint类型来存储64位整数.

      
      数据类型
      

      
      LP64
      

      
      ILP64
      

      
      LLP64
      

      
      ILP32
      

      
      LP32
      

      
      char
      

      
      8
      

      
      8
      

      
      8
      

      
      8
      

      
      8
      

      
      short
      

      
      16
      

      
      16
      

      
      16
      

      
      16
      

      
      16
      

      
      _int32
      

      
      N/A
      

      
      32
      

      
      N/A
      

      
      N/A
      

      
      N/A
      

      
      int
      

      
      32
      

      
      64
      

      
      32
      

      
      32
      

      
      16
      

      
      long
      

      
      64
      

      
      64
      

      
      32
      

      
      32
      

      
      32
      

      
      long long
      

      
      N/A
      

      
      N/A
      

      
      64
      

      
      N/A
      

      
      N/A
      

      
      pointer
      

      
      64
      

      
      64
      

      
      64
      

      
      32
      

      
      32
      

以上内容是小编给大家介绍的32位和64位的整形范围,希望对大家有所帮助。
            
            
您可能感兴趣的文章:
  • 在双硬盘上安装独立32位和64位双系统
  • VB的32位程序在64位系统中出现文件和注册表自动转向的解决方法
  • 阿里云主机Windows 2008 32位 64位自助正版激活图文教程
  • Visual Studio中根据系统区分引用64位、32位DLL动态库文件的配置方法
  • C#中实现在32位、64位系统下自动切换不同的SQLite dll文件
  • 安装SQL server 2005 出现警告 32位ASP.NET已经注册,需要注册64位的解决方法
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端