JDK中内置了很多常用的工具类,且多以“s”结尾,如:集合工具类Collections,数组工具类Arrays,对象工具类Objects,文件工具类Files,路径工具类Paths,数学工具类Maths;但也有一些不是以“s”结尾的工具类,如TimeUnit和System。

下面就简单介绍各工具类的用法。
(1)Objects中定义很多有用的API,如空指针判断,对象相等比较等。比较常用的API有以下几个:
​ 用于判断两个对象是否相等,两个参数都可以为null
​ public static boolean equals(Object a, Object b)
 用于判断一个对象是否为空
​ public static boolean isNull(Object obj)
 用于判断一个对象是否不为空
 public static boolean nonNull(Object obj)
 用于对变量进行非空校验,如果为空则抛出空指针异常,不为空则返回此变量,还可以抛出指 定异常信息
 public static <T> T requireNonNull(T obj)
 public static <T> T requireNonNull(T obj, String message)

​ Objects使用示例:

     static void useObjects() {
String str1 = null;
String str2 = "Hello Java"; // 判断str1与str2是否相等
boolean equalFlag = Objects.equals(str1, str2); // 进行空指针判断,如果为null就会抛出空指针异常,否则返回原值
str1 = Objects.requireNonNull(str1);
str2 = Objects.requireNonNull(str2, "Str2 is null"); // 判断str1是否为null
boolean nullFlag = Objects.isNull(str1);
// 判断str2是否为非空
boolean nonNullFlag = Objects.nonNull(str2);
}

(2)Arrays中定义了很多与数组相关API,常用的主要有一下几个API

  // 数组排序
  public static void sort(int[] a)
  // 二分法查找数组中的元素
  public static int binarySearch(long[] a, long key)
  // 判断两个数组是否相等(数组元素对应相等,且数组长度一致)
  public static boolean equals(long[] a, long[] a2)
  // 使用指定值填充数组
  public static void fill(long[] a, long val)
  // 复制数组
  public static <T> T[] copyOf(T[] original, int newLength)
  // 获取数组的hashCode
  public static int hashCode(long a[])
  // 将整个数组转化为形如:[a, b, c, ..., d]的格式的字符串
  public static String toString(int[] a)

  Arrays使用示例代码如下:

     static void useArrays() {
int[] arr1 = {5, 3, 2, 1, 4};
int[] arr2 = {5, 3, 2, 1, 4, 5}; // 对arr1进行排序,默认是升序排序
Arrays.sort(arr1); // 搜索2在arr1中的位置,返回索引值,arr1必须是有序的
int index = Arrays.binarySearch(arr1, 2); // 判断arr1与arr2是否相等
boolean equalFlag = Arrays.equals(arr1, arr2); int[] newArr = new int[10];
// 使用10填充newArr数组
Arrays.fill(newArr, 10); // 复制newArr的数组0--4的元素,并返回新数组
int[] ansArr = Arrays.copyOf(newArr, 5); // 获得ansArr的hashCode
int ansHashCode = Arrays.hashCode(ansArr); // 将ansArr转化为一个字符串
String str = Arrays.toString(ansArr);
}

(3)Collections中定义了许多集合常用的API,常用的API如下:
  // 对List进行排序
  public static <T extends Comparable<? super T>> void sort(List<T> list)
  // 二分法查找List中的元素索引值,List必须有序
  public static <T> int binarySearch(List<? extends Comparable<? super T>> list, T key)
  // 翻转List
  public static void reverse(List<?> list)
  // 寻找出List中的最小元素值
  public static <T extends Object & Comparable<? super T>>
  T min(Collection<? extends T> coll)
  // 寻找出List中的最大元素值
  public static <T extends Object & Comparable<? super T>>
  T max(Collection<? extends T> coll)

  Collections的使用示例代码如下:

     static void useCollections() {
List<Integer> nums = new ArrayList<>();
nums.add(1);
nums.add(3);
nums.add(2);
nums.add(5);
nums.add(4);
// 对List中的元素进行排序
Collections.sort(nums); // 寻找5在nums中的索引值
int index = Collections.binarySearch(nums, 5); // 翻转nums
Collections.reverse(nums);
// 寻找出nums中的最小值
Collections.min(nums);
// 寻找出nums中的最大值
Collections.max(nums);
}

