Maison > Java > javaDidacticiel > le corps du texte

Explication détaillée du principe ouvert et fermé en Java

黄舟
Libérer: 2017-08-09 14:10:44
original
2392 Les gens l'ont consulté

Définition : Les entités logicielles (classes, modules, fonctions, etc.) doivent être extensibles mais non modifiables. Ouvert pour expansion, fermé pour changement. La clé est l’abstraction, séparant clairement les parties générales d’une fonctionnalité des détails de mise en œuvre.

Ici, nous devons avoir des concepts abstraits lors de l'écriture du code. Qu’est-ce que l’abstraction ? Fait référence au processus de réflexion consistant à faire abstraction des concepts des entités. Il s’agit d’extraire des caractéristiques essentielles communes à de nombreux objets. Dans le processus d'écriture de code, où une classe abstraite est nécessaire, il suffit de saisir la fonction essentielle de cette classe, et de ne pas toujours penser à sa fonction spécifique dans ce projet.

Continuons à regarder le principe ouvert et fermé. Ce principe nécessite que la partie partagée et la partie implémentation d'une fonction soient clairement séparées. Parce que vous ne pouvez pas prédire tous les changements qui se produiront lors de la première construction de l'architecture, cette classe ne restera pas inchangée. Au fur et à mesure que vous l'implémenterez dans chaque module, vous constaterez que la classe abstraite est adaptée à cette fonction, mais ce n'est pas le cas. adapté à une autre fonction. Alors, voulez-vous revenir en arrière et modifier la classe abstraite ? Ce coût est très élevé et nécessite de repenser et d’ajuster des détails spécifiques. Il est préférable que le programme n'ait pas encore été publié, revenir en arrière pour modifier la classe abstraite aura un plus grand impact. Par conséquent, lorsque nous commençons à faire abstraction, nous devons empêcher ce phénomène de se produire et suivre le principe ouvert et fermé. Les classes abstraites et les interfaces sont des standards. Une fois définies dans un programme, elles ne peuvent pas être facilement modifiées. Que dois-je faire si les exigences changent ? Vous pouvez étendre cette interface, réécrire des méthodes ou ajouter de nouvelles méthodes après l'héritage, mais veillez à ne pas la modifier.

Deux exemples sont utilisés ci-dessous pour illustrer le principe ouvert-fermé.

1. Connectez-vous à la base de données à titre d'exemple.

Par exemple, les différents types de connexions aux bases de données utilisées dans le programme, Access et Oracle. La connexion directe est la suivante :


class ConnectAccess 
{ 
  public string ConnectString() 
  { 
    string dataPath = "数据库路径"; 
    return string.Format("Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};Persist Security Info=True;Jet OLEDB:Database Password={1}", dataPath, "密码"); 
  } 
} 
class ConnectOracle 
{ 
  public string ConnectString() 
  { 
    return @"server=localhost;database=命名空间;uid=用户名;pwd=密码"; 
  } 
}
Copier après la connexion

Appeler


static void Main(string[] args) 
 { 
   //连接Access 
  ConnectAccess connAccess = new ConnectAccess(); 
 
  OleDbConnection accessConnection = new OleDbConnection(connAccessConnectString()); 
 
   //连接Oracle 
  ConnectOracle connOracle = new ConnectOracle(); 
 
  OracleConnection oracleConnection = new OracleConnection(connOracleConnectString()); 
 }
Copier après la connexion

comme ça à chaque fois. Vous devez réfléchir aux paramètres d'OleDbConnection à utiliser. Modifiez-le ci-dessous. Résumé d'une interface.


interface ConnectDataBase 
{ 
  string ConnectString(); 
} 
 
class ConnectAccess : ConnectDataBase 
{ 
  #region ConnectDataBase 成员 
 
  public string ConnectString() 
  { 
    string dataPath = "数据库路径"; 
 
    return stringFormat("Provider=MicrosoftJetOLEDB0;Data Source={0};Persist Security Info=True;Jet OLEDB:Database Password={1}", dataPath, "密码"); 
  } 
 
  #endregion 
} 
 
class ConnectOracle : ConnectDataBase 
{ 
  #region ConnectDataBase 成员 
 
  public string ConnectString() 
  { 
    return @"server=localhost;database=命名空间;uid=用户名;pwd=密码"; 
  } 
 
  #endregion 
}
Copier après la connexion

Appeler


static void Main(string[] args) 
{ 
  ConnectDataBase conn = null; 
 
  //连接Access 
  conn = new ConnectAccess(); 
 
  OleDbConnection accessConnection = new OleDbConnection(connConnectString()); 
 
  //连接Oracle 
  conn = new ConnectOracle(); 
 
  OracleConnection oracleConnection = new OracleConnection(connConnectString()); 
}
Copier après la connexion

Après le changement, il vous suffit se soucier de conn Quelle que soit la classe que vous utilisez pour instancier, c'est très bien. Cependant, vous constaterez peut-être que, puisque la connexion Oracle nécessite OracleConnection, les avantages peuvent ne pas être faciles à voir.

2. Prenez le type de base comme paramètre de méthode à titre d'exemple.

C'est la raison pour laquelle les principes généraux de conception soulignent que les paramètres de méthode doivent éviter autant que possible les types de base. Comparez les deux définitions de méthodes suivantes :


//定义1  
bool Connect(string userName, string password, string wifiAddress, int port) 
{ 
  return false; 
}
Copier après la connexion


//定义2  
bool Connect(Account account) 
{ 
  return false; 
}
Copier après la connexion


public class Account 
{ 
  public string UserName 
  { 
    get; 
    set; 
  } 
  public string Password 
  { 
    get; 
    set; 
  } 
  public string WifiAddress 
  { 
    get; 
    set; 
  } 
  public int Port 
  { 
    get; 
    set; 
  } 
}
Copier après la connexion

En comparaison, la définition 2 a une définition de classe Account supplémentaire, et la méthode Connect() est évidemment plus stable. Si la méthode Connect() wifiAddress change, la définition 1 doit modifier l'interface de la méthode, et par conséquent, tous les objets qui appellent la méthode Connect() seront affectés tandis que la définition 2 n'a besoin que de modifier la classe Account, car l'interface de la méthode Connect() reste inchangée et l'appelant de la méthode Connect() n'a pas besoin de wifiAddress. Une telle modification n'affectera pas du tout l'appelant, réduisant ainsi l'impact des changements de demande.

En bref, la clé du principe ouvert et fermé est l'abstraction, mais cela ne signifie pas qu'une fois l'interface et la classe abstraites déterminées, elles ne doivent pas être modifiées. Cependant, lorsque nous faisons de l'abstraction, nous devons réfléchir de manière globale et nous efforcer d'éviter les modifications. Une fois les exigences modifiées, il suffit d'apporter des modifications pendant la mise en œuvre. Bien entendu, les besoins évoluent constamment. Une fois que la partie abstraite doit être modifiée, tant que le principe est strictement suivi, l'impact sera beaucoup plus faible. Bien entendu, s’il est modifié, des tests unitaires doivent être effectués et tout ce qui est utilisé doit être testé correctement.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal