zoukankan      html  css  js  c++  java
  • 一脚踩进java之基础篇28——常用API(Arrays类,大数据运算)

    一、Arrays类

    1.1 概念

    此类包含用来操作数组(比如排序和搜索)的各种方法。需要注意,如果指定数组引用为 null,则访问此类中的方法都会抛出空指针异常NullPointerException

    1.2 常用方法

       1)sort方法,用来对指定数组中的元素进行排序(元素值从小到大进行排序)

    //源arr数组元素{1,5,9,3,7}, 进行排序后arr数组元素为{1,3,5,7,9}
    int[] arr = {1,5,9,3,7};
    Arrays.sort( arr );

      2)toString方法,用来返回指定数组元素内容的字符串形式

    int[] arr = {1,5,9,3,7};
    String str = Arrays.toString(arr); // str的值为[1, 3, 5, 7, 9]

      3)binarySearch方法,在指定数组中,查找给定元素值出现的位置。若没有查询到,返回位置为-1。要求该数组必须是个有序的数组。

    int[] arr = {1,3,4,5,6};
    int index = Arrays.binarySearch(arr, 4); //index的值为2
    int index2= Arrasy.binarySearch(arr, 2); //index2的值为-1

    1.3 Arrays类的方法练习

      1)练习一:定义一个方法,接收一个数组,数组中存储10个学生考试分数,该方法要求返回考试分数最低的后三名考试分数。

    public static int[] method(double[] arr){
        Arrays.sort(arr); //进行数组元素排序(元素值从小到大进行排序)
        int[] result = new int[3]; //存储后三名考试分数
        System.arraycopy(arr, 0, result, 0, 3);//把arr数组前3个元素复制到result数组中
      return result;
    }

    二、大数据运算

    2.1 BigInteger

    java中long型为最大整数类型,对于超过long型的数据如何去表示呢.在Java的世界中,超过long型的整数已经不能被称为整数了,它们被封装成BigInteger对象.在BigInteger类中,实现四则运算都是方法来实现,并不是采用运算符.

      BigInteger类的构造方法:

    构造方法中,采用字符串的形式给出整数

    四则运算代码:

    public static void main(String[] args) {
            //大数据封装为BigInteger对象
            BigInteger big1 = new BigInteger("12345678909876543210");
            BigInteger big2 = new BigInteger("98765432101234567890");
            //add实现加法运算
            BigInteger bigAdd = big1.add(big2);
            //subtract实现减法运算
            BigInteger bigSub = big1.subtract(big2);
            //multiply实现乘法运算
            BigInteger bigMul = big1.multiply(big2);
            //divide实现除法运算
            BigInteger bigDiv = big2.divide(big1);
    }

    2.2 BigDecimal

    在程序中执行下列代码,会出现什么问题?

        System.out.println(0.09 + 0.01);

        System.out.println(1.0 - 0.32);

        System.out.println(1.015 * 100);

        System.out.println(1.301 / 100);

     double和float类型在运算中很容易丢失精度,造成数据的不准确性,Java提供我们BigDecimal类可以实现浮点数据的高精度运算

       构造方法如下:

    建议浮点数据以字符串形式给出,因为参数结果是可以预知的

      实现加法减法乘法代码如下: 

    public static void main(String[] args) {
              //大数据封装为BigDecimal对象
              BigDecimal big1 = new BigDecimal("0.09");
              BigDecimal big2 = new BigDecimal("0.01");
              //add实现加法运算
              BigDecimal bigAdd = big1.add(big2);
              
              BigDecimal big3 = new BigDecimal("1.0");
              BigDecimal big4 = new BigDecimal("0.32");
              //subtract实现减法运算
              BigDecimal bigSub = big3.subtract(big4);
              
              BigDecimal big5 = new BigDecimal("1.105");
              BigDecimal big6 = new BigDecimal("100");
              //multiply实现乘法运算
              BigDecimal bigMul = big5.multiply(big6);
    }

    对于浮点数据的除法运算,和整数不同,可能出现无限不循环小数,因此需要对所需要的位数进行保留和选择舍入模式

     

  • 相关阅读:
    ASP.NET中自定义控件无法响应事件的问题
    通过编程为ASP.NET页面设置缓存
    VB.NET中Module的概念
    IDENTITY列及其编号的问题
    使用XML RPC进行远程调用
    存储过程编写和优化的经验
    为控件添加设计期支持
    SSIS的一个问题
    多线程编程中的锁定(lock,Monitor)
    汉字的奥秘: 获取汉字的笔画数
  • 原文地址:https://www.cnblogs.com/smilehq/p/12883013.html
Copyright © 2011-2022 走看看