<?xml version="1.0" encoding="utf-8"?><?xml-stylesheet title="XSL formatting" type="text/xsl" href="http://mirmodynamics.com/feed/rss2/xslt" ?><rss version="2.0"
  xmlns:dc="http://purl.org/dc/elements/1.1/"
  xmlns:wfw="http://wellformedweb.org/CommentAPI/"
  xmlns:content="http://purl.org/rss/1.0/modules/content/"
  xmlns:atom="http://www.w3.org/2005/Atom">
<channel>
  <title>Mirmo Dynamics - concepts</title>
  <link>http://mirmodynamics.com/</link>
  <atom:link href="http://mirmodynamics.com/feed/tag/concepts/rss2" rel="self" type="application/rss+xml"/>
  <description>Rien de grand ne se fit jamais sans enthousiasme.</description>
  <language>en</language>
  <pubDate>Thu, 02 Oct 2008 10:02:46 +0200</pubDate>
  <copyright>2003-2008 &amp;copy; Geoffrey Bachelet</copyright>
  <docs>http://blogs.law.harvard.edu/tech/rss</docs>
  <generator>Dotclear</generator>
  
    
  <item>
    <title>Ergonomie d'un blog</title>
    <link>http://mirmodynamics.com/post/2007/02/06/Ergonomie-dun-blog</link>
    <guid isPermaLink="false">urn:md5:07236eaaf779b167e98bc746cc86d29f</guid>
    <pubDate>Tue, 06 Feb 2007 10:27:00 +0100</pubDate>
    <dc:creator>Geoffrey</dc:creator>
        <category>Geekeries</category>
        <category>bonnes pratiques</category><category>clichés</category><category>concepts</category><category>ergonomie</category><category>interfaces utilisateurs</category><category>opinions</category>    
    <description>    &lt;p&gt;&lt;a href=&quot;http://www.biologeek.com/journal/index.php/ergonomie-d-un-blog-analyse-des-reponses&quot;&gt;Petite étude rapide sur l'ergonomie des blogs&lt;/a&gt;, chez Biologeek. Le panel représentatif est peut-être un peu faible, mais l'analyse compense :-)&lt;/p&gt;</description>
    
    
    
          <comments>http://mirmodynamics.com/post/2007/02/06/Ergonomie-dun-blog#comment-form</comments>
      <wfw:comment>http://mirmodynamics.com/post/2007/02/06/Ergonomie-dun-blog#comment-form</wfw:comment>
      <wfw:commentRss>http://mirmodynamics.com/feed/rss2/comments/742</wfw:commentRss>
      </item>
    
  <item>
    <title>Interfaces et Classes Abstraites</title>
    <link>http://mirmodynamics.com/post/2007/01/31/Interfaces-et-Classes-Abstraites</link>
    <guid isPermaLink="false">urn:md5:7eff991a33b1612a701afab5a0ed3233</guid>
    <pubDate>Wed, 31 Jan 2007 09:08:00 +0100</pubDate>
    <dc:creator>Geoffrey</dc:creator>
        <category>Coding</category>
        <category>bonnes pratiques</category><category>concepts</category><category>doc</category><category>oop</category><category>opinions</category><category>php</category>    
    <description>&lt;p&gt;Les concepts de classes abstraites et d'interfaces sont souvents assez flous quand on débute dans la programmation objet, et on se fourvoie assez souvent sur leur utilisation et leur but. Voila une petite explication qui j'espère sera 1) juste et 2) assez claire pour tout le monde. Si vous pensez que je me fourvoie sur ces 2 concepts de base de la &lt;acronym&gt;POO&lt;/acronym&gt;, n'hésitez pas à me le faire savoir !&lt;/p&gt;    &lt;p&gt;Commençons par le commencement: l'Interface. Une Interface définit une &lt;acronym&gt;API&lt;/acronym&gt; (Application Programming Interface), dont le seul et unique but est de décrire les méthodes disponibles pour un objet donné. Une Interface ne contient pas de code fonctionnel, seulement des synopsis de méthodes et d'attributs. Par exemple, l'utilisation du mot clé &amp;quot;instanceof&amp;quot; permet de déterminer si un objet donné implémente ou non une interface donnée, et d'adapter le comportement de l'application selon la réponse. Le &amp;quot;type hinting&amp;quot; permet également ce genre de choses:&lt;/p&gt;

