Technopedia Center
PMB University Brochure
Faculty of Engineering and Computer Science
S1 Informatics S1 Information Systems S1 Information Technology S1 Computer Engineering S1 Electrical Engineering S1 Civil Engineering

faculty of Economics and Business
S1 Management S1 Accountancy

Faculty of Letters and Educational Sciences
S1 English literature S1 English language education S1 Mathematics education S1 Sports Education
  • Registerasi
  • Brosur UTI
  • Kip Scholarship Information
  • Performance
  1. Weltenzyklopädie
  2. Interface (informatique) — Wikipédia
Interface (informatique) — Wikipédia 👆 Click Here! Read More..
Un article de Wikipédia, l'encyclopédie libre.
Si ce bandeau n'est plus pertinent, retirez-le. Cliquez ici pour en savoir plus.
Si ce bandeau n'est plus pertinent, retirez-le. Cliquez ici pour en savoir plus.

Cet article ne cite pas suffisamment ses sources (août 2022).

Si vous disposez d'ouvrages ou d'articles de référence ou si vous connaissez des sites web de qualité traitant du thème abordé ici, merci de compléter l'article en donnant les références utiles à sa vérifiabilité et en les liant à la section « Notes et références ».

En pratique : Quelles sources sont attendues ? Comment ajouter mes sources ?
Page d’aide sur l’homonymie

Pour les articles homonymes, voir interface.

Une interface définit la frontière de communication entre deux entités, comme des éléments de logiciel, des composants de matériel informatique, ou un utilisateur. Elle se réfère généralement à une image abstraite qu'une entité fournit d'elle-même à l'extérieur. Cela permet de distinguer les méthodes de communication avec l'extérieur et les opérations internes, et autorise à modifier les opérations internes sans affecter la façon dont les entités externes interagissent avec elle, en même temps qu'elle en fournit des abstractions multiples. On appelle aussi interfaces des dispositifs fournissant un moyen de traduction entre des entités qui n'utilisent pas le même langage, comme entre un être humain et un ordinateur. Étant donné que ces interfaces réalisent des traductions et des adaptations, elles entraînent des coûts de développement supplémentaires par rapport à des communications directes.

Variétés :

  • Une interface humain-machine permet des échanges entre un humain et une machine ;
  • Une interface de programmation permet des échanges entre plusieurs logiciels ;
  • L’interface qui est présentée à l’utilisateur est nommée interface utilisateur ;
  • Les interfaces entre des composants de matériel informatique sont des interfaces physiques.

Cet article traite des interfaces logicielles qui existent entre différents composants logiciels et fournissent un mode de programmation par lequel ces composants peuvent communiquer.[pas clair]

7 types d’interfaces en informatique.

Interfaces en pratique

[modifier | modifier le code]

Un élément de logiciel fournit l'accès aux ressources informatiques (comme la mémoire, le processeur, le stockage, etc.) par son système informatique sous-jacent ; laisser ces ressources accessibles par d'autres logiciels peut avoir des ramifications majeures — quelquefois désastreuses — pour ses fonctionnalités et sa stabilité. Un principe clé de conception est d'interdire l'accès à toutes les ressources par défaut, en autorisant l'accès seulement à travers des points d'entrée bien définis, i.e. les interfaces (voir encapsulation).

Les types d'accès que les interfaces fournissent entre les composants logiciels peuvent inclure : constantes, types de données, types de procédures, exception spécifications et signatures de méthodes. Dans certains cas, il peut être utile de définir dans l'interface des variables. On y spécifie souvent aussi la fonctionnalité des procédures et des méthodes incluses, soit par des commentaires ou (dans certains langages expérimentaux) par des assertions formelles logiques.

L'interface d'un module logiciel A {\displaystyle A} {\displaystyle A} est intentionnellement gardée rigoureusement séparée de l'implémentation de celui-ci. Ce dernier contient le code proprement dit des procédures et méthodes décrites dans l'interface (aux côtés du code des variables et procédures « privées »). Un module logiciel B {\displaystyle B} {\displaystyle B} qui utilise A {\displaystyle A} {\displaystyle A} (autrement dit un client de A) n'y accède pas directement, il y accède uniquement par le travers de l'interface de A {\displaystyle A} {\displaystyle A}. L'utilisation d'interfaces offre ainsi l'avantage qu'un remplacement d'implémentation de A {\displaystyle A} {\displaystyle A} par une autre, répondant aux mêmes spécifications de l'interface, ne peut causer de défaillance d'un module client B {\displaystyle B} {\displaystyle B} — si tant est bien sûr que son utilisation de A {\displaystyle A} {\displaystyle A} se conforme aux spécifications de l'interface (voir aussi principe de substitution de Liskov).

