<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>LocalDev &#187; OOP</title>
	<atom:link href="http://localdev.de/tags/oop/feed/" rel="self" type="application/rss+xml" />
	<link>http://localdev.de</link>
	<description>Web, Desktop &#38; Mobile Development</description>
	<lastBuildDate>Mon, 12 Jul 2010 15:39:16 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.0</generator>
		<item>
		<title>PHP: Welche Interfaces implementiert eine Klasse</title>
		<link>http://localdev.de/2010/04/php-welche-interfaces-implementiert-eine-klasse-reflection/</link>
		<comments>http://localdev.de/2010/04/php-welche-interfaces-implementiert-eine-klasse-reflection/#comments</comments>
		<pubDate>Sun, 11 Apr 2010 21:22:31 +0000</pubDate>
		<dc:creator>Fabian Martin</dc:creator>
				<category><![CDATA[PHP]]></category>
		<category><![CDATA[Feature]]></category>
		<category><![CDATA[Interface]]></category>
		<category><![CDATA[Klasse]]></category>
		<category><![CDATA[Objekt]]></category>
		<category><![CDATA[OOP]]></category>

		<guid isPermaLink="false">http://localdev.de/?p=681</guid>
		<description><![CDATA[Auf Phpmonkeys ist letzte Woche ein Artikel über Marker Interfaces erschienen, der einem kurz die Idee dahinter erläutert und wie man sie am Beispiel eines Caches nutzen kann. Ich selber nutze Marker Interfaces in verschiedenen Projekten um darüber zu bestimmen, ob ein bestimmtes Feature für ein Objekt zur Verfügung steht. Ich vereinfache damit u.a. die [...]]]></description>
			<content:encoded><![CDATA[<p>Auf <a href="http://www.phpmonkeys.de/">Phpmonkeys</a> ist letzte Woche ein Artikel über <a href="http://www.phpmonkeys.de/2010/04/06/marker-interfaces-ein-beispiel/">Marker Interfaces</a> erschienen, der einem kurz die Idee dahinter erläutert und wie man sie am Beispiel eines Caches nutzen kann. </p>
<p>Ich selber nutze Marker Interfaces in verschiedenen Projekten um darüber zu bestimmen, ob ein bestimmtes Feature für ein Objekt zur Verfügung steht. Ich vereinfache damit u.a. die Generierung des Administrations Oberfläche. Aber wie bekommt man heraus, welche Interfaces eine Klasse implementiert?</p>
<p>Wir haben die Möglichkeit über <em>instanceof</em> und <em>is_a</em> zu prüfen ob eine bestimmtes Interface implementiert wird, oder wir lassen uns von den Reflection Klassen, die seit PHP 5.0 zur Verfügung stehen, alle implementierten Interfaces zurückgeben.</p>
<p><strong>Unsere Testobjekte</strong></p>
<pre class="brush: php;">
interface AdminFeature
{

}

class Admin implements AdminFeature
{

}

$objAdmin = new Admin();
</pre>
<p><strong>Instanz der Reflection Klasse erzeugen</strong></p>
<pre class="brush: php;">
$objReflection = new ReflectionClass('Admin');

// Oder direkt vom Objekt
// $objReflection = new ReflectionClass($objAdmin);
</pre>
<p>Die Reflection Klasse enthält die Methoden <em>getInterfaceNames</em> und <em>getInterfaces</em>, die uns alle genutzten Interfaces zurückgeben. Möchten wir auf ein bestimmtes Interface prüfen, stehen uns die Methode <em>implementsInterface</em> bzw. die Prüfung mittels <em>instanceof</em> und <em>is_a</em> zur Verfügung.</p>
<p><strong>getInterfaceNames</strong><br />
getInterfaceNames gibt uns ein Array mit den Namen der Interfaces zurück.</p>
<pre class="brush: php;">
$arrResult = $objReflection-&gt;getInterfaceNames();

/*
array(1) {
  [0]=&gt;
  string(12) &quot;AdminFeature&quot;
}
*/
</pre>
<p><strong>getInterfaces</strong><br />
getInterfaces gibt uns ein Array mit allen Interfaces zurück. Die Elemente des Arrays enthalten für jedes Interface ein Objekt der Relection Klasse.</p>
<pre class="brush: php;">
$arrResult = $objReflection-&gt;getInterfaces();

/*
array(1) {
  [&quot;AdminFeature&quot;]=&gt;
  &amp;object(ReflectionClass)#3 (1) {
    [&quot;name&quot;]=&gt;
    string(12) &quot;AdminFeature&quot;
  }
}
*/
</pre>
<p><strong>implementsInterface, instanceof und is_a</strong><br />
Haben wir ein Objekt der Klasse erzeugt, können wir instanceof und is_a nutzen um herauszufinden, ob die gewünschte Klasse implementiert wird. Der Weg über die Reflection Klasse ist hier nicht nötig.</p>
<p>Möchten wir vor der Erzeugung des Objekts herausfinden, ob ein Interface implementiert wird, können wir die Methode implementsInterface unseres Reflection Objekts nutzen.</p>
<pre class="brush: php;">
$boolReturn = $objReflection-&gt;implementsInterface('AdminFeature');
// bool(true)
$boolReturn = $objAdmin instanceof AdminInterface;
// bool(true)
$boolReturn = is_a($objAdmin, 'AdminInterface');
// bool(true)
</pre>
<p>is_a ist seit PHP 5.3 übrigens nicht mehr als deprecated markiert.</p>
<p>Über Reflection kann man aber mehr als nur die Interfaces ermitteln. Wer möchte kann sich z.B. die Kommentare zurückgeben lassen und über diese z.B <a href="http://de.wikipedia.org/wiki/Annotation_(Programmierung)">Annotations</a> implementieren. Ein Blick ins <a href="http://de2.php.net/manual/de/book.reflection.php">PHP Handbuch</a> lohnt sich. </p>
]]></content:encoded>
			<wfw:commentRss>http://localdev.de/2010/04/php-welche-interfaces-implementiert-eine-klasse-reflection/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>PHP: Getter und Setter mit PDT generieren</title>
		<link>http://localdev.de/2010/02/php-getter-und-setter-mit-pdt-generieren/</link>
		<comments>http://localdev.de/2010/02/php-getter-und-setter-mit-pdt-generieren/#comments</comments>
		<pubDate>Fri, 05 Feb 2010 11:40:25 +0000</pubDate>
		<dc:creator>Fabian Martin</dc:creator>
				<category><![CDATA[PHP]]></category>
		<category><![CDATA[Software]]></category>
		<category><![CDATA[Tipps & Tricks]]></category>
		<category><![CDATA[Eclipse]]></category>
		<category><![CDATA[Getter]]></category>
		<category><![CDATA[Klassen]]></category>
		<category><![CDATA[Kostenlos]]></category>
		<category><![CDATA[OOP]]></category>
		<category><![CDATA[PDT]]></category>
		<category><![CDATA[Properties]]></category>
		<category><![CDATA[Setter]]></category>

		<guid isPermaLink="false">http://localdev.de/?p=518</guid>
		<description><![CDATA[Eine Möglichkeit, automatisch Getter und Setter mit PDT zu generieren, habe ich noch nicht gefunden. Mit dem unten genannten Code, könnt Ihr das Erstellen von Gettern und Settern mit PDT aber beschleunigen. Erstellt hierzu ein neues Code Template (Window -> Preferences -> PHP -> Editor -> Templates) und gebt ihm den Namen &#8216;get&#8217;. In das [...]]]></description>
			<content:encoded><![CDATA[<p>Eine Möglichkeit, automatisch Getter und Setter mit PDT zu generieren, habe ich noch nicht gefunden. Mit dem unten genannten Code, könnt Ihr das Erstellen von Gettern und Settern mit PDT aber beschleunigen.</p>
<p>Erstellt hierzu ein neues Code Template (<em>Window</em> -> <em>Preferences</em> -> <em>PHP</em> -> <em>Editor</em> -> <em>Templates</em>) und gebt ihm den Namen &#8216;get&#8217;. In das Feld Pattern, fügt ihr den unten gezeigten Code ein.</p>
<p>Um nun Getter und Setter zu generieren, müsst ihr nur noch &#8216;get&#8217; in euren Editor tippen und die Tastenkombination STRG+Leertaste drücken. Der Code sollte erscheinen und der Cursor in der ersten Variable blinken. Mit Tab könnt ihr zwischen den Werten springen.</p>
<pre class="brush: php;">
/**
* Legt ${field} fest
*
* @param ${type} ${dollar}${field}
* @return void
*/
public function set${funcName}(${dollar}${field})
{
	${dollar}this-&gt;${field} = ${dollar}${field};
}

/**
* Gibt ${field} zurück
*
* @return ${type}
*/
public function get${funcName}()
{
	return ${dollar}this-&gt;${field};
}
</pre>
<p>Das ganze geht natürlich auch mit statischen Werten:</p>
<pre class="brush: php;">
/**
* Legt ${field} fest
*
* @param ${type} ${dollar}${field}
* @return void
*/
public static function set${funcName}(${dollar}${field})
{
	self::${dollar}${field} = ${dollar}${field};
}

/**
* Gibt ${field} zurück
*
* @return ${type}
*/
public static function get${funcName}()
{
	return self::${dollar}${field};
}
</pre>
]]></content:encoded>
			<wfw:commentRss>http://localdev.de/2010/02/php-getter-und-setter-mit-pdt-generieren/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

<!-- Performance optimized by W3 Total Cache. Learn more: http://www.w3-edge.com/wordpress-plugins/

Minified using memcached
Page Caching using memcached
Database Caching 6/12 queries in 0.004 seconds using memcached

Served from: localdev.de @ 2010-07-29 21:54:30 -->