>  기사  >  Java  >  Java 프로그래밍의 void 메소드에 대한 학습 튜토리얼

Java 프로그래밍의 void 메소드에 대한 학습 튜토리얼

高洛峰
高洛峰원래의
2017-01-22 10:11:391762검색

void 키워드
이 섹션에서는 void 메소드를 선언하고 호출하는 방법을 설명합니다.
다음 예에서는 printGrade라는 메소드를 선언하고 이를 호출하여 지정된 성적을 인쇄합니다.

public class TestVoidMethod {
 
  public static void main(String[] args) {
   printGrade(78.5);
  }
 
  public static void printGrade(double score) {
   if (score >= 90.0) {
     System.out.println('A');
   }
   else if (score >= 80.0) {
     System.out.println('B');
   }
   else if (score >= 70.0) {
     System.out.println('C');
   }
   else if (score >= 60.0) {
     System.out.println('D');
   }
   else {
     System.out.println('F');
   }
  }
}

위 예제의 컴파일 및 실행 결과는 다음과 같습니다.

C

여기서 printGrade 메소드는 void입니다. 값을 반환하지 않는 유형 메서드입니다.
void 메소드에 대한 호출은 명령문이어야 합니다. 따라서 메인 메소드의 세 번째 줄에 있는 문장이라고 부릅니다. 세미콜론으로 끝나는 모든 명령문과 같습니다.

void 유형 메소드의 단일 테스트
Java의 서비스 계층에는 save* 및 update*와 같은 많은 void 유형 메소드가 있으며 이러한 메소드는 일부 업데이트만 수행하고 값을 반환하지 않습니다. 메소드의 반환 값을 기반으로 하며 특수 메소드만 사용할 수 있습니다.

이 메소드의 환경: Mockito, testng

테스트할 메소드:

테스트된 VOID 메서드

@Override
  public void updateRuleName(Long ruleId, String newRuleName, Long ucId) {
    Assert.notNull(ruleId, "规则ID不能为Null");
    Assert.notNull(newRuleName, "规则名称不能为Null");
    Assert.notNull(ucId, "操作人的UCID不能为Null");
     
    String cleanNewRuleName = StringUtils.trim(newRuleName);
    if (StringUtils.isBlank(cleanNewRuleName)) {
      throw new IllegalArgumentException("新的规则名称不能为空");
    }
     
    // 查询规则对象
    Rule rule = queryRuleById(ruleId);
    if (null == rule) {
      throw new IllegalDataException("没有查到该规则");
    }
     
    rule.setRuleId(ruleId);
    rule.setRuleName(cleanNewRuleName);
    rule.setUpdateUcid(ucId);
    rule.setUpdateTime(new Date());
     
    ruleDao.updateSelective(rule);
  }

테스트된 메서드:

test에서 반환된 void 메서드

@Test
  public void testUpdateRuleName() {
    Long ruleId = 1L;
    String newRuleName = "newRuleName";
    Long ucId = 123L;
     
    List<Rule> rules = new ArrayList<Rule>();
    Rule rule = new Rule();
    rule.setRuleStatus((byte) DBValueSetting.RULE_STATUS_TAKE_EFFECT);
    rules.add(rule);
     
    // 查询规则对象
    Map<String, Object> params = new HashMap<String, Object>();
    params.put("ruleId", ruleId);
    Mockito.when(ruleDao.queryRulesByCondition(params)).thenReturn(rules);
     
    Mockito.doAnswer(new Answer<Object>() {
      public Object answer(InvocationOnMock invocation) {
        // 断点2:这里随后执行
        Rule rule = (Rule) invocation.getArguments()[0];
        Assert.assertTrue(rule.getRuleName().equals("newRuleName"));
        return null;
      }
    }).when(ruleDao).updateSelective(Mockito.any(Rule.class));
     
    // 断点1:先执行到这里
    ruleService.updateRuleName(ruleId, newRuleName, ucId);
  }

주석에 명시된 대로, if 두 개의 중단점이 추가되면 실행 과정에서 마지막 호출 라인이 먼저 실행됩니다. 끝점 1이 실행되는 동안 끝점 2의 스텁이 실행됩니다. 이 때 메서드 실행의 입력 매개 변수를 얻을 수 있습니다. 중단점 2. 목적을 달성하기 위해 입력 매개변수에 대한 Assert 확인을 수행합니다.

new Anwer는 메서드 호출을 위한 프록시 실행 항목을 설정하는 데 사용되는 메서드가 하나만 있는 인터페이스입니다. 🎜>doAnswer 구현

public interface Answer<T> {
  /**
   * @param invocation the invocation on the mock.
   *
   * @return the value to be returned
   *
   * @throws Throwable the throwable to be thrown
   */
  T answer(InvocationOnMock invocation) throws Throwable;
}

"ruleDao.updateSelective(rule);" 코드가 실행되면 모의 개체에 대해 호출되는 인터셉터가 트리거됩니다. 동적 프록시가 생성됩니다. 호출은 새로운 답변에서 다루는 방법입니다.

는 이를 사용하여 입력 매개변수와 출력 매개변수의 설정 및 획득을 실현합니다. VOID 메소드 내부의 실행 클래스 호출을 확인하세요.

Java 프로그래밍의 void 메소드 학습 튜토리얼과 관련된 더 많은 기사를 보려면 PHP 중국어 웹사이트를 주목하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.