Zend_Date-Theory.xml 3.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!-- EN-Revision: 15343 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.date.definition.theory">
  5. <title>Aspect théorique</title>
  6. <para>
  7. Pourquoi n'existe-il que l'unique classe <classname>Zend_Date</classname> pour gérer
  8. les dates et les heures dans Zend Framework&#160;?
  9. </para>
  10. <para>
  11. Beaucoup de langages divisent la gestion des heures et des dates de calendrier en
  12. deux classes. Cependant Zend Framework lutte pour une extrême simplicité, et forcer le
  13. développeur à gérer différents objets avec différentes méthodes pour les heures et les
  14. dates entraîne un fardeau dans beaucoup de situations. Puisque les méthodes de
  15. <classname>Zend_Date</classname> supporte le travail avec des dates ambiguës qui
  16. n'incluraient pas toutes les parties (ère, année, mois, jour, heure, minute, seconde,
  17. décalage horaire), les développeurs aiment la flexibilité et la facilité d'utilisation
  18. d'une même classe et des mêmes méthodes afin de réaliser les mêmes actions par exemple
  19. addition, soustraction, comparaison, fusion de parties de dates, etc.). Diviser la gestion
  20. de ces fragments de date dans de multiples classes pourraient entraîner des complications
  21. quand on souhaite réaliser des inter-opérations. Une unique classe réduit la duplication de
  22. code pour des opérations similaires, sans l'obligation d'une hiérarchie d'héritage
  23. complexe.
  24. </para>
  25. <sect2 id="zend.date.theory.internals">
  26. <title>Fonctionnement interne</title>
  27. <para>
  28. <itemizedlist mark="opencircle">
  29. <listitem>
  30. <para>Référence temporelle UNIX (timestamp)&#160;:</para>
  31. <para>
  32. Toutes les dates et heures, même celles ambiguës (par exemple sans
  33. année), sont représentées en interne par des moments absolus dans le temps,
  34. stockés en tant que référence temporelle UNIX exprimant la différence entre
  35. le moment désiré et le 1er janvier 1970 à 00:00:00 GMT. Ceci est seulement
  36. possible, parce que <classname>Zend_Date</classname> n'est pas limité aux
  37. références temporelles UNIX ou aux valeurs entières. L'extension BCMath est
  38. requise pour supporter les très grandes dates hors de la plage du Vendredi
  39. 13 décembre 1901 à 20:45:54 GMT au Mardi 19 janvier 2038 à 03:14:07 GMT. De
  40. plus de petites erreurs mathématiques peuvent apparaître causées par les
  41. limitations inhérentes aux types de données float et aux arrondis, à moins
  42. d'utiliser l'extension BCMath.
  43. </para>
  44. </listitem>
  45. <listitem>
  46. <para>
  47. Parties de date en tant que décalages de référence temporelle&#160;:
  48. </para>
  49. <para>
  50. Ainsi, une instance d'objet représentant trois heures peut être
  51. exprimé en tant que trois heures après le 1er janvier 1970 à 00:00:00 GMT -
  52. c'est-à-dire 0 + 3 * 60 * 60 = 10800.
  53. </para>
  54. </listitem>
  55. <listitem>
  56. <para>Fonctions PHP&#160;:</para>
  57. <para>
  58. Quand cela est possible, <classname>Zend_Date</classname> utilise
  59. actuellement les fonctions PHP pour améliorer les performances.
  60. </para>
  61. </listitem>
  62. </itemizedlist>
  63. </para>
  64. </sect2>
  65. </sect1>