當前位置: 首頁>>代碼示例>>Java>>正文


Java Comparator.comparingInt方法代碼示例

本文整理匯總了Java中java.util.Comparator.comparingInt方法的典型用法代碼示例。如果您正苦於以下問題:Java Comparator.comparingInt方法的具體用法?Java Comparator.comparingInt怎麽用?Java Comparator.comparingInt使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.util.Comparator的用法示例。


在下文中一共展示了Comparator.comparingInt方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: printSorted

import java.util.Comparator; //導入方法依賴的package包/類
/**
 * Print all tuples in IDHashTable sorted
 */
public final void printSorted() {
    int iter;
    Collection<Entry> list;

    list = new TreeSet<>(Comparator.comparingInt(p_entryA -> p_entryA.m_key));

    for (int i = 0; i < m_elementCapacity; i++) {
        iter = getKey(i);
        if (iter != 0) {
            list.add(new Entry(iter, getValue(i)));
        }
    }

    for (Entry entry : list) {
        System.out.println("Key: " + entry.m_key + ", value: " + ChunkID.toHexString(entry.m_value));
    }
}
 
開發者ID:hhu-bsinfo,項目名稱:dxram,代碼行數:21,代碼來源:NameserviceHashTable.java

示例2: toCourseRequirements

import java.util.Comparator; //導入方法依賴的package包/類
public CourseRequirements toCourseRequirements(HashMap<Integer, Shift> shifts) {
    Set<Shift> requiredShifts = new TreeSet<>(Comparator.comparingInt(Shift::getId));
    Map<Integer, Integer> numTutorsPerShift = new HashMap<>();

    this.specifics.forEach(specific -> {
        int shiftId = specific.getShiftId();
        int numTutors = specific.getNumTutors();

        Shift shift = shifts.get(shiftId);
        if (shift != null) {
            requiredShifts.add(shift);
            numTutorsPerShift.put(shift.getId(), numTutors);
        }
    });

    CourseIntensity intensity = CourseIntensity.fromString(this.intensity);

    return new CourseRequirements(requiredShifts, this.timesPerWeek, 0, intensity, numTutorsPerShift, this.numTutors);
}
 
開發者ID:cocolocomoco21,項目名稱:ULCRS,代碼行數:20,代碼來源:ULCCourseRequirements.java

示例3: resolveExistingMigrations

import java.util.Comparator; //導入方法依賴的package包/類
static List<Path> resolveExistingMigrations(File migrationsDir, boolean reversed, boolean onlySchemaMigrations) {
	if (!migrationsDir.exists()) {
		migrationsDir.mkdirs();
	}

	File[] files = migrationsDir.listFiles();

	if (files == null) {
		return Collections.emptyList();
	}

	Comparator<Path> pathComparator = Comparator.comparingInt(FileResolver::compareVersionedMigrations);
	if (reversed) {
		pathComparator = pathComparator.reversed();
	}
	return Arrays.stream(files)
			.map(File::toPath)
			.filter(path -> !onlySchemaMigrations || SCHEMA_FILENAME_PATTERN.matcher(path.getFileName().toString()).matches())
			.sorted(pathComparator)
			.collect(Collectors.toList());
}
 
開發者ID:Devskiller,項目名稱:jpa2ddl,代碼行數:22,代碼來源:FileResolver.java

示例4: goodsToMake

import java.util.Comparator; //導入方法依賴的package包/類
/**
 * Chooses a type of goods for some of the natives in a settlement
 * to manufacture.
 * Simple rule: choose the refined goods that is the greatest shortage
 * for which there is a surplus of the raw material.
 *
 * @return A {@code GoodsType} to manufacture, or null if
 *      none suitable.
 */
private GoodsType goodsToMake() {
    final ToIntFunction<GoodsType> deficit = cacheInt(gt ->
        getWantedGoodsAmount(gt) - getGoodsCount(gt));
    final Predicate<GoodsType> goodsPred = gt ->
        gt.isRawMaterial()
            && gt.getOutputType() != null
            && !gt.getOutputType().isBreedable()
            && gt.getOutputType().isStorable()
            && deficit.applyAsInt(gt) < 0
            && deficit.applyAsInt(gt.getOutputType()) > 0;
    final Comparator<GoodsType> comp = Comparator.comparingInt(deficit);
    return maximize(getSpecification().getGoodsTypeList(), goodsPred, comp);
}
 
開發者ID:wintertime,項目名稱:FreeCol,代碼行數:23,代碼來源:IndianSettlement.java

示例5: NewUnitPanel

import java.util.Comparator; //導入方法依賴的package包/類
/**
 * The constructor to use.
 *
 * @param freeColClient The {@code FreeColClient} for the game.
 * @param layout The {@code LayoutManager} to use.
 * @param label The label for the panel.
 * @param units A list of {@code UnitType}s to offer.
 */
