| PHP Developer Forum Hier habt ihr die Möglichkeit, eure Skriptprobleme mit anderen Anwendern zu diskutieren. Seid so fair und beantwortet auch Fragen von anderen Anwendern. Dieses Forum ist sowohl für ANFÄNGER als auch für PHP-Profis! Post your PHP questions here! |
 |

01-07-2011, 12:40
|
|
thotti
Registrierter Benutzer
|
|
Registriert seit: Jul 2011
Beiträge: 5
|
|
PHP 5.3 > 5.4 / Probleme mit (Parameter n to function() expected to be a reference, v
Hi,
ich hatte unter PHP 5.3 ein Script laufen, welches ohne Probleme lief. Nach Umstellung auf Debian 6 und damit auf PHP 5.4 erhalte ich eine Fehlermeldung. Kann mir bitte einer sagen, warum das nicht mehr geht, und/oder was ich besser machen kann?
Das Script hier mal auf das Wesentliche reduziert:
PHP-Code:
<?php
class MyClass { public function __construct() { $this->my_external_handler = 'my_external_user_function'; declare(ticks = 1); pcntl_signal(SIGINT, array($this, "signal_handler")); } public function signal_handler($signal_number) { $this->info = "signal $signal_number caught"; call_user_func($this->my_external_handler, $this); } }
ini_set("display_errors", 1); ini_set("error_reporting", E_ALL);
$TestClass = new MyClass;
$i = 10; while($i--) { echo("Waiting $i seconds for SIGINT (CONTROL+C) ...\n"); sleep(1); }
function my_external_user_function(&$data) { echo("info: '".$data->info."'\n"); exit; } ?>
Wenn ich es in der Shell wie folgt ausführe
dann erhalte ich die Meldung:
Code:
Parameter 1 to my_external_user_function() expected to be a reference, value given in /var/lib/asterisk/agi-bin/test.php on line 15
Wenn ich Zeile 15 wie folgt ändere, dann klappt es:
PHP-Code:
call_user_func($this->my_external_handler, &$this);
Aber: Ist das so richtig?
|

01-07-2011, 12:41
|
|
h3ll
Registrierter Benutzer
|
|
Registriert seit: Mar 2008
Beiträge: 2.328
|
|
Warum verwendest du hier eine Referenz? Lass sie doch einfach weg.
|

01-07-2011, 12:44
|
|
thotti
Registrierter Benutzer
|
|
Registriert seit: Jul 2011
Beiträge: 5
|
|
Ja hier in der reduzierten Form wäre das kein Problem. In meinem Script spielt das schon eine Rolle ... Unabhängig davon wüsste ich schon gerne, warum das nicht mehr geht.
|

01-07-2011, 12:52
|
|
h3ll
Registrierter Benutzer
|
|
Registriert seit: Mar 2008
Beiträge: 2.328
|
|
Zitat:
Zitat von thotti
Ja hier in der reduzierten Form wäre das kein Problem. In meinem Script spielt das schon eine Rolle ... Unabhängig davon wüsste ich schon gerne, warum das nicht mehr geht.
|
Dann zeig bitte ein Beispiel, wo das so notwendig ist. Ich seh keine Notwendigkeit für eine Referenz. Mit Fantasiecode, der nichts mit dem Problem zu tun hat, kann man schlecht arbeiten.
|

01-07-2011, 13:22
|
|
combie
PHP Expert
|
|
Registriert seit: May 2006
Beiträge: 2.925
|
|
Zitat:
PHP-Code:
call_user_func($this->my_external_handler, &$this);
Aber: Ist das so richtig?
|
Nein!
Das ist Unsinn!
Denn $this ist IMMER eine Referenz.
|

01-07-2011, 13:33
|
AmicaNoctis
 Moderatorin
|
|
Registriert seit: Jul 2009
Beiträge: 5.550
|
|
Zitat:
Zitat von combie
Nein!
Das ist Unsinn!
Denn $this ist IMMER eine Referenz.
|
$this ist immer ein Objekt, aber keine Referenz, jedenfalls nicht in PHP 5. Ich würde den Parameter $data einfach als MyClass typen und fertig. Es gibt keinen Grund, ihn als Referenz zu deklarieren.
__________________
Hast du die Grundlagen zur Fehlersuche gelesen? Hast du Code-Tags benutzt? 
Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
Super, danke! 
|

01-07-2011, 13:36
|
|
thotti
Registrierter Benutzer
|
|
Registriert seit: Jul 2011
Beiträge: 5
|
|
Zitat:
Zitat von AmicaNoctis
Ich würde den Parameter $data einfach als MyClass typen und fertig.
|
Was heisst das bitte?
|

01-07-2011, 13:39
|
AmicaNoctis
 Moderatorin
|
|
Registriert seit: Jul 2009
Beiträge: 5.550
|
|
Zitat:
Zitat von thotti
Was heisst das bitte?
|
PHP-Code:
function my_external_user_function (MyClass $data) { // ... }
Alles was du in dieser Funktion mit $data anstellst, wird sich auf das übergebene Objekt auswirken. Es gibt also keinen Grund für eine Referenz. Du darfst $data nur keinen völlig neuen Wert zuweisen.
__________________
Hast du die Grundlagen zur Fehlersuche gelesen? Hast du Code-Tags benutzt? 
Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
Super, danke! 
|

01-07-2011, 13:43
|
|
thotti
Registrierter Benutzer
|
|
Registriert seit: Jul 2011
Beiträge: 5
|
|
Zitat:
Zitat von AmicaNoctis
PHP-Code:
function my_external_user_function (MyClass $data) { // ... }
|
Danke - wo kann ich darüber bitte mehr lesen? Das habe ich noch nie gesehen. "Casten" ansich kenne ich - aber nicht so.
Und noch eine Frage bitte: Damit wäre es also eigentlich egal, ob ich eine Referenz übergebe und dies als Refernz in der Funktion deklariere ODER ob ich als value übergebe und dies ebenso in der Funktion als value angebe? Oder anders: die folgenden Varianten sind praktisch(!) identisch?
1)
call_user_func($this->my_external_handler, $this);
[...]
function my_external_user_function($data)
2)
call_user_func($this->my_external_handler, &$this);
[...]
function my_external_user_function(&$data)
|

01-07-2011, 14:13
|
AmicaNoctis
 Moderatorin
|
|
Registriert seit: Jul 2009
Beiträge: 5.550
|
|
Zitat:
Zitat von thotti
Danke - wo kann ich darüber bitte mehr lesen?
|
PHP: Type Hinting - Manual
Zitat:
Zitat von thotti
Und noch eine Frage bitte: Damit wäre es also eigentlich egal, ob ich eine Referenz übergebe und dies als Refernz in der Funktion deklariere ODER ob ich als value übergebe und dies ebenso in der Funktion als value angebe?
|
Wenn ein Parameter als Referenz deklariert ist, wird immer eine Referenz übergeben. Wenn du dann myfunc( &$var) aufrufst (statt myfunc($var)), kommt sogar eine Fehlermeldung (ab PHP 5.4 sogar als Fatal Error).
Egal ist es allerdings nicht ganz. Referenzen sollten nach Möglichkeit gar nicht benutzt werden und wenn doch, dann aus gutem Grund. Wenn man sauber objektorientiert arbeitet, braucht man sie in der Regel erst recht nicht.
Zitat:
Zitat von thotti
Oder anders: die folgenden Varianten sind praktisch(!) identisch?
1)
call_user_func($this->my_external_handler, $this);
[...]
function my_external_user_function($data)
2)
call_user_func($this->my_external_handler, &$this);
[...]
function my_external_user_function(&$data)
|
Das kommt darauf an, was du mit $data machst. Abgesehen davon, dass die zweite Variante wie gesagt ungültig ist, wirst du vermutlich dasselbe Resultat sehen, also ist es praktisch fast gleich, allerdings würde ich nicht behaupten „identisch“.
__________________
Hast du die Grundlagen zur Fehlersuche gelesen? Hast du Code-Tags benutzt? 
Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
Super, danke! 
|

