随机种子有最大字符数限制吗?

Is there a maximum character limit to random seed?

Python 中的种子是否有最大字符数(以及相应的值)?

import random
random.seed(13) # fine
random.seed(1234567890) # also fine
random.seed(31415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679821480865132823066470938446095505822317253594081284811174502841027019385211055596446229489549303819644288109756659334461284756482337867831652712019091456485669234603486104543266482133936072602491412737245870066063155881748815209209628292540917153643678925903600113305305488204665213841469519415116094330572703657595919530921861173819326117931051185480744623799627495673518857527248912279381830119491298336733624406566430860213949463952247371907021798609437027705392171762931767523846748184676694051320005681271452635608277857713427577896091736371787214684409012249534301465495853710507922796892589235420199561121290219608640344181598136297747713099605187072113499999983729780499510597317328160963185950244594553469083026425223082533446850352619311881710100031378387528865875332083814206171776691473035982534904287554687311595628638823537875937519577818577805321712268066130019278766111959092164201989)
# also fine

我不确定为什么有人会选择这么高的值,但我只想知道是否有限制。

由于 random.seed 期望 Noneintlong,因此在技术上没有为种子定义限制,因为 long 可以非常大,取决于可用地址 space,这是一个实际限制。无论如何,函数中也没有检查限制的迹象。

没有最大限制,但输入最终会被截断为 20,000 位。

即使你不了解算法(我不懂),你也可以在源代码中跟进。

首先,CPython 将输入分成 32 位块,并从中创建一个字节数组:https://github.com/python/cpython/blob/55edd0c185ad2d895b5d73e47d67049bc156b654/Modules/_randommodule.c#L258-L293

然后,Mersene Twister PRNG 的种子编号为 19,650,218,之后发生了一些超出我理解的数学问题:https://github.com/python/cpython/blob/55edd0c185ad2d895b5d73e47d67049bc156b654/Modules/_randommodule.c#L172-L196

但是在所有这些操作中,请注意这一行:https://github.com/python/cpython/blob/55edd0c185ad2d895b5d73e47d67049bc156b654/Modules/_randommodule.c#L180

N 个元素之后的任何内容都不会循环,因此会被有效丢弃。在这种情况下,N 是 624(它是一个魔法常量:https://github.com/python/cpython/blob/55edd0c185ad2d895b5d73e47d67049bc156b654/Modules/_randommodule.c#L76),因此使用的输入字节不超过 625 * 32 = 20,000

由于代码中的注释是"from the right",我们将相信他们的话(这一切都超出了我的理解范围,所以我无权质疑他们)。因此我有足够的信心得出结论,输入的最右边的 20,000 位被使用,其余的被丢弃。

也就是说,我想 "rightmost" 的定义是平台相关的,所以它可能不是您应该依赖的行为。