最近,我在Java MVC框架中编写了一个简单的游戏,一位高级程序员告诉我,得分是不安全的,其获取器和设置器在玩家模型本身中定义。不幸的是,我无法从他们那里获得有关如何以及为什么如此的进一步信息,而且我无法弄清原因。
有人可以复习这些课程并指出为什么不建议使用此体系结构吗?
播放器型号:
public class player implements Comparable<player>{
private int score;
private int consecutive_misses;
private String name;
private int foul_count;
private int turn;
private boolean win;
public player()
{
this.score=0;
this.consecutive_misses=0;
this.foul_count=0;
this.win=false;
}
public void setWin(boolean win)
{
this.win=win;
}
public boolean getWin()
{
return this.win;
}
public void setPlayerName(String name)
{
this.name=name;
}
public void setTurn(int turn)
{
this.turn=turn;
}
public int getTurn()
{
return this.turn;
}
public void addScore(int score)
{
this.score+=score;
}
public String getName()
{
return this.name;
}
public int getScore(){
return this.score;
}
public void resetFoulCount() {
this.foul_count = 0;
}
public void incrementFoulCount() {
this.foul_count++;
}
public int getFoulCount()
{
return this.foul_count;
}
public void resetConsecutiveMisses() {
this.consecutive_misses = 0;
}
public void incrementConsecutiveMisses() {
this.consecutive_misses++;
}
public int getConsecutiveMisses()
{
return this.consecutive_misses;
}
public int compareTo(player comparePlayer)
{
int compareScore=((player) comparePlayer).getScore();
return compareScore-this.score;
}
}```
the main game model class where i implemented player model
package com.tiffany.CleanStrike_1.models;
import java.util.HashMap;
import java.util.Map;
public class gameModel {
private int player_count;
private player[] players;
private player current_player;
private player winner=new player();
private gameState game_state;
private boolean draw=false;
private carromBoard carrom_board;
public gameModel(int player_count,int black_coin_count,int red_coin_count,int black_val,int red_val)
{
this.game_state=gameState.DORMANT;
this.players=new player[player_count];
for(int i=0;i<player_count;i++)
{
this.players[i]=new player();
}
this.setPlayerCount(player_count);
Coin black_coin=new Coin(CoinColour.BLACK,black_val);
carrom_board=new carromBoard();
this.carrom_board.addCoin(black_coin,black_coin_count);
Coin red_coin=new Coin(CoinColour.RED,red_val);
this.carrom_board.addCoin(red_coin,red_coin_count);
}
public int getNoOfCoins(CoinColour colour)
{
Map<Coin,Integer> coins=new HashMap<Coin,Integer>();
coins=this.getCoinsOnBoard();
for(Coin coin: coins.keySet())
{
if(coin.getColour()==colour)
return coins.get(coin);
}
return 0;
}
public void setPlayerName(int i,String name)
{
this.players[i].setPlayerName(name);
}
public void setGameDraw()
{
this.draw=true;
}
public boolean getGameDraw()
{
return this.draw;
}
public void setGameState(gameState game_s)
{
this.game_state=game_s;
}
public gameState getGameState()
{
return this.game_state;
}
public int getCountOfAllCoins()
{
return this.carrom_board.getCountOfAllCoins();
}
public int getCoinValue(CoinColour colour)
{
for ( Coin coin : this.carrom_board.getCoins().keySet() ) {
if(coin.getColour()==colour) {
return coin.getValue();
}
}
return 0;
}
public void setWinner(player w)
{
this.winner=w;
}
public player getWinner()
{
return this.winner;
}
public void setCurrentPlayer(player p)
{
this.current_player=p;
}
public player getCurrentPlayer()
{
return this.current_player;
}
public void setPlayerCount(int count)
{
this.player_count=count;
}
public int getPlayerCount()
{
return this.player_count;
}
public Map<Coin,Integer> getCoinsOnBoard()
{
return this.carrom_board.getCoins();
}
public void removeCoin(CoinColour colour,int count)
{
this.carrom_board.removeCoin(colour, count);
}
public player[] getPlayers()
{
return this.players;
}
}
答案 0 :(得分:1)
一个类不应公开其内部结构。通过公开其内部结构,它打破了许多法律(如Demeter法则),其他班级可以利用这种情况并设置所需的分数。您可以在“清洁代码”一书中阅读有关此内容的更多信息。