Java 프로젝트에서 사용되지 않는 코드 / 죽은 코드를 찾는 방법


Answers

합리적으로 잘 작동하는 Eclipse 플러그인은 Unused Code Detector 입니다.

그것은 전체 프로젝트 또는 특정 파일을 처리하고 다양한 미사용 / 데드 코드 (dead code) 방법을 보여줄뿐 아니라 가시성 변경 (예 : 보호되거나 비공개가 될 수있는 공개 방법)을 제안합니다.

Question

대형 자바 프로젝트에서 사용되지 않는 코드 / 죽은 코드를 찾으려면 어떤 툴을 사용합니까? 우리 제품은 몇 년 동안 개발되어 왔으며 더 이상 사용되지 않는 코드를 수동으로 감지하는 것이 매우 어려워졌습니다. 그러나 우리는 사용하지 않는 코드를 최대한 삭제하려고 노력합니다.

일반적인 전략 / 기법 (특정 도구 제외)에 대한 제안도 환영합니다.

편집 : 코드 커버리지 도구 (Clover, IntelliJ)를 이미 사용하고 있지만 이것들은 거의 도움이되지 않습니다. 데드 코드는 여전히 단위 테스트를 가지고 있으며 다루는대로 표시됩니다. 이상적인 도구는 코드에 따라 다른 코드가 거의없는 코드 클러스터를 식별하여 수동 검사를 문서화 할 수 있습니다.




하나의 클래스에서 이클립스에서하는 것으로 알려진 한 가지 점은 모든 메소드를 비공개로 변경 한 다음 내가받는 불만 사항을 확인하는 것입니다. 사용되는 메소드의 경우 오류가 발생하여 최대한 낮은 액세스 수준으로 되돌립니다. 사용되지 않는 메소드의 경우, 사용되지 않는 메소드에 대한 경고가 표시되고, 메소드를 삭제할 수 있습니다. 그리고 보너스로, 당신은 종종 개인적으로 할 수 있고해야만하는 공개 방법을 발견합니다.

그러나 그것은 매우 수동적입니다.




테스트 커버리지 도구를 사용하여 코드베이스를 계측 한 다음 테스트가 아닌 응용 프로그램 자체를 실행하십시오.

EmmaEclemma 는 주어진 코드 실행에 대해 어떤 클래스가 실행되는지에 대한 좋은 보고서를 제공 할 것입니다.




이론 상으로는 결정적으로 사용되지 않는 코드를 찾을 수 없습니다. Theres 수학적 증거 이것 (글쎄,이 더 일반적인 정리의 특별한 경우)입니다. 호기심이 있다면, 정지 문제를 찾아보십시오.

이것은 자바 코드로 여러모로 나타날 수 있습니다 :

  • 사용자 입력, 설정 파일, 데이터베이스 항목 등을 기반으로 클래스로드
  • 외부 코드로드 중.
  • 타사 라이브러리에 객체 트리 전달
  • 기타

즉, IDEA IntelliJ를 선택 IDE로 사용하고 모듈, 사용되지 않는 메소드, 사용되지 않은 멤버, 사용되지 않는 클래스 등의 findign 종속성을위한 광범위한 분석 도구를 사용합니다. 너무 지능적인 방법은 호출되지 않는 개인 메소드와 같습니다. 사용되지 않은 태그가 있지만 공개 방법은보다 광범위한 분석이 필요합니다.




IntelliJ에는 사용되지 않는 코드를 탐지하는 코드 분석 도구가 있습니다. 가능한 한 많은 필드 / 메소드 / 클래스를 비공개로 만들어야하며, 사용되지 않는 메소드 / 필드 / 클래스가 더 많이 표시됩니다.

또한 코드 볼륨을 줄이는 방법으로 중복 코드를 찾으려고합니다.

내 마지막 제안은 오픈 소스 코드를 찾아서 사용하면 코드를 더 간단하게 만들려고합니다.




코드를 프로파일 링하고 코드 적용 데이터를 제공하는 도구가 있습니다. 이를 통해 코드가 얼마나 많이 호출되는지 볼 수 있습니다. 당신은 얼마나 많은 고아 코드를 발견 할 수있는 도구를 얻을 수 있습니다.




EMMA와 같은 사용자 서비스 제공 도구. 하지만 그것은 정적 도구가 아닙니다 (즉, 회귀 테스트를 통해 실제로 응용 프로그램을 실행해야합니다. 가능한 모든 오류 사례를 통과해야합니다.)

그래도 EMMA는 매우 유용합니다.




  • FindBugs는 이런 종류의 일에 탁월합니다.
  • PMD (Project Mess Detector)는 사용할 수있는 또 다른 도구입니다.

그러나 둘 다 작업 공간에서 사용되지 않는 공용 정적 메서드 를 찾을 수 없습니다. 그런 도구를 아는 사람이라면 알려 주시기 바랍니다.




Eclipse는 도달 할 수없는 코드를 보여 주거나 강조 표시 할 수 있습니다. JUnit은 코드 커버리지를 보여줄 수 있지만 테스트가 필요하며 관련 테스트가 누락되었거나 코드가 실제로 사용되지 않는지를 결정해야합니다.




Java 프로젝트 - Dead Code Detector (DCD)가 있습니다. 소스 코드의 경우 잘 작동하지 않지만 .jar 파일의 경우에는 정말 좋습니다. 또한 클래스별로 필터링 할 수도 있습니다.