Utilisation des interfaces

[modifier | modifier le code]

Le concept d'interface est la pierre angulaire de la programmation modulaire, un précurseur et un élément standard de la programmation orientée objet. Dans la programmation orientée objet, l'interface d'un objet consiste en un ensemble de méthodes que l'objet doit suivre. C'est le « contrat de service » du composant. Les variables d'instance de l'objet ne font pas partie de l'interface - on y accède spécifiquement via des accesseurs.

Certains langages orientés-objet nécessitent de définir séparément l'interface et l'implémentation. Par exemple, en Objective-C, l'interface est définie dans un fichier d'en-tête et l'implémentation dans un fichier source. Par exemple, de par le typage et le chargement dynamique d'Objective-C, il est possible d'envoyer un message à n'importe quel objet, l'interface spécifiant quelle méthode doit y répondre (parmi les méthodes de la classe de l'objet et les méthodes des classes parentes).

Les interfaces sont historiquement dérivées des fichiers d'entête C avec un contexte et un contenu restreints, devenant une partie de la sémantique du langage (par opposition aux fonctionnalités du préprocesseur C).

Le langage Java adopte une approche différente du concept d'interface qui existe normalement dans d'autres langages orientés objet (ie., que l'interface spécifiée est l'interface avec la classe), en ce qu'une interface spécifie un ensemble de méthodes qui implémente des fonctionnalités spécifiques, communes à un ensemble de classes. Voir protocole (programmation orientée objet).

Certains langages de programmation (e.g. D, Java, Logtalk) autorisent la définition de hiérarchies d'interface. Ceci autorise une définition de, par exemple, à la fois la version minimale et étendue d'une interface.

Certains langages de programmation (e.g. Logtalk) supportent une implémentation privée et protégée d'une interface. Ainsi, les méthodes (publiques) déclarées dans une interface peuvent facilement devenir des méthodes privées ou protégées d'une classe qui implémente l'interface.

Le langage Eiffel inclut dans l'interface d'une classe son invariant et la pré- et postconditions des méthodes de la classe. Ceci est essentiel à la méthodologie de conception par contrat, et peut être considéré comme une extension des conditions imposées par les types d'arguments. Ces règles peuvent être spécifiées dans l'implémentation d'une classe ou dans un ancêtre qui peut quitter les méthodes non implémentées.

Ces règles peuvent être extraites dans l'environnement de développement par l'analyseur syntaxique afin de fournir à l'utilisateur une vue de l'interface de ces classes. Au niveau de la compilation, elles permettent de définir des assertions c'est-à-dire des conditions déclenchant des exceptions ; on parle de contrat de la méthode.

Exemple de contrat d'une fonction « division(numérateur, diviseur) » recevant numérateur et diviseur en paramètres : si le diviseur est égal à zéro, je déclenche une assertion sinon j'effectue une division.

Les assertions peuvent avoir des comportements différents selon le mode debug ou release : généralement en mode debug l'application s'arrête ce qui permet de repérer l'erreur contrairement au mode release qui favorise la continuité de service.

Dans l'exemple de la division, l'assertion provoquerait en mode debug l'arrêt du programme et en release renverrait la valeur zéro.

Le langage assure aussi que les classes dérivées obéissent aux contrats de leurs ancêtres.

Langages qui fournissent des facilités d'interfaçage

[modifier | modifier le code]

Certains langages de programmation ont différentes méthodologies pour permettre la réalisation d'interfaces. En général, tout langage de programmation peut implémenter une interface, mais les langages de programmation suivants offrent des facilités d'interfaçage spécifiques d'une façon ou d'une autre :

ActionScript in Flash, Ada, C#, C (langage), D, Delphi, Eiffel, Java, Logtalk, Mesa, ML, Modula, Modula-2, Modula-3, Oberon, Objective-C, PHP, Ocaml, Python, REALbasic, Unified Modeling Language, Visual Basic

Interfaces de programmation

[modifier | modifier le code]

Une interface de programmation (Application Programming Interface ou API) définit les fonctions publiées par une bibliothèque logicielle, utilisables par les applications clientes.

En science de la communication

[modifier | modifier le code]

En sciences de l'information et de la communication, l’interface est un empilement de couches, depuis le support physique de l'information jusqu'à sa diffusion dans la société.

En électronique

[modifier | modifier le code]

