PHP Klassenversteh problem
Micha
- php
0 Marc Reichelt0 Tom0 Marc Reichelt0 Tom
0 dedlfix
Habe kein kleines Verständnisproblem:
class foo
{
var $test;
function bar(){
$this->test;
}
}
Mit $this->test; wäre ja hier die Variable $test gemeint. Nun habe ich Klasse gefunden die so aussieht:
class foo
{
function bar(){
$this->test;
}
}
Wie verstehe ich hier $this->test;?
Gruß
Micha
Hallo Micha,
class foo
{
var $test;
function bar(){
$this->test;
}
}Mit $this->test; wäre ja hier die Variable $test gemeint. Nun habe ich Klasse gefunden die so aussieht:
class foo
{
function bar(){
$this->test;
}
}Wie verstehe ich hier $this->test;?
Ist fehlerhaft (soeben ausgetestet). Bei error_reporting(E_ALL) gibt er eine Notiz aus, wenn man von der Klasse ein Objekt anlegt und die Funktion bar() aufruft.
Das Beispiel oben ist korrekt.
Grüße
Marc Reichelt || http://www.marcreichelt.de/
Hello,
class foo
{
var $test;
function bar(){
$this->test;
}
}Mit $this->test; wäre ja hier die Variable $test gemeint. Nun habe ich Klasse gefunden die so aussieht:
class foo
{
function bar(){
$this->test;
}
}Wie verstehe ich hier $this->test;?
Ist fehlerhaft (soeben ausgetestet). Bei error_reporting(E_ALL) gibt er eine Notiz aus, wenn man von der Klasse ein Objekt anlegt und die Funktion bar() aufruft.
Das Beispiel oben ist korrekt.
Was soll das denn auch bewirken?
$this->test;
ist eine unvollständige Anweisung. Es ist weder eine Ausgabeanweisung, noch eine Zuweisung noch eine Rechenoperation... Der Parser nimmt daher an, dass auf $this->test als Datenquelle referenziert werden soll, was natürlich nicht geht (glücklicherweise), wenn es noch keine Instanz dieses (unbestimmten) Typs gibt.
Harzliche Grüße vom Berg
esst mehr http://www.harte-harzer.de
Tom
Hallo Tom,
Was soll das denn auch bewirken?
$this->test;
ist eine unvollständige Anweisung.
Jupp. Aber in PHP ist das sogar gültig (auch wenn bei E_ALL eine Notiz (sprich: keine Warnung) ausgegeben wird). Danach ist die Variable AFAIK initialisiert.
Sauber ist es hingegen nicht - und deshalb habe ich einfach gesagt es ist falsch. ;-)
Grüße
Marc Reichelt || http://www.marcreichelt.de/
Hello,
Jupp. Aber in PHP ist das sogar gültig (auch wenn bei E_ALL eine Notiz (sprich: keine Warnung) ausgegeben wird). Danach ist die Variable AFAIK initialisiert.
Nö, nicht dass ich wüsste. Das wäre ja schlimm, wenn eine Variable "initialisiert" wird, nur weil man darauf (lesend) zugreift. Kannst Du ja auch ganz einfach ausprobieren, indem du das Konstrukt einfach mehrmals in den Source schreibst. Wenn Du dann für jedes Vorkommen eine Notice kassierst, ist auch nix initialisiert worden...
Harzliche Grüße vom Berg
esst mehr http://www.harte-harzer.de
Tom
Hallo Tom,
Nö, nicht dass ich wüsste. Das wäre ja schlimm, wenn eine Variable "initialisiert" wird, nur weil man darauf (lesend) zugreift. Kannst Du ja auch ganz einfach ausprobieren, indem du das Konstrukt einfach mehrmals in den Source schreibst. Wenn Du dann für jedes Vorkommen eine Notice kassierst, ist auch nix initialisiert worden...
Du hast Recht.
<?php
error_reporting(E_ALL);
class foo {
function bar() {
$this->test;
echo $this->test;
}
}
$myFoo = new foo();
$myFoo->bar();
?>
Der Aufruf der Datei erzeugt ohne error_reporting(E_ALL) keine Ausgabe, mit gibt es jedoch zwei Notices aus - beide Male, weil die Variable undefiniert ist.
Ersetzt man die Zeile mit
$this->test;
jedoch durch
$this->test = "bar\n";
so gibt es auch keine Notices - weil er dann die Variable anlegt.
Da sieht man halt doch wieder, dass die Vorschriften von PHP etwas lax sind. Da ich PHP 4 verwende, würde ich aber doch gerne wissen, ob der Code oben (inklusive Zuweisung von "bar\n") in PHP 5 genausowenig Warnungen ausgibt.
Grüße
Marc Reichelt || http://www.marcreichelt.de/
Hallo Marc.
Da ich PHP 4 verwende, würde ich aber doch gerne wissen, ob der Code oben (inklusive Zuweisung von "bar\n") in PHP 5 genausowenig Warnungen ausgibt.
PHP5 reagiert wie PHP4.
Einen schönen Dienstag noch.
Gruß, Ashura
echo $begrüßung;
$this->test = "bar\n";
so gibt es auch keine Notices - weil er dann die Variable anlegt.
Da sieht man halt doch wieder, dass die Vorschriften von PHP etwas lax sind.
Das ist nun mal das Konzept von PHP, dass Variablen implizit angelegt werden und nicht deklariert werden müssen. Es muss noch nicht mal ein Objekt vorhanden sein, um einer Objektvariable etwas zuzuweisen. Dann wird eben zu dem Zeitpunkt ein neues Objekt erzeugt, dessen Klasse stdClass ist.
$a->b = 42;
var_dump($a);
ergibt:
object(stdClass)#1 (1) {
["b"]=>
int(42)
}
echo "$verabschiedung $name";
echo $begrüßung;
class foo
{
function bar(){
$this->test;
}
}Wie verstehe ich hier $this->test;?
Wie in PHP üblich muss man Variablen vor Gebrauch nicht deklarieren. Das gilt auch für Objekt-Variablen. Beim ersten Schreibzugriff werden sie angelegt, wenn sie bis dato noch nicht vorhanden waren.
echo "$verabschiedung $name";