Bonjour,
je suis tombé sur ce lien :
http://binstock.blogspot.com/2008/04/perfecting-oos-small-classes-and-short.html
Etudiant et amateur de programmation orienté Objet, et je me demandais ce que certains programmeur professionnels pensent de ces règles de programmation Objet.
Je commence donc par mon sentiment, pour moi c'est une méthode très instructive, qui a le défaut de devoir faire beaucoup de classes, dont certaines deviennent bateau, de simples conteneurs ... Egalement la regle sur les getter/setter qui me parait assez dure a respecter ( comment faire pour une classe Money, qui possede un attribut int money, si on ne peut ni le set/get ...) et je trouve l'utilisation d'un seul point par ligne totalement extremiste... Cela dit certaines autres regles me séduisent donc je suis dans le flou ..
Et vous vous en pensez quoi ?
EDIT : pour plus de facilité dans le post voici les règles :
1. Use only one level of indentation per method. If you need more than one level, you need to create a second method and call it from the first. This is one of the most important constraints in the exercise.
2. Don’t use the ‘else’ keyword. Test for a condition with an if-statement and exit the routine if it’s not met. This prevents if-else chaining; and every routine does just one thing. You’re getting the idea.
3. Wrap all primitives and strings. This directly addresses “primitive obsession.” If you want to use an integer, you first have to create a class (even an inner class) to identify it’s true role. So zip codes are an object not an integer, for example. This makes for far clearer and more testable code.
4. Use only one dot per line. This step prevents you from reaching deeply into other objects to get at fields or methods, and thereby conceptually breaking encapsulation.
5. Don’t abbreviate names. This constraint avoids the procedural verbosity that is created by certain forms of redundancy—if you have to type the full name of a method or variable, you’re likely to spend more time thinking about its name. And you’ll avoid having objects called Order with methods entitled shipOrder(). Instead, your code will have more calls such as Order.ship().
6. Keep entities small. This means no more than 50 lines per class and no more than 10 classes per package. The 50 lines per class constraint is crucial. Not only does it force concision and keep classes focused, but it means most classes can fit on a single screen in any editor/IDE.
7. Don’t use any classes with more than two instance variables. This is perhaps the hardest constraint. Bay’s point is that with more than two instance variables, there is almost certainly a reason to subgroup some variables into a separate class.
8. Use first-class collections. In other words, any class that contains a collection should contain no other member variables. The idea is an extension of primitive obsession. If you need a class that’s a subsumes the collection, then write it that way.
9. Don’t use setters, getters, or properties. This is a radical approach to enforcing encapsulation. It also requires implementation of dependency injection approaches and adherence to the maxim “tell, don’t ask.”

 

 
		
		 
         
 

 
			
			


 Question de POO
 Question de POO
				
 Répondre avec citation
  Répondre avec citation


 
  
  
 
 
 
 
			 
   
 




 
			 
   Envoyé par DisSsha
 Envoyé par DisSsha
					



 
			 
  
  
			 
						
Partager