public NewUnitPanel(FreeColClient freeColClient, LayoutManager layout,
                    String label, List<UnitType> units) {
    super(freeColClient, layout);

    this.question = new JLabel(label);
    this.units.addAll(units);
    final Europe europe = getMyPlayer().getEurope();
    this.priceComparator = Comparator.comparingInt((UnitType ut) ->
        europe.getUnitPrice(ut));

    okButton.setText(Messages.message("close"));

    update();
}
 
開發者ID:FreeCol,項目名稱:freecol,代碼行數:23,代碼來源:NewUnitPanel.java

示例6: getMostValuableGoods

import java.util.Comparator; //導入方法依賴的package包/類
/**
 * Get the most valuable goods available in one of the player's
 * colonies for the purposes of choosing a threat-to-boycott.  The
 * goods must not currently be boycotted, the player must have
 * traded in it, and the amount to be discarded will not exceed
 * GoodsContainer.CARGO_SIZE.
 *
 * @return A goods object, or null if nothing suitable found.
 */
public Goods getMostValuableGoods() {
    if (!isEuropean()) return null;
    final Predicate<Goods> boycottPred = g ->
        getArrears(g.getType()) <= 0 && hasTraded(g.getType());
    final Comparator<Goods> tradedValueComp = Comparator.comparingInt(g ->
        market.getSalePrice(g.getType(),
            Math.min(g.getAmount(), GoodsContainer.CARGO_SIZE)));
    return maximize(flatten(getColonies(),
                            c -> c.getCompactGoodsList().stream()),
                    boycottPred, tradedValueComp);
}
 
開發者ID:wintertime,項目名稱:FreeCol,代碼行數:21,代碼來源:Player.java

示例7: getClosestTerritory

import java.util.Comparator; //導入方法依賴的package包/類
/**
 * Find the closest territory to a given tile from a list of choices.
 *
 * @param tile The {@code Tile} to search from.
 * @param territories The list of {@code Territory}s to choose from.
 * @return The closest {@code Territory} found, or null if none.
 */
private Territory getClosestTerritory(final Tile tile,
                                      List<Territory> territories) {
    final Map map = tile.getMap();
    final Comparator<Territory> comp = Comparator.comparingInt(t ->
        map.getDistance(tile, t.getCenterTile(map)));
    return minimize(territories, comp);
}
 
開發者ID:wintertime,項目名稱:FreeCol,代碼行數:15,代碼來源:SimpleMapGenerator.java

示例8: updateMostHated

import java.util.Comparator; //導入方法依賴的package包/類
/**
 * Updates the most hated nation of this settlement.
 * Needs to be public so it can be set by backwards compatibility code
 * in FreeColServer.loadGame.
 *
 * -til: This might change the tile appearance.
 *
 * @return True if the most hated nation changed.
 */
public boolean updateMostHated() {
    final Player old = this.mostHated;
    final Predicate<Player> hatedPred = p -> {
        Tension alarm = getAlarm(p);
        return alarm != null && alarm.getLevel() != Tension.Level.HAPPY;
    };
    final Comparator<Player> mostHatedComp
        = Comparator.comparingInt(p -> getAlarm(p).getValue());
    this.mostHated = maximize(getGame().getLiveEuropeanPlayers(),
                              hatedPred, mostHatedComp);
    return this.mostHated != old;
}
 
開發者ID:FreeCol,項目名稱:freecol,代碼行數:22,代碼來源:ServerIndianSettlement.java

示例9: testIntComparator