&lt;pre&gt;
&amp;lt;?php

interface Bar_Interface {
      public function doSomething();
}

class Bar implements Bar_Interface {
      public function doSomething() {
            echo &amp;quot;something was done.&amp;quot;;
      }
}

class Foo {
      public function doSomething(Bar_Interface $bar) {
            $bar-&amp;gt;doSomething();
      }
}

?&amp;gt;
&lt;/pre&gt;


&lt;p&gt;Dans cet exemple, quand Foo::doSomething() est executée, on est certain que l'objet $bar dispose de la méthode doSomething car il implémente l'Interface Bar_Interface.&lt;/p&gt;


&lt;p&gt;Vient ensuite la classe abstraite. La classe abstraite, &amp;quot;abstract class&amp;quot; en V.O., se comporte comme un squelette d'objet. Elle est utile dans le cas où on utilise une série d'objets d'une même famille qui partagent du code commun, mais qui comportent tous leurs particularités propres. Dans ce cas de figure, on commence par implémenter le code commun dans la classe abstraite, dont hériteront les autres objets, dans lesquels le code spécifique pourra à son tour être implémenté. C'est très utile pour certains Design Pattern, comme par exemple &amp;quot;Adapter&amp;quot; ou &amp;quot;Proxy&amp;quot;, qui ont tous deux pour but de permettre des stratégies différentes pour une même situation, situation qui présente le plus souvent des points similaires quelque soit la stratégie adoptée.&lt;/p&gt;



&lt;p&gt;En règle générale, une classe abstraite implémente une interface (et un exemple d'Adapter en cadeau bonux):&lt;/p&gt;

&lt;pre&gt;
&amp;lt;?php

interface Bar_Adapter_Interface {
      public function doSomething();
}

class Bar {
      public function __construct(Bar_Adapter_Interface $adapter) {
            $this-&amp;gt;_adapter = $adapter;
      }

      public function doSomething() {
            return $this-&amp;gt;_adapter-&amp;gt;doSomething();
      }

      static public function factory($adapter) {
            $className = &amp;quot;Bar_Adapter_&amp;quot;.$adapter;
            if (!class_exists($className)) {
                  throw new Exception('Adapter not available: '.$adapter);
            } else {
                  return new Bar(new $className);
            }
      }
}

abstract class Bar_Adapter_Abstract implements Bar_Adapter_Interface {
      protected function getSomething() {
            return &amp;quot;la méthode pour accéder a ce truc est la même pour tout le monde&amp;quot;;
      }
}

class Bar_Adapter_Explode extends Bar_Adapter_Abstract {
      public function doSomething() {
            return explode(' ', $this-&amp;gt;getSomething());
      }
}

class Bar_Adapter_PregSplit extends Bar_Adapter_Abstract {
      public function doSomething() {
            return preg_split('/ /', $this-&amp;gt;getSomething());
      }
}

$bar = Bar::factory('Explode');
print_r($bar-&amp;gt;doSomething());

?&amp;gt;
&lt;/pre&gt;


&lt;p&gt;Ici, l'objet Bar offre la méthode doSomething, qui présentement retourne une chaine explosée, et on propose deux adapteurs pour se faire, l'un utilisant explode(), l'autre preg_split(). Bien sur, cet exemple est complètement trivial :-)&lt;/p&gt;</description>
    
    
    
          <comments>http://mirmodynamics.com/post/2007/01/31/Interfaces-et-Classes-Abstraites#comment-form</comments>
      <wfw:comment>http://mirmodynamics.com/post/2007/01/31/Interfaces-et-Classes-Abstraites#comment-form</wfw:comment>
      <wfw:commentRss>http://mirmodynamics.com/feed/rss2/comments/739</wfw:commentRss>
      </item>
    
</channel>
</rss>