01-07-2011, 14:15
|
|
thotti
Registrierter Benutzer
|
|
Registriert seit: Jul 2011
Beiträge: 5
|
|
Gelöst
Danke an alle!
|

01-07-2011, 14:18
|
|
h3ll
Registrierter Benutzer
|
|
Registriert seit: Mar 2008
Beiträge: 2.328
|
|
Zitat:
Zitat von thotti
die folgenden Varianten sind praktisch(!) identisch?
|
Nein. Ein $this als Referenz zu übergeben, macht generell keinen Sinn, weil $this nicht überschrieben werden kann.
Bei anderen Objekten wirkt es sich so aus:
PHP-Code:
function doSomething($object) { $object->bar = 2; $object = null; }
$foo = new foo(); $foo->bar = 1; doSomething($foo); var_dump($foo);
// object(foo)#1 (1) { // ["bar"]=> // int(2) // }
PHP-Code:
function doSomething(&$object) { $object->bar = 2; $object = null; }
$foo = new foo(); $foo->bar = 1; doSomething($foo); var_dump($foo);
// NULL
Wie du hier siehst, kann es ziemlich gefährlich werden, wenn du ein Objekt als Referenz übergibst, weil du so Objekte löschen/überschreiben kannst, die noch an anderer Stelle gebraucht werden. Deswegen ist ganz klar darauf zu verzichten.
Geändert von h3ll (01-07-2011 um 14:20 Uhr)
|

01-07-2011, 14:23
|
AmicaNoctis
 Moderatorin
|
|
Registriert seit: Jul 2009
Beiträge: 5.550
|
|
@h3ll: Genau, schönes Beispiel!
__________________
Hast du die Grundlagen zur Fehlersuche gelesen? Hast du Code-Tags benutzt? 
Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
Super, danke! 
|
|
Aktive Benutzer in diesem Thema: 1 (Registrierte Benutzer: 0, Gäste: 1)
|
|
|
| Themen-Optionen |
|
|
| Thema bewerten |
|
|
Forumregeln
|
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre Beiträge zu bearbeiten.
HTML-Code ist aus.
|
|
|
|
PHP News
|