, однако кодирование не может работать в потоке, только байт [].
blockquote>Правильно, но
StreamReader : TextReader
может быть связано с потоком.Так что просто создайте этот MemoryStream, вставьте байты на одном конце и используйте ReadLine () на другом. Я должен сказать, что никогда не пробовал этого.
PHP обрабатывает обратные вызовы как строки, не указатели функции. Причина Ваш первый тест работает, состоит в том, потому что интерпретатор PHP принимает foo1 как строка. Если у Вас есть включенная погрешность нивелировки E_NOTICE, необходимо видеть доказательство этого.
"Использование неопределенного постоянного foo1 - приняло 'foo1'",
Вы не можете назвать статические методы этим путем, к сожалению. Объем (класс) релевантен, таким образом, необходимо использовать call_user_func вместо этого.
<?php
function foo1($a,$b) { return $a/$b; }
class Bar
{
public static function foo2($a,$b) { return $a/$b; }
public function UseReferences()
{
$fn = 'foo1';
echo $fn(6,3);
$fn = array( 'self', 'foo2' );
print call_user_func( $fn, 6, 2 );
}
}
$b = new Bar;
$b->UseReferences();
В php 5.2 можно использовать переменную в качестве имени метода в статическом вызове, но использовать переменную в качестве имени класса, необходимо будет использовать обратные вызовы, как описано BaileyP.
Однако от php 5.3, Вы можете использовать переменную в качестве имени класса в статическом вызове. Так:
class Bar
{
public static function foo2($a,$b) { return $a/$b; }
public function UseReferences()
{
$method = 'foo2';
print Bar::$method(6,2); // works in php 5.2.6
$class = 'Bar';
print $class::$method(6,2); // works in php 5.3
}
}
$b = new Bar;
$b->UseReferences();
?>
Это, кажется, работает на меня:
<?php
class Foo{
static function Calc($x,$y){
return $x + $y;
}
public function Test(){
$z = self::Calc(3,4);
echo("z = ".$z);
}
}
$foo = new Foo();
$foo->Test();
?>
"К участнику или методу, объявленному с помехами, нельзя получить доступ с переменной, которая является экземпляром объекта и не может быть переопределена в расширяющемся классе"
( http://theserverpages.com/php/manual/en/language.oop5.static.php )
В PHP 5.3.0 вы также можете сделать следующее:
<?php
class Foo {
static function Bar($a, $b) {
if ($a == $b)
return 0;
return ($a < $b) ? -1 : 1;
}
function RBar($a, $b) {
if ($a == $b)
return 0;
return ($a < $b) ? 1 : -1;
}
}
$vals = array(3,2,6,4,1);
$cmpFunc = array('Foo', 'Bar');
usort($vals, $cmpFunc);
// This would also work:
$fooInstance = new Foo();
$cmpFunc = array('fooInstance', 'RBar');
// Or
// $cmpFunc = array('fooInstance', 'Bar');
usort($vals, $cmpFunc);
?>