(4)Files中定义了许多常用的与文件相关的API,常用API如下:
  // 获取指定文件的字节输入流
  public static InputStream newInputStream(Path path, OpenOption... options)
  // 获取指定文件的字节输出流
  public static OutputStream newOutputStream(Path path, OpenOption... options)
  // 以指定编码获取指定文件的字符输入流
  public static BufferedReader newBufferedReader(Path path, Charset cs)
  // 以指定编码获取指定文件的字符输出流
  public static BufferedWriter
  newBufferedWriter(Path path, Charset cs, OpenOption... options)
  // 以指定编码获取一个文件中的所有内容,并以字符串流返回
  public static Stream<String> lines(Path path, Charset cs)
  // 创建文件
  public static Path createFile(Path path, FileAttribute<?>... attrs)
  // 创建路径
  public static Path createDirectory(Path dir, FileAttribute<?>... attrs)
  // 删除文件
  public static void delete(Path path)
  // 如果文件存在,则删除文件
  public static boolean deleteIfExists(Path path
  // 文件复制
  public static Path copy(Path source, Path target, CopyOption... options)
  // 文件移动
  public static Path move(Path source, Path target, CopyOption... options)

  Files使用示例代码如下:

     static void useFiles() throws IOException {
Path dataPath = Paths.get("data.txt");
// 获取字符输入流
InputStream is = Files.newInputStream(dataPath);
// 获取字符输出流
OutputStream os = Files.newOutputStream(dataPath);
// 获取字符输入流
BufferedReader reader = Files.newBufferedReader(dataPath);
// 获取字符输出流
BufferedWriter writer = Files.newBufferedWriter(dataPath);
// 获取文件中的所有内容,并以字符串流返回,每个字符串代表文件的一行文本
Stream<String> lines = Files.lines(dataPath, Charset.forName("UTF-8")); // 创建一个文件路径
Files.createDirectories(Paths.get("hello"));
// 创建一个文件
Files.createFile(Paths.get("config.txt")); // 删除文件或文件夹,如果不存在,则会抛出异常
Files.delete(Paths.get("data.txt"));
// 删除文件或文件夹,如果不存在则不会执行删除操作,也不会抛出异常
Files.deleteIfExists(Paths.get("hello")); // 只能进行文件复制,不能进行文件夹复制
Files.copy(Paths.get("1.txt"), Paths.get("2.txt")); // 文件或文件夹移动
Files.move(Paths.get("SRC"), Paths.get("DES"));
}

(5)Paths主要和Files,File搭配使用,没有什么需要讲的。

(6)Maths主要封装了一些常用的与数学相关的操作,这是大家最为熟悉的工具类,也不需要讲解。

(7)TimeUnit主要是线程sleep的时候比较方便:
  // 线程休眠5小时
  TimeUnit.HOURS.sleep(5);
  // 线程休眠5分钟
  TimeUnit.MINUTES.sleep(5);
  // 线程休眠5秒
  TimeUnit.SECONDS.sleep(5);

(8)System也是大家比较熟悉的一个工具类,比如大家最常用的控制台输出就是用的
  System.out.println(),常用的API有:
  // 获取当前时间,值是以毫秒为单位
  public static native long currentTimeMillis()
  // 结束Java程序运行
  public static void exit(int status)
  // 数组复制
  public static native
  void arraycopy(Object src, int srcPos, Object dest, int destPos, int length)

  System使用示例代码如下:

     static void useSystem() {
// 获取当前时间,单位是毫秒
long time = System.currentTimeMillis(); // 将数组1复制到数组2
int[] arr1 = {1, 2, 3, 4, 5};
int[] arr2 = new int[5];
System.arraycopy(arr1, 0, arr2, 0, arr1.length); // 正常退出程序
System.exit(0);
}

本文章只是粗略的介绍了各工具类的用法,更详细的用法请观看相应的API文档。

如有错误,敬请指出。

JDK中工具类的使用的更多相关文章

  1. JDK中String类的源码分析(二)

    1.startsWith(String prefix, int toffset)方法 包括startsWith(*),endsWith(*)方法,都是调用上述一个方法 public boolean s ...

  2. 观察者模式学习--使用jdk的工具类简单实现

    观察者模式学习之二:使用jdk的自带的工具类实现,与自己实现相比,两者有以下的区别: 1,自己实现,需要定义观察者的接口类和目标对象的接口类.使用java util的工具类,则不需要自己定义观察者和目 ...

  3. JDK并发工具类

    在JDK的并发包里提供了几个非常有用的并发工具类.CountDownLatch.CyclicBarrier和Semaphore工具类提供了一种并发流程控制的手段,Exchanger工具类则提供了在线程 ...

  4. JDK中Unsafe类详解

    Java中Unsafe类详解 在openjdk8下看Unsafe源码 浅析Java中的原子操作 Java并发编程之LockSupport http://hg.openjdk.java.net/jdk7 ...

  5. JDK中Integer类的进制转换实现

    JDK中关于Integer类的进制转换方法很精巧,具体实现如下: final static char[] digits = { '0' , '1' , '2' , '3' , '4' , '5' , ...

  6. JDK中String类的源码分析(一)

    1.String类是final的,不允许被继承 /** The value is used for character storage. */ private final char value[]; ...

  7. 利用jdk中工具完成Java程序监控方法记录

    转载加自己整理的部分内容,转载自:http://jiajun.iteye.com/blog/810150 记录下JConsole使用方法 一.JConsole是什么    从Java 5开始 引入了 ...

  8. JDK中哪些类是不能继承的?

    不能继承的是类是那些用final关键字修饰的类. 实际上即使我们自己开发的类,也可以通过使用final修饰来阻止被继承.通过使用final修饰一个类,可以阻止该类被继承,这样该类就被完全地封闭起来了, ...

  9. 使用JDK中的类URL访问HDFS(来自吴超Hadoop)

    package hdfs; import java.io.InputStream; import java.net.URL; import org.apache.hadoop.fs.FsUrlStre ...

随机推荐

  1. [Mapreduce]eclipse下写wordcount

    上传两个文件到hdfs上的input目录下 代码例如以下: import java.io.IOException; import java.util.StringTokenizer; import o ...

  2. JS调用Delphi编写的OCX控件

    原文:http://www.mamicode.com/info-detail-471283.html 一.使用Delphi XE2编写OCX控件 生成OCX工程: 1.File-New-Other,在 ...

  3. iOS开发——实用篇Swift篇&项目开发常用实用技术

    项目开发常用实用技术 实现拨打电话 要实现打电话功能,最简单最直接的方式便是:直接跳到拨号界面 (注意:这个需要真机调试,模拟器无效果)     UIApplication.sharedApplica ...

  4. Ruby on Rails Tutorial 第一章 之 简介

    1.目标:掌握MVC和REST.生成器.迁移.路由.嵌入式Ruby 本书涉及Rails,Ruby语言,Rails默认使用的测试框架(MiniTest),Unix命令行,HTML,CSS,少量的Java ...

  5. C#_判断2个对象的值是否相等

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  6. PS将图标变灰

    方法一:直接去色,图像——调整——去色:快捷键ctrl+shift+U 方法二:图像——调整——灰白:快捷键shift+ctrl+alt+B;

  7. linux乱码问题

    命令输入: export LANG=zh_CN.GBK grep 匹配时高亮 先执行:export GREP_OPTIONS='--color=auto'; 后执行:grep 匹配内容 文件; 描述: ...

  8. 如何在linux下解压缩rar和zip格式的文件压缩包

    转载:http://oldboy.blog.51cto.com/2561410/597515 使用apt-get安装:  sudo apt-get install  rar  zip rar使用: 将 ...

  9. hdu 4417 划分树

    思路:二分枚举区间第k大.用划分树查找是否符合要求的高度. #include<iostream> #include<algorithm> #include<cstdio& ...

  10. 转:Android开发中的MVP架构(最后链接资源不错)

    Android开发中的MVP架构 最近越来越多的人开始谈论架构.我周围的同事和工程师也是如此.尽管我还不是特别深入理解MVP和DDD,但是我们的新项目还是决定通过MVP来构建. 这篇文章是我通过研究和 ...