어떻게 자바 프로젝트 에서 if-else 를 대량으로 사용 하 는 것 을 피 합 니까?
초보 자 들 은 한 가 지 를 소홀히 할 수 있 지만 사실은 if-else 는 과정 을 향 한 실현 이다.
그렇다면 대상 프로 그래 밍 에서 if-else 를 대량으로 사용 하 는 것 을 어떻게 피 할 수 있 을 까?
인터넷 에 해결 방향 이 많 습 니 다.공장 모델,전략 모델,심지어 규칙 엔진 도 있 습 니 다.
이것들 은 모두 공 통 된 단점 이 하나 있 는데,사용 하기 에는 여전히 너무 무겁다.비록 너무 많은 if-else 가 나타 나 는 것 을 피한다 고 하지만 추가 적 인 유형 이 많이 증가 할 것 이다.나 는 항상 실 용적 이지 않 고 특정한 모델 로 만 공부 하면 된다 고 생각한다.
대량의 if-else 문 구 를 교체 할 수 있 고 비교적 좋 은 가 독성 과 확장 성 을 가 지 며 경 량 화 될 수 있 습 니 다.저 는 전략 적 매 거 진 을 사용 하여 if-else 를 없 애 는 것 을 추천 합 니 다.
어떻게 사용 합 니까?다음은 한 업무 사례 부터 말씀 드 리 겠 습 니 다.
만약 에 이런 수요 가 있 으 면 일주일 에 7 일 동안 일 을 해 야 한 다 는 것 을 각각 알 고 있 는 메모 기능 을 실현 해 야 한다.이 안에 하나의 절차 판단 과 관련 될 것 이다.당신 은 바로 if-else 를 사용 하 는 것 을 생각 할 것 이다.그러면 이렇게 실 현 될 것 이다.
//if-else    
  public String getToDo(String day){
      if("Monday".equals(day)){
          ......      
         return "      ";
     }else if("Tuesday".equals(day)){
          .....      
          return "      ";
     }else if("Wednesday".equals(day)){
         ......      
         return "      ";
      }else if("Thursday".equals(day)){
         ......      
        return "      ";
    }else if("sunday".equals(day)){
         ......      
        return "      ";
     }else{
             10086 ......
     }
 }이 때 는 프로 세 스 를 위 한 if-else 를 대체 하기 위해 전략 적 매 거 진 형식 을 고려 할 수 있 습 니 다.
