作者:天秤aaaaaaa_150 | 来源:互联网 | 2023-07-03 15:03
问题来源于https://segmentfault.com/q/10这里。看了@elarity的回答,他使用了200000的元素插入到redis集合。于是乎我使用了1百万个元素数组来
问题来源于 https://segmentfault.com/q/10... 这里。看了@elarity 的回答,他使用了200000的元素插入到redis集合。于是乎我使用了1百万个元素数组来插入,在我这里是内存溢出的,所以我使用了生成器的方式
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
| function xrange() {
for ($i=0; $i<1000000; $i++) {
yield $i;
}
}
$r = xrange();
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$key = 'jimu';
$redis->del($key);
$begin = microtime(true);
$redis->sadd($key, ...$r);
$end = microtime(true);
echo ($end - $begin) . "\n"; |
输出结果:
1 2 3
| [vagrant@localhost ~]$ php redis.php
1.2786898612976
[vagrant@localhost ~]$ |
然后redis-cli中确实有了一百万个元素。那么当我把代码中的一百万修改为一千万的时候又报内存溢出
1 2 3 4
| [vagrant@localhost ~]$ php redis.php
PHP Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 32 bytes) in /home/vagrant/redis.php on line 6
Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 32 bytes) in /home/vagrant/redis.php on line 6 |
根据我理解的生成器知识不应该出现内存溢出的情况。因为自始至终生成器xrange只占用一个变量
内存?
所以我猜测是不是
1
| $redis->sadd($key, ...$r); |
这一步的时候
依然会解析成大数组。 现在不知道如何证实。
补充:
我在
之前使用
发现输出的都是
1 2 3 4 5 6 7
| int(999775)
int(999776)
int(999777)
int(999778)
int(999779)
int(999780)
int(999781) |
这样可以证明生成器确实是一个一个产出值的。那么为什么将...$r传入到sadd()的时候还报内存不足呢?不明白这个
的原理,还请大佬们指点。