import java.util.Comparator; //導入方法依賴的package包/類
public void testIntComparator() {
    Thing[] things = new Thing[intValues.length];
    for (int i=0; i<intValues.length; i++)
        things[i] = new Thing(intValues[i], 0L, 0.0, null);
    Comparator<Thing> comp = Comparator.comparingInt(new ToIntFunction<Thing>() {
        @Override
        public int applyAsInt(Thing thing) {
            return thing.getIntField();
        }
    });

    assertComparisons(things, comp, comparisons);
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:14,代碼來源:BasicTest.java

示例10: getMostValuableGoods

import java.util.Comparator; //導入方法依賴的package包/類
/**
 * Get the most valuable goods available in one of the player's
 * colonies for the purposes of choosing a threat-to-boycott.  The
 * goods must not currently be boycotted, the player must have
 * traded in it, and the amount to be discarded will not exceed
 * GoodsContainer.CARGO_SIZE.
 *
 * @return A goods object, or null if nothing suitable found.
 */
public Goods getMostValuableGoods() {
    if (!isEuropean()) return null;
    final Market market = getMarket();
    if (market == null) return null;
    final Predicate<Goods> boycottPred = g ->
        getArrears(g.getType()) <= 0 && hasTraded(g.getType());
    final Comparator<Goods> tradedValueComp = Comparator.comparingInt(g ->
        market.getSalePrice(g.getType(),
            Math.min(g.getAmount(), GoodsContainer.CARGO_SIZE)));
    return maximize(flatten(getColonies(),
                            c -> c.getCompactGoodsList().stream()),
                    boycottPred, tradedValueComp);
}
 
開發者ID:FreeCol,項目名稱:freecol,代碼行數:23,代碼來源:Player.java

示例11: getBestFoodProduction

import java.util.Comparator; //導入方法依賴的package包/類
/**
 * Get the best food type to produce here.
 *
 * @return The {@code AbstractGoods} to produce.
 */
public AbstractGoods getBestFoodProduction() {
    final Comparator<AbstractGoods> goodsComp
        = Comparator.comparingInt(ag ->
            getPotentialProduction(ag.getType(), null));
    return maximize(flatten(getType().getAvailableProductionTypes(true),
                            pt -> pt.getOutputs()),
                    AbstractGoods::isFoodType, goodsComp);
}
 
開發者ID:FreeCol,項目名稱:freecol,代碼行數:14,代碼來源:Tile.java

示例12: search

import java.util.Comparator; //導入方法依賴的package包/類
private static Set<Node> search(Node inputNode, int desiredCost) {
    log.info("Searching at desiredCost: " + desiredCost);
    frontier = new PriorityQueue<>(Comparator.comparingInt(Node::getCost));
    explored = new HashSet<>();

    frontier.add(inputNode);

    Set<Node> success = new HashSet<>();

    while (frontier.size() != 0) {
        Node node = frontier.remove();
        explored.add(node);

        int parentCost = generateCost(node);
        log.info("Removing from frontier with cost " + parentCost+ " | remaining nodes on frontier: " + frontier.size());

        List<Node> successors = successors(node);
        for (Node successor : successors) {
            int cost = generateCost(successor);
            if (cost <= desiredCost) {
                success.add(successor);
                if (success.size() >= GENERATE_SCHEDULE_SIZE) {
                    return success;
                }
            }

            if (cost < parentCost && !frontier.contains(successor)) {
                frontier.add(successor);
                log.info("Adding to frontier | parentCost: " + parentCost + " | childCost: " + cost + " | remaining nodes on frontier: " + frontier.size());
            }
        }
    }

    return success.isEmpty() ? null : success;
}
 
開發者ID:cocolocomoco21,項目名稱:ULCRS,代碼行數:36,代碼來源:Scheduler.java

示例13: getBestPlanTile

import java.util.Comparator; //導入方法依賴的package包/類
/**
 * Gets the best plan for a colony from the tipMap.
 *
 * @param colony The {@code Colony} to check.
 * @return The tile with the best plan for a colony, or null if none found.
 */
public Tile getBestPlanTile(Colony colony) {
    final Comparator<TileImprovementPlan> valueComp
        = Comparator.comparingInt(TileImprovementPlan::getValue);
    final Function<Tile, TileImprovementPlan> tileMapper = t ->
        tipMap.get(t);
    TileImprovementPlan best
        = maximize(map(colony.getOwnedTiles(), tileMapper),
                   isNotNull(), valueComp);
    return (best == null) ? null : best.getTarget();
}
 
開發者ID:wintertime,項目名稱:FreeCol,代碼行數:17,代碼來源:EuropeanAIPlayer.java

示例14: testMaxBy

import java.util.Comparator; //導入方法依賴的package包/類
public void testMaxBy() {
    Comparator<People> cmp = Comparator.comparing(People::getFirstName);
    // lesser
    assertSame(maxBy(cmp).apply(people[0], people[1]), people[1]);
    // euqal
    cmp = Comparator.comparing(People::getLastName);
    assertSame(maxBy(cmp).apply(people[0], people[1]), people[0]);
    // greater
    cmp = Comparator.comparingInt(People::getAge);
    assertSame(maxBy(cmp).apply(people[0], people[1]), people[0]);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:12,代碼來源:BasicTest.java

示例15: getClosestPortForEurope

import java.util.Comparator; //導入方法依賴的package包/類
/**
 * Gets the port closest to Europe owned by this player.
 *
 * @return This players closest port.
 */
public Settlement getClosestPortForEurope() {
    final Comparator<Settlement> comp
        = Comparator.comparingInt(Settlement::getHighSeasCount);
    return minimize(getSettlements(), comp);
}
 
開發者ID:FreeCol,項目名稱:freecol,代碼行數:11,代碼來源:Player.java


注:本文中的java.util.Comparator.comparingInt方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。