Les conseils du créateur de NetNewsWire pour développer une app rapide

Nicolas Furno |

NetNewsWire est un client RSS pour macOS et iOS qui se distingue sur plusieurs points, mais notamment par sa rapidité. L’interface très simple et proche des standards de chaque plateforme évite au maximum les animations, ce qui donne une impression de vitesse à l’usage, mais l’app est aussi vraiment plus rapide que ses concurrentes dans toutes ses tâches. Brent Simmons, son principal développeur, explique sur son blog comment il a créé une app rapide.

N’espérez pas y trouver une solution facile, il n’y a pas de miracle : NetNewWire est une app rapide, parce que son créateur en a décidé ainsi dès le départ et parce qu’il a toujours fait très attention à ce point. Cela paraît évident, mais beaucoup de développeurs commencent par créer une app sans se soucier des performances ils ne s’intéressent à ce sujet que dans un deuxième temps.

NetNewsWire sur iPadOS.

Si vous suivez cette stratégie, votre app sera au mieux rapide qu’une partie du temps, quand vous avez le temps de vous pencher sur la question. Alors que Brent Simmons a décidé dès le départ que la performance sera au cœur de l’app, ce qui l’a obligé à prendre des décisions en respectant toujours ce critère. NetNewsWire a ainsi été rapide dès le premier jour et il devrait toujours le rester. En tout cas, tous les choix de développement sont liés à ce critère, ce qui n’est pas le cas de la majorité des apps.

L’article contient malgré tout quelques conseils pratiques utilisés pour NetNewsWire. Ils ne s’appliqueront pas forcément à votre app dans le détail, mais ils peuvent donner une idée des pistes à suivre pour placer la rapidité en tête des priorités. Par exemple, Brent Simmons a écrit son propre moteur pour lire le contenu des flux RSS, et il a utilisé pour cela une API de bas niveau, plus complexe et contraignante à mettre en place, mais qui offre des performances inégalées.

Autre exemple, NetNewsWire n’utilise pas CoreData pour stocker ses données, mais une base de données SQLite qui permet d’optimiser les requêtes ou encore d’avoir un système de cache très performant. Pour une app comme celle-ci, qui se résume en gros à extraire des informations depuis des flux RSS, les stocker dans une base de données et les afficher dans une interface, optimiser le stockage des données est un point essentiel.

L’autre point important concerne l’interface justement et Brent Simmons recommande de ne jamais utiliser les Stack Views et d’éviter d’utiliser Auto Layout dans les listes. Ces outils fournis par Apple simplifient le développement d’une app, mais ils ne sont pas aussi performants que des alternatives. C’est pourquoi les listes de flux RSS et d’articles dans NetNewsWire sont créées à la main, ce qui est plus fastidieux, mais c’est à ce prix que le défilement est aussi fluide.

Un extrait du code source de NetNewsWire affiché dans Xcode.

Les développeurs trouveront d’autres détails encore dans son article, mais on peut résumer l’esprit général en donnant deux points :

  • Penser aux performances dès le début et toujours garder cet objectif en tête ;
  • Mesurer continuellement les performances d’apps en utilisant les outils fournis par Apple et notamment Instruments, une app fournie avec Xcode qui peut servir à repérer les composants les plus lents d’une app.

NetNewsWire étant une app open-source codée en Swift, vous pouvez aussi consulter son code sur GitHub pour voir exactement comment ses développeurs ont réussi à créer une app rapide. Et si vous êtes juste un utilisateur, vous pouvez tester l’app en la téléchargeant gratuitement sur le site officiel pour les Mac ou sur l’App Store pour les iPhone et iPad.

Accédez aux commentaires de l'article