在C/C 語言中,Pair(對)是將兩個資料類型組成一個資料類型的容器,例如std::pair。
Pair主要有兩種用途:
把key和value放在一起成對處理,主要用於Map中傳回名值對,例如Map中的Entry類別;
當一個函數需要傳回兩個結果時,可以使用Pair來避免定義過多的資料模型類別。
第一種用途比較常見,這裡主要說明第二種用途。
函數實作程式碼:
/** 点和距离类 */@Setter@Getter@ToString@AllArgsConstructorpublic static class PointAndDistance { /** 点 */ private Point point; /** 距离 */ private Double distance; }/** 获取最近点和距离 */public static PointAndDistance getNearestPointAndDistance(Point point, Point[] points) { // 检查点数组为空 if (ArrayUtils.isEmpty(points)) { return null; } // 获取最近点和距离 Point nearestPoint = points[0]; double nearestDistance = getDistance(point, points[0]); for (int i = 1; i < points.length; i++) { double distance = getDistance(point, point[i]); if (distance < nearestDistance) { nearestDistance = distance; nearestPoint = point[i]; } } // 返回最近点和距离 return new PointAndDistance(nearestPoint, nearestDistance); }
函數使用案例:
Point point = ...; Point[] points = ...; PointAndDistance pointAndDistance = getNearestPointAndDistance(point, points);if (Objects.nonNull(pointAndDistance)) { Point point = pointAndDistance.getPoint(); Double distance = pointAndDistance.getDistance(); ... }
在JDK中,沒有提供原生的Pair資料結構,也可以使用Map::Entry來取代。不過,Apache的commons-lang3套件中的Pair類別更為好用,以下便以Pair類別進行舉例說明。
函數實作程式碼:
/** 获取最近点和距离 */public static Pair<Point, Double> getNearestPointAndDistance(Point point, Point[] points) { // 检查点数组为空 if (ArrayUtils.isEmpty(points)) { return null; } // 获取最近点和距离 Point nearestPoint = points[0]; double nearestDistance = getDistance(point, points[0]); for (int i = 1; i < points.length; i++) { double distance = getDistance(point, point[i]); if (distance < nearestDistance) { nearestDistance = distance; nearestPoint = point[i]; } } // 返回最近点和距离 return Pair.of(nearestPoint, nearestDistance); }
函數使用案例:
Point point = ...; Point[] points = ...; Pair<Point, Double> pair = getNearestPointAndDistance(point, points);if (Objects.nonNull(pair)) { Point point = pair.getLeft(); Double distance = pair.getRight(); ... }
以上是java如何使用Pair實現成對結果的返回的詳細內容。更多資訊請關注PHP中文網其他相關文章!