아래 편집기는 Java에서 메소드를 매개변수로 사용하는 예(다형성)를 보여줍니다. 편집자님이 꽤 좋다고 생각하셔서 지금 공유하고 모두에게 참고용으로 드리도록 하겠습니다.
얼마 전 지능형 알고리즘을 공부할 때 Java를 사용하여 구현하면 구체적인 구현 프로세스는 유사한 경우가 많지만 적합도 값 함수가 크게 달라지는 것을 발견했습니다. 이는 코드 유지에 큰 장애물을 만들어 다음과 같은 질문으로 이어집니다. C/C++ 습관에 따르면 포인터의 존재로 인해 피트니스 값 함수
를 메서드에 전달할 수 있습니까? , 함수는 포인터가 전달되는 방식으로 사용될 수 있습니다. 포인터 사용의 복잡성과 어려움으로 인해 효과는 평균입니다. 객체 지향적 사고로 바꾸면 인터페이스 I을 디자인한다고 생각할 수 있습니다. 이 인터페이스는 메서드를 호출할 때 인터페이스를 매개 변수로 전달하는 것과 같습니다. 클래스를 만들고 인터페이스 I을 구현한 다음 함수를 메서드에 전달할 수 있습니다.
다음은 목적 함수가 다르기 때문에 0.618 황금 검색 방법을 예로 들었습니다. 이러한 종류의 검색은 단봉 함수에만 가능합니다.
알고리즘은 다음과 같습니다. 아래 그림:
public interface Fitness {
public double getFitness(double X);
}
public class stationUtils{/***
* 黄金分割搜索法,寻找最小值的函数
* @param min 搜索上限
* @param max 搜索下限
* @param fitness 函数值
* @return
*/
public double goldenSearch(double min,double max,Fitness fitness){
/*double X1=min+0.382*(max-min);*/
double a=doubleOperation.substract(max,min);
double X1=doubleOperation.add(min,doubleOperation.multiply(0.382,a));
/*double X2=min+0.618*(max-min);*/
double X2=doubleOperation.add(min,doubleOperation.multiply(0.618,a));
double F1=fitness.getFitness(X1);
double F2=fitness.getFitness(X2);
while(Math.abs(doubleOperation.substract(X1,X2))>delt){
if(F1<F2){
max=X2;
X2=X1;
F2=F1;
X1=min+0.382*(max-min);
F1=fitness.getFitness(X1);
}else{
min=X1;
X1=X2;
F1=F2;
X2=min+0.618*(max-min);
F2=fitness.getFitness(X2);
}
}
return doubleOperation.pide(doubleOperation.add(max,min),2);
}
}
public class Func implements Fitness{
@Override
public double getFitness(double X) {
return X*X- 3 * X + 1;
}
}
@Test
public void run1(){
Func func=new Func();
double result=stationUtils.goldenSearch(-2.00,4.00,func);
System.out.println(result);
}
, 더 많은 매개변수가 전달되고, 값이 인터페이스 구현 클래스에 전달될 수 있으며, getFitness 메소드가 이 매개변수에 액세스할 수 있습니다. .
위 내용은 Java는 매개변수 전달 시 다형성의 예로 메소드를 사용합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!