miller
发布于

int最大值, mysql与计算机内

int 是4个字节,1个字节等于8个比特,共有4*8个比特,每个比特位不是1就是0,那么就有2种选择,
而在二进制里,我们把第一个比特位用来表示正负,0为正数,1为负数。我们把32个比特位都用上,再减去用来表示正负第一个比特位,有31个比特位可以用,也就是有231个组合方式,那么大家可能会自然想到,231就是最大值,但是,最重要的一点大家忽略了,

因为我们现实生活中一般是从1开始计数,我们自然就认为231就是最大值,
可我们计算机里是从0开始计数,组合数231要减去1才是int型能表示的最大值。

换个说法就是,231个表达组合里,当31个比特位都是0时,表示的是0,而不是1,所以最大值为231-1。

mysql int最大值, 自增id 如果是 id int unsigned NOT NULL AUTO_INCREMENT 无符号, 那么就是 2^32 - 1(4294967295)
有符号 就是上边2^31 -1 了.

浏览 (835)
点赞
收藏
评论