Dans le cas de l’électronique, il est utile de détailler la couche physique précédemment décrite et commode de réunir les suivantes. L’interface peut alors être définie par quatre couches :

  1. Physique : définition des broches de connexion (nombre, disposition), configuration mécanique des connecteurs (NB : cette couche peut être absente de certaines définitions relâchées d’une interface)
  2. Électrique : mode de pilotage (tension/courant) des signaux, niveaux de tension (ou de courant) définissant les états de chaque signal, vitesses minimale et maximale de commutation, temps d’établissement et/ou de maintien (par rapport à d’autres signaux), etc.
  3. Logique : nom des signaux et alimentations véhiculés par les broches du/des connecteur(s), sens de distribution (ou éventuellement bidirectionnalité)
  4. Protocolaire : rapport des signaux entre eux, signification des successions d’événements sur un signal ou un groupe de signaux, interdits, etc.

Notes et références

[modifier | modifier le code]

Voir aussi

[modifier | modifier le code]

Articles connexes

[modifier | modifier le code]
  • Héritage
  • Programmation orientée composant
  • Modularité
  • Application binary interface
  • Bus informatique
  • Interface description language, ou 'IDL'

Liens externes

[modifier | modifier le code]

  • Notices dans des dictionnaires ou encyclopédies généralistesVoir et modifier les données sur Wikidata :
    • Britannica
    • Den Store Danske Encyklopædi
    • Gran Enciclopèdia Catalana
  • Notices d'autoritéVoir et modifier les données sur Wikidata :
    • GND
    • Israël
    • Tchéquie
v · m
Éléments de programmation informatique
Bibliothèque logicielle
  • Bibliothèque standard
  • Espace de noms
  • Framework
  • Gabarit
  • Interface
  • Interface de programmation (API)
Vocabulaire
  • Algorithme
  • Expression
  • Indentation
  • Instruction
  • Ligne de code
  • Opérateur
  • Pseudo-code
  • Ramasse-miettes
Fonctions
  • Dispatch multiple
  • Factorisation
  • Fonction imbriquée
  • Fonction de rappel
  • Fonction d'ordre supérieur
  • Fonction récursive
  • Généricité
  • Opérande
  • Paramètre
  • Polymorphisme
  • Procédure
  • Signature de type
  • Surcharge
Objet
  • Classe
  • Constructeur
  • Destructeur
  • Encapsulation
  • Héritage
  • Héritage multiple
  • Instance
  • Méthode
Événementiel Inversion de contrôle
Code source
Structures de données
  • Arbre
  • Enregistrement
  • Ensemble
  • File
  • Liste
  • Liste chaînée
  • Pile
  • Sémaphore
  • Tableau
  • Tas
  • Type abstrait
  • Vecteur
Déclarations
  • Affectation
  • Convention de nommage
  • Pointeur
  • Portée
  • Référence
  • Tableau associatif
  • Type énuméré
  • Type récursif
  • Typage statique
  • Variable
  • Variable globale
  • Variable locale
Structures de contrôle
  • Case
  • Eval
  • For
  • Goto
  • Switch
  • While
Fonctions usuelles
  • Concaténation
  • Incrémentation
  • malloc
  • printf
Outil de développement
  • Environnement de développement
  • Générateur de documentation
  • Gestion de versions
  • Modèle
  • Patch
  • Spécification
Folklore
  • Hello world
  • Principe KISS
  • Langage de programmation exotique
Catégories :
  • Programmation informatique
  • Développement logiciel
  • icône décorative Portail de la programmation informatique
  • icône décorative Portail de l’informatique
Ce document provient de « https://fr.teknopedia.teknokrat.ac.id/w/index.php?title=Interface_(informatique)&oldid=225421738 ».
Catégorie :
  • Terminologie de l'informatique
Catégories cachées :
  • Article manquant de références depuis août 2022
  • Article manquant de références/Liste complète
  • Page utilisant un modèle Bases inactif
  • Page utilisant P1417
  • Page utilisant P8313
  • Page utilisant P1296
  • Page pointant vers des bases externes
  • Page pointant vers des dictionnaires ou encyclopédies généralistes
  • Article de Wikipédia avec notice d'autorité
  • Portail:Programmation informatique/Articles liés
  • Portail:Informatique/Articles liés
  • Portail:Technologies/Articles liés

  • indonesia
  • Polski
  • الرية
  • Deutsch
  • English
  • Español
  • Français
  • Italiano
  • مصر
  • Nederlands
  • 本語
  • Português
  • Sinugboanong Binisaya
  • Svenska
  • Українска
  • Tiếng Việt
  • Winaray
  • 中文
  • Русски
Sunting pranala
Pusat Layanan

UNIVERSITAS TEKNOKRAT INDONESIA | ASEAN's Best Private University
Jl. ZA. Pagar Alam No.9 -11, Labuhan Ratu, Kec. Kedaton, Kota Bandar Lampung, Lampung 35132
Phone: (0721) 702022
Email: pmb@teknokrat.ac.id