我有一个自定义PHP扩展,它比较二进制数据字符串中的每个字节。如果文件中同一位置的两个字节都打开(或大于1),则相同位置的输出将打开。否则它关闭。扩展如下......
PHP_FUNCTION(compare_memory)
{
char *memory1, *memory2;
int memory1_length, memory2_length, return_length;
int length;
char *output;
int x;
zval *param;
// MAKE SURE WE HAVE
// string, (string_len,), string2, (string2_len) and length
if(ZEND_NUM_ARGS() != 2) WRONG_PARAM_COUNT;
// GET ARGUMENTS FROM PHP
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "ss", &memory1, &memory1_length, &memory2, &memory2_length) == FAILURE)
{
return;
}
if (memory1_length < memory2_length)
{
length = memory1_length;
return_length = memory2_length;
} else
{
length = memory2_length;
return_length = memory1_length;
}
if ((output = emalloc(return_length * sizeof(int))) == NULL)
{
printf("Error on malloc\n");
return;
}
// START COMPARING
for(x=1;x<length;x++)
{
if (memory1[x] > 0 && memory2[x] == 1)
{
output[x] = memory1[x];
}
}
RETVAL_STRINGL(output, return_length, 1);
efree(output);
}
我还有一个PHP实现如下......
function compare_memory($data1, $data2)
{
$pack_one = pack("c", 1);
$pack_zero = pack("c", 0);
$strlen_data1 = strlen($data1);
$strlen_data2 = strlen($data2);
if ($strlen_data1 > $strlen_data2)
{
$strlen = $strlen_data1;
} else
{
$strlen = $strlen_data2;
}
$output = "";
for($x=0;$x<$strlen;$x++)
{
if ($strlen_data1 > $x)
{
$arr = unpack("cc", $data1[$x]);
$d1 = $arr["c"];
} else
{
$d1 = 0;
}
if ($strlen_data2 > $x)
{
$arr = unpack("cc", $data2[$x]);
$d2 = $arr["c"];
} else
{
$d2 = 0;
}
if ($d1 > 0 && $d2 == 1)
{
$output .= pack("c", $d1);
} else
{
$output .= $pack_zero;
}
}
return $output;
}
这个扩展程序在PHP 5.0下运行良好(我知道它已经很老了)。我们最近升级到5.3,这不再适用。然而PHP实现呢。
我认为版本之间的PHP内部API已经发生了很多变化,包括“参数解析API统一将导致某些函数在类型杂耍时表现得更严格或更不严格”。
您是否可以在PHP扩展中看到任何明显可能导致它无法在更新版本的PHP中运行的内容?我对C(和PHP API)的了解很少。
答案 0 :(得分:0)
我不确定你是否可以保证emalloc
将返回用零初始化的内存。您可以尝试使用ecalloc代替。
或者自己动手:
if ((output = emalloc(return_length * sizeof(int))) == NULL)
{
printf("Error on malloc\n");
return;
}
memset(output, 0, return_length * sizeof(int) );
另外,我认为emalloc
永远不会返回NULL
(另外我不确定为什么你的for(x=1;x<length;x++)
从1而不是0开始,但也许是有原因的)