우선 getToDo()호출 방법 을 정의 합 니 다.만약 에'월요일',즉 인자'Monday'가 들 어 오 면.
//      
public String getToDo(String day){
    CheckDay checkDay=new CheckDay();
    return checkDay.day(DayEnum.valueOf(day));
}다음은 checkDay.day(Day Enum.valueOf("Monday")를 실행 하면 day()방법 에 들 어 갑 니 다.여 기 는 dayEnum.toDo()를 통 해 정책 이 일치 할 때 입 니 다.주의 하 세 요.Day Enum.valueOf("Monday")는 매 거 진 Monday 를 얻 었 습 니 다.그러면 실질 적 으로 Monday.toDo()를 집행 한 것 입 니 다.즉,Monday 의 toDo()를 집행 한 다 는 것 입 니 다.
public class CheckDay {
    public String day( DayEnum dayEnum) {
        return dayEnum.toDo();
    }
}
public enum DayEnum {
    Monday {
        @Override
        public String toDo() {
            ......      
            return "      ";
        }
    },
    Tuesday {
        @Override
        public String toDo() {
            ......      
            return "      ";
        }
    },
    Wednesday {
        @Override
        public String toDo() {
            ......      
            return "      ";
        }
    },
    Thursday {
        @Override
        public String toDo() {
            ......      
            return "      ";
        }
    };
    public abstract String toDo();
}
public abstract String toDo();요약 하면 전략 매 거 는 매 거 에서 전략 모델 을 사용 하 는 것 이다.이른바 전략 모델 은 열 쇠 를 주 는 것 이다.특정한 약속 방식 에 따라 바로 열 수 있 는 문 을 찾 을 수 있다.예 를 들 어 내 가 너 에 게 준 열 쇠 는'Monday'라 고 한다.그러면 약속 방식 으로 dayEnum.toDo()를 통 해 매 거 진 Monday 대문 을 찾 아 문 으로 들 어가 하고 싶 은 일 을 할 수 있다.그 중에서 문 뒤의 방 마다 다른 기능 이 있 지만 똑 같은 추상 적 인 기능 인 toDo()가 있다.즉,각 방 의 공 통 된 곳 은 어떤 일 을 할 수 있 는 기능 이지 만 구체 적 으로 어떤 일 을 할 수 있 는 지 는 각각 다르다.본 논문 의 사례 에서 모든 대문 안의 toDo()는 서로 다른 전략 모델 에 따라 서로 다른 문자열 을 얻 을 수 있다.예 를 들 어'오늘 영어 수업','오늘 국어 수업'등 이다.
이 를 통 해 알 수 있 듯 이 절차 판단 을 전략 적 매 거 진 에 추출 하고 판단 을 결합 시 켜 업무 코드 논리 에 빽빽 하고 불필요 한 if-else 가 나타 나 지 않도록 할 수 있다.
같은 기능 을 반복 하 는 여러 가지 판단 이 있다 면,예 를 들 어 if-else 에 서 는 이렇다.
public String getToDoByIfElse(String day){
    if("Monday".equals(day)||"Tuesday".equals(day)||"Wednesday".equals(day)){
        ......      
        return "      ";
    }else if("Thursday".equals(day)){
        ......
    }
}다음 과 같은 사고방식 을 참고 하여 내부 전략 매 거 를 설정 하고 같은 기능 을 가 진 외부 인용 을 같은 내부 매 거 요 소 를 가리 키 면 중복 기능 을 호출 할 수 있다.
public enum DayEnum {
    //                      
    Monday("   ", Type.ENGLISH),
    Tuesday("   ", Type.ENGLISH),
    Wednesday("   ", Type.ENGLISH),
    
    Thursday("   ", Type.CHINESE);
    private final Type type;
    private final String day;
    DayEnum(String day, Type type) {
        this.day = day;
        this.type = type;
    }
    String toDo() {
        return type.toDo();
    }
    /**
     *       
     */
    private enum Type {
        ENGLISH {
            @Override
            public String toDo() {
                ......      
                return "      ";
            }
        },
        CHINESE {
            @Override
            public String toDo() {
                ......      
                return "      ";
            }
        };
        public abstract String toDo();
    }
}이 가능 하 다,~할 수 있다,...
이 기능 은 부류 가 부 류 를 계승 하 는 것 과 유사 하 다.DayEnum 은 부모 클래스 와 유사 하 며,DayEnum 이 매 거 진 요 소 는 그 하위 클래스 에 해당 합 니 다.부모 클래스 에서 추상 적 인 방법 인 toDo()를 정의 하면 계승 하 는 하위 클래스 는 기본적으로 toDo()방법 을 실현 합 니 다.그러면 매 거 진 에서 이렇게 쓸 수 있 는 방법 이 나타 납 니 다.
private enum Type {
        ENGLISH {
            @Override
            public String toDo() {
                return "      ";
            }
        };
        public abstract String toDo();
    }자바 에서 비 즈 니스 논리 에서 if-else 를 대량으로 사용 하면 과정 을 대상 으로 합 니 다.비 즈 니스 논리 에서 if-else 는 위 에서 아래 if 로 판단 되 기 때문에 각 if 에 정지점 을 두 고 debug 를 내 려 가면 과정 을 대상 으로 한 다 는 것 을 알 수 있 습 니 다.
이 를 통 해 알 수 있 듯 이 프로젝트 에 대량의 if-else 가 있다 면 성능 에 영향 을 주 는 일이 다.이런 성능 은 무시 할 수 있 지만 더 좋 은 대체 방안 이 있 는 것 이 좋 지 않 겠 는가?
자바 프로젝트 에서 if-else 를 대량으로 사용 하 는 것 을 피 하 는 방법 에 관 한 이야기 입 니 다.의 글 은 여기까지 소개 되 었 습 니 다.더 많은 관련 사항 은 if-else 콘 텐 츠 를 대량으로 사용 하지 않도록 하 겠 습 니 다.우리 의 이전 글 을 검색 하거나 아래 의 관련 글 을 계속 조회 하 시기 바 랍 니 다.앞으로 많은 응원 바 랍 니 다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
JPA + QueryDSL 계층형 댓글, 대댓글 구현(2)이번엔 전편에 이어서 계층형 댓글, 대댓글을 다시 리팩토링해볼 예정이다. 이전 게시글에서는 계층형 댓글, 대댓글을 구현은 되었지만 N+1 문제가 있었다. 이번에는 그 N+1 문제를 해결해 볼 것이다. 위의 로직은 이...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.