From 111e6a3fdf613767782817836c42810bf2bda5e8 Mon Sep 17 00:00:00 2001 From: Tsuyoshi Ozawa Date: Thu, 16 Jul 2015 14:08:31 +0900 Subject: [PATCH] HADOOP-10615. FileInputStream in JenkinsHash#main() is never closed. Contributed by Chen He. --- hadoop-common-project/hadoop-common/CHANGES.txt | 3 +++ .../org/apache/hadoop/util/hash/JenkinsHash.java | 15 ++++++++------- 2 files changed, 11 insertions(+), 7 deletions(-) diff --git a/hadoop-common-project/hadoop-common/CHANGES.txt b/hadoop-common-project/hadoop-common/CHANGES.txt index 3d641560f4..9bb7a26c23 100644 --- a/hadoop-common-project/hadoop-common/CHANGES.txt +++ b/hadoop-common-project/hadoop-common/CHANGES.txt @@ -961,6 +961,9 @@ Release 2.8.0 - UNRELEASED HADOOP-12200. TestCryptoStreamsWithOpensslAesCtrCryptoCodec should be skipped in non-native profile. (Masatake Iwasaki via aajisaka) + HADOOP-10615. FileInputStream in JenkinsHash#main() is never closed. + (Chen He via ozawa) + Release 2.7.2 - UNRELEASED INCOMPATIBLE CHANGES diff --git a/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/util/hash/JenkinsHash.java b/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/util/hash/JenkinsHash.java index bf4891378c..f3895d0248 100644 --- a/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/util/hash/JenkinsHash.java +++ b/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/util/hash/JenkinsHash.java @@ -252,13 +252,14 @@ public class JenkinsHash extends Hash { System.err.println("Usage: JenkinsHash filename"); System.exit(-1); } - FileInputStream in = new FileInputStream(args[0]); - byte[] bytes = new byte[512]; - int value = 0; - JenkinsHash hash = new JenkinsHash(); - for (int length = in.read(bytes); length > 0 ; length = in.read(bytes)) { - value = hash.hash(bytes, length, value); + try (FileInputStream in = new FileInputStream(args[0])) { + byte[] bytes = new byte[512]; + int value = 0; + JenkinsHash hash = new JenkinsHash(); + for (int length = in.read(bytes); length > 0; length = in.read(bytes)) { + value = hash.hash(bytes, length, value); + } + System.out.println(Math.abs(value)); } - System.out.println(Math.abs(value)); } }