-
Notifications
You must be signed in to change notification settings - Fork 6
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[정재]String-adding-calculation #7
base: jj
Are you sure you want to change the base?
Conversation
dongry1002
commented
Mar 1, 2020
- CustomerDelimeter 추가예정
- 배열이 아니라 ArrayList로 바꾸자
package calculator; | ||
|
||
public class Calclator { | ||
Spliter spliter = new Spliter(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
여기서 선언한 Spliter가 새로 바뀌거나 한다면 위처럼 가변 참조 필드로 두어도 되겠지만, 그것이 아니기 때문에 private final 걸어주면 좋을것같아요
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
혹시 private final로 걸어야하는부분이 spliter 인가요?ㅠ
int result = 0; | ||
System.out.println("숫자들을 입력하세요 : "); | ||
Scanner scanner = new Scanner(System.in); | ||
String inputValue = scanner.nextLine(); | ||
if (inputValue.isEmpty()) { | ||
System.out.println(result); | ||
return; | ||
} | ||
|
||
Spliter spliter = new Spliter(); | ||
String[] splitedValue = spliter.splitValue(inputValue); | ||
|
||
System.out.println(splitedValue); | ||
Calclator calclator = new Calclator(); | ||
result = calclator.sum(splitedValue); | ||
|
||
System.out.println(result); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
result라는 변수가 꼭 필요한가 싶습니다.
int result = 0; | |
System.out.println("숫자들을 입력하세요 : "); | |
Scanner scanner = new Scanner(System.in); | |
String inputValue = scanner.nextLine(); | |
if (inputValue.isEmpty()) { | |
System.out.println(result); | |
return; | |
} | |
Spliter spliter = new Spliter(); | |
String[] splitedValue = spliter.splitValue(inputValue); | |
System.out.println(splitedValue); | |
Calclator calclator = new Calclator(); | |
result = calclator.sum(splitedValue); | |
System.out.println(result); | |
System.out.println("숫자들을 입력하세요 : "); | |
Scanner scanner = new Scanner(System.in); | |
String inputValue = scanner.nextLine(); | |
if (inputValue.isEmpty()) { | |
System.out.println(0); | |
return; | |
} | |
Spliter spliter = new Spliter(); | |
String[] splitedValue = spliter.splitValue(inputValue); | |
System.out.println(splitedValue); | |
Calclator calclator = new Calclator(); | |
System.out.println(calclator.sum(splitedValue)); |
import java.util.regex.Matcher; | ||
import java.util.regex.Pattern; | ||
|
||
public class Spliter { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
https://88240.tistory.com/440
참고하세요 :)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
가변필드를 가지고 있지 않고 Util 성을 띄고있는 것 같아 static 클래스로 만들어줘도 좋을 것 같습니다 ! 그렇게 하면 Main과 Calculator 에서 불필요하게 두번씩 생성할 필요도 없을 것 같습니다!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
네 static으로 바꿨습니다. 감사합니다~
|
||
public void checkPositve(int parseInt) { | ||
if (parseInt > 0) { | ||
return; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
여기있는 return 부분이 불필요해 보입니다. if 안의 조건문을 변경해보세요
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
네 변경하였습니다.
System.out.println(splitedValue[0]); | ||
System.out.println(splitedValue[1]); | ||
System.out.println(splitedValue[2]); | ||
return splitedValue; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
이렇게 인덱싱을 했을때 outofbound 에러가 나지는 않을지 예외케이스를 생각해보세요
} | ||
|
||
public int parseToInt(String splitedValue) { | ||
if (isNumberic(splitedValue)) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
isNumberic과 아래 코드에서 parseInt를 두번 체크하는데 다른 방식을 고려해보세요
checkPositve(number); | ||
return number; | ||
} | ||
throw new IllegalArgumentException("양수로 된 숫자만 입력하세요."); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
isNumeric 의 catch 문에서 throw 하는 것은 어떨까요?? return false를 굳이 하지 않아도 될 것 같아요 ! isNumeric ParseInt 중복 부분을 해결하면 같이 해결될 것 같습니다 ~
public static final String CUSTOMER_DELIMITER = "//(.)\n(.*)"; | ||
|
||
public String[] splitValue(String value) { | ||
Matcher m = Pattern.compile(CUSTOMER_DELIMITER).matcher(value); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
여기서 Pattern.complie 은 항상 같은 Pattern 을 가리키잖아요?
Pattern 은 생성 비용이 높기 때문에 상수로 초기화시키고 사용하는 것이 좋다고 하더라구요!
Matcher m = Pattern.compile(CUSTOMER_DELIMITER).matcher(value); | |
private static final Pattern CUSTOM_PATTERN = Pattern.compile(CUSTOMER_DELIMITER); |
아, 그리고 이 클래스의 멤버변수는 private 이어도 될 것 같습니다! Splitter 클래스만 알고 있어도 되는 변수로 보여요!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
String customDelimiter = m.group(1); | ||
String tokens =m.group(2); | ||
String[] splitedValue = tokens.split(CUSTOMER_DELIMITER); | ||
System.out.println(splitedValue[0]+"custom"); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
System.out 은 테스트용인건가요!?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
넵 지웠습니다. 감사해요
public static final String DELIMITER1 = "[,|:]"; | ||
public static final String CUSTOMER_DELIMITER = "//(.)\n(.*)"; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
해당 상수들이 public
하게 공개되어있을 필요가 없을것 같아여!
public static final String CUSTOMER_DELIMITER = "//(.)\n(.*)"; | ||
|
||
public String[] splitValue(String value) { | ||
Matcher m = Pattern.compile(CUSTOMER_DELIMITER).matcher(value); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Matcher
객체의 변수를 m
으로 사용하고 있네요!
축약은 코드를 읽는 사람들에게 혼동을 줄 수 있어요!
@Test | ||
void splitValue() { | ||
// String inputValue = new String("1,2:3"); | ||
// assertThat(spliter.splitValue(inputValue)).isEqualTo(["1", "2", "3"]); | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
불필요한 테스트는 제거해주세요 ㅎㅎ
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
추가적으로 기본식이 입력 되었을 때와 커스텀 구분자가 들어간 식에 대한 계산 테스트가 존재하지 않네요!
만약 해당 테스트를 작성하기 힘들다면 작성하게 힘들어지는 부분을 찾고 리팩토링을 해보는게 좋을것 같아요!
참고로 커스텀 구분자는 \n
때문에 테스트 작성하기가 힘들어 질수도 있어요 이때는 @ParameterizedTest
와 @MethodSource
를 이용해 보면 좋을것 같아요!
try { | ||
Integer.parseInt(splitedValue); | ||
return true; | ||
} catch (IllegalArgumentException e) { | ||
return false; | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
이펙티브자 자바3판 아이템 69 예외는 진짜 예외 상황에만 사용하라
한번 검색해서 참고해 보시면 좋을것 같아요!
저는 지금 이 코드가 제어 흐름용 exception 이라고 생각해요!
public static void main(String[] args) { | ||
int result = 0; | ||
System.out.println("숫자들을 입력하세요 : "); | ||
Scanner scanner = new Scanner(System.in); | ||
String inputValue = scanner.nextLine(); | ||
if (inputValue.isEmpty()) { | ||
System.out.println(result); | ||
return; | ||
} | ||
|
||
Spliter spliter = new Spliter(); | ||
String[] splitedValue = spliter.splitValue(inputValue); | ||
|
||
System.out.println(splitedValue); | ||
Calclator calclator = new Calclator(); | ||
result = calclator.sum(splitedValue); | ||
|
||
System.out.println(result); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
main 메서드길이를 최대 10라인이 되도록 수정해주세요!
저희 이번 미션 프로그래밍 요구사항에 포함되어 있었습니다 ㅎㅎ