
org.cloudbus.cloudsim.allocationpolicies.VmAllocationPolicyNull Maven / Gradle / Ivy
package org.cloudbus.cloudsim.allocationpolicies;
import org.cloudbus.cloudsim.datacenters.Datacenter;
import org.cloudbus.cloudsim.hosts.Host;
import org.cloudbus.cloudsim.vms.Vm;
import org.cloudsimplus.autoscaling.VerticalVmScaling;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import java.util.function.BiFunction;
/**
* A class that implements the Null Object Design Pattern for the {@link VmAllocationPolicy}
* class.
*
* @author Manoel Campos da Silva Filho
* @see VmAllocationPolicy#NULL
*/
final class VmAllocationPolicyNull implements VmAllocationPolicy {
@Override public Datacenter getDatacenter() {
return Datacenter.NULL;
}
@Override public void setDatacenter(Datacenter datacenter) {/**/}
@Override public boolean scaleVmVertically(VerticalVmScaling scaling) {
return false;
}
@Override public boolean allocateHostForVm(Vm vm) {
return false;
}
@Override public boolean allocateHostForVm(Vm vm, Host host) {
return false;
}
@Override public void deallocateHostForVm(Vm vm) {/**/}
@Override public List getHostList() { return Collections.emptyList(); }
@Override public Map getOptimizedAllocationMap(List extends Vm> vmList) { return Collections.emptyMap(); }
@Override public Optional findHostForVm(Vm vm) { return Optional.empty(); }
@Override public boolean isVmMigrationSupported() { return false; }
@Override public int getHostCountForParallelSearch() { return 0; }
@Override public void setHostCountForParallelSearch(int hostCountForParallelSearch) {/**/}
@Override public void setFindHostForVmFunction(BiFunction> findHostForVmFunction) {/**/}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy