为了基于PHP创建一个在bash中生成素数的列表,并且可以在中断后恢复,我使用了fmod()函数以及PHP评论区中其他两位用户提供的一些代码片段。
这将输出
"素数;最后一个素数与当前素数的差值"
所以功劳归于他们。我只做了日志文件的输出。
这个函数可以处理fmod()支持的任何最大值。只需输入$end值。并对日志文件执行touch命令,然后使用chmod 666命令,以便PHP可以访问它。
<?php
function tailCustom($filepath, $lines = 1, $adaptive = true) {
$f = @fopen($filepath, "rb");
if ($f === false) return false;
if (!$adaptive) $buffer = 4096;
else $buffer = ($lines < 2 ? 64 : ($lines < 10 ? 512 : 4096));
fseek($f, -1, SEEK_END);
if (fread($f, 1) != "\n") $lines -= 1;
$output = '';
$chunk = '';
while (ftell($f) > 0 && $lines >= 0) {
$seek = min(ftell($f), $buffer);
fseek($f, -$seek, SEEK_CUR);
$output = ($chunk = fread($f, $seek)) . $output;
fseek($f, -mb_strlen($chunk, '8bit'), SEEK_CUR);
$lines -= substr_count($chunk, "\n");
}
while ($lines++ < 0) {
$output = substr($output, strpos($output, "\n") + 1);
}
fclose($f);
return trim($output);
}
function isPrime( $num )
{
for( $i = 2; $i*$i <= $num; $i++ )
if( !fmod($num,$i) )
return FALSE;
return TRUE;
}
$logfile = 'prim_save.log';
$lastline = explode(";", tailCustom($logfile));
$begin = ($lastline[0] +1);
$lastprime = $lastline[0];
$end = 999999999999999999999999999999999999;
$fp = fopen($logfile, 'a');
for($i = $begin; $i<$end; $i++)
{
if(isPrime($i) == TRUE)
{
$difference = $i - $lastprime;
fputs($fp,$i.';'.$difference.';'."\n");
$lastprime = $i;
}
}
fclose($fp);
?>