博客
关于我
无穷大0x3f3f3f3f
阅读量:544 次
发布时间:2019-03-07

本文共 528 字,大约阅读时间需要 1 分钟。

0x3f3f3f3f是一个非常有用的数值,它同时满足两个特定的条件,是最大的符合条件的整数。第一点是这个整数的两倍不能超过0x7f7f7f7f,也就是整数能表示的最大正整数。第二点是这个整数的每8位(每个字节)都是一样的。这意味着它可以被用来初始化数组,因为这是一个典型的使用场景。

在编程中,我们经常需要用到memset函数来初始化一个数组a。这个函数 接受三个参数:目标数组a、转移值val以及数组的大小。由于val的取值范围只能从0x00到0xFF,memset只能将每个字节设置为相同的值。这正好符合我们想要的第二个条件,即每个字节的值都一样。

有时候,我们需要把一个数组初始化为全最小值或者全最大值的负数。不过这会带来一个问题:如果使用arithmetic operations(算术操作)进行初始化,可能会导致溢出。因此,我们需要一个更方便且更容易的方法。

为了简化这个过程,程序员通常会用memset函数将数组初始化为0x3f3f3f3f的值。这个数值看起来像是每个字节都被设置为0x3f,这正好满足了我们前面的两个条件。值得注意的是,0x3f占据了四个字节的位置,因此最终的数值就是0x3f3f3f3f。这也是为什么它被广泛使用的主要原因。

转载地址:http://hddcz.baihongyu.com/

你可能感兴趣的文章
Objective-C实现2D变换算法(附完整源码)
查看>>
Objective-C实现3n+1猜想(附完整源码)
查看>>
Objective-C实现3n+1猜想(附完整源码)
查看>>
Objective-C实现9x9乘法表算法(附完整源码)
查看>>
Objective-C实现9×9二维数组数独算法(附完整源码)
查看>>
Objective-C实现A*(A-Star)算法(附完整源码)
查看>>
Objective-C实现A-Star算法(附完整源码)
查看>>
Objective-C实现abbreviation缩写算法(附完整源码)
查看>>
Objective-C实现ABC人工蜂群算法(附完整源码)
查看>>
Objective-C实现activity selection活动选择问题算法(附完整源码)
查看>>
Objective-C实现AC算法(Aho-Corasick) 算法(附完整源码)
查看>>
Objective-C实现adaboost算法(附完整源码)
查看>>
Objective-C实现Adler32算法(附完整源码)
查看>>
Objective-C实现AES算法(附完整源码)
查看>>
Objective-C实现AffineCipher仿射密码算法(附完整源码)
查看>>
Objective-C实现aliquot sum等分求和算法(附完整源码)
查看>>
Objective-C实现all combinations所有组合算法(附完整源码)
查看>>
Objective-C实现all permutations所有排列算法(附完整源码)
查看>>
Objective-C实现all subsequences所有子序列算法(附完整源码)
查看>>
Objective-C实现AlphaNumericalSort字母数字排序算法(附完整源码)
查看>>