Java的第一遍学习笔记 常用类2

Math类

常用方法

1. abs 绝对值

System.out.println(Math.abs(-11)); //输出11

2. pow 求幂

System.out.println(Math.pow(2,3)); //2的三次方

3. ceil 向上取整    floor 向下取整    round 四舍五入(实际上是 floor(n + 0.5))

System.out.println(Math.ceil(1.1));
System.out.println(Math.floor(1.1));
System.out.println(Math.round(1.4));  // Math.floor(n+0.5)
System.out.println(Math.round(1.5));

4. sqrt 求开方

System.out.println(Math.sqrt(9));

5. random 求随机数,返回一个 [0,1) 之间的double数。

获取 a-b 之间的一个随机整数:公式为  int num = (int)(a + Math.random()*(b - a + 1));

System.out.println((int)(2 + Math.random()*(6-2+1))); //返回[2,6]之间的数

 返回 [2,6]之间的整数实际上就等于返回 [2,7)之间的整数。

6. max 求最大值,min 求最小值。

Arrays

Arrays里面包含了一系列静态方法,用于管理或操作数组(比如排序和搜索)

1. toString 返回数组的字符串形式

int[] a = {1,2,3,4,5};
System.out.println(Arrays.toString(a)); // 输出 [1, 2, 3, 4, 5]

 2. sort排序(自然排序和定制排序)

  因为数组是引用类型,因此sort会直接改变原数组。

        int[] a = {31,2,5,999,-3};
        Arrays.sort(a);  //自然排序,从小到大排列
        System.out.println(Arrays.toString(a));// [-3, 2, 5, 31, 999]

   需要重点理解的就是定制排序:它不仅需要传入一个数组,还需要实现一个匿名内部类(通过传入一个接口 Comparator 实现),传入的数组不能是基本类型,必须是包装类(如Integer),因为用到了泛型。

public static void main(String[] args) {
        Integer[] a = {31,2,5,999,-3};  // 不能是基本类型
        Arrays.sort(a, new Comparator<Integer>() {
            @Override
            public int compare(Integer o1, Integer o2) {
                return o2 - o1;   // 从大到小排
            }
        });
        System.out.println(Arrays.toString(a));  //[999, 31, 5, 2, -3]
    }

   对 return o2 - o1 的理解:实际上sort调用了父类的一个 binarySort的方法,而 o2 - o1的结果会影响方法的走向。

  而在C++中,实现自定义排序则是通过自定义函数cmp。

int cmmp(object a,object b){
    return a>b;  // 从大到小排序
    // 从小到大排序是 return a<b;
}

    而在Java并不能用boolean来代表整形,因此只能用相减是否为正来判断该走哪一步。只要记住返回 o2 - o1 是从大到小排就行了。 

3. 用冒泡排序模拟定制排序

    public static void bubbleSort(Integer a[],Comparator b){
        for(int i = 0;i<a.length-1;i++){
            for(int j = 0;j<a.length-i-1;j++){ //冒泡排序
                if(b.compare(a[j],a[j+1])<0){ //根据compare的返回结果判定是否交换
                                              // 这与真正的compare思想一致
                    int temp = a[j];
                    a[j] = a[j+1];
                    a[j+1] = temp;
                }//调用Comparator接口的compare方法
            }
        }
    }
public static void main(String[] args) {
        Integer[] a = {31,2,5,999,-3};
        bubbleSort(a, new Comparator() {  //匿名内部类
            @Override
            public int compare(Object o1, Object o2){ 
                int n1 = (Integer)o1;
                int n2 = (Integer)o2;
                return n1 - n2; 
            }
        }); 
        System.out.println(Arrays.toString(a)); // [999, 31, 5, 2, -3]
    }

  根据compare的具体实现,n1 - n2 < 0时进行交换,即n1小于n2时交换,也就是说最后是从大到小排列。

4. binarySearch  二分查找

    通过二分搜索法进行查找,返回对应元素的索引,要求必须排好序如果该数组中不存在该元素,则返回 -(low + 1),其中low最终是 查找元素应该位于的索引

Integer[] a = {1,2,3,4,5};
int index1 = Arrays.binarySearch(a,5); // 输出4
int index2 = Arrays.binarySearch(a,6); // 输出-6 ,如果6存在的话索引应该是5

5. copyOf  数组元素的复制 

Integer[] a = new Integer[]{1,2,3,4,5}; 
Integer[] newArr = Arrays.copyOf(a,3); //复制3个元素
System.out.println(Arrays.toString(newArr)); //[1, 2, 3]

  如果拷贝的长度 > a.length ,那么就在新数组的后面增加 null,如果拷贝长度 < 0,就会抛出异常NegativeArraySizeException。

Integer[] newArr = Arrays.copyOf(a,10); 
//[1, 2, 3, 4, 5, null, null, null, null, null]

Integer[] newArr = Arrays.copyOf(a,-1);
//  Exception in thread "main" java.lang.NegativeArraySizeException 

6. fill  数组元素的填充

Integer[] a = new Integer[]{1,2,3,4,5};
Arrays.fill(a,1000);
System.out.println(Arrays.toString(a)); // [1000, 1000, 1000, 1000, 1000]

7. equals  比较两个数组元素内容是否完全一致

        Integer[] a = new Integer[]{1,2,3,4,5};
        Integer[] b = new Integer[]{1,2,3,4,5};
        Integer[] c = new Integer[]{1,3,2,4,5};
        System.out.println(Arrays.equals(a,b)); // true
        System.out.println(Arrays.equals(a,c)); // false,顺序不一样也不行

8. asList  将一组值转换成list(链表)

  asList编译类型为 List(接口),运行类型为 java.util.Arrays$ArrayList,是Arrays类的。

List<Integer> asList = Arrays.asList(2,3,4,5,6,1);
System.out.println(asList.getClass()); // class java.util.Arrays$ArrayList

System

1. exit  退出当前程序。

System.exit(0); // 0表示一个正常的状态。

2. arraycopy:复制数组元素,比较适合底层调用。一般还是使用 Arrays.copyOf 完成复制数组。

System.arraycopy(src,srcPos,dest,destPos,length);

 src:源数组(提供数据)。srcPos:从源数组的哪个索引位置开始拷贝。dest:目标数组。 

destPos:从源数组的数据拷贝到目标数组的哪个索引。 length:从源数组拷贝多少个数据。

3. currentTimeMillens:返回当前时间距离1970-1-1的毫秒数。

System.out.println(System.currentTimeMillis());

4. gc:运行垃圾回收机制 System.gc();

大数

1. BigInteger适合保存比较大的整形

2. BigDecinal适合保存精度更高的浮点型。

大数不能用符号加减乘除,而需要调用方法,这里只拿BigDecinal进行演示:

        BigDecimal a = new BigDecimal("1.23213131391123131");
        BigDecimal b = new BigDecimal("2.22222"); 
        System.out.println(a.add(b));  //加
        System.out.println(a.subtract(b));  //减
        System.out.println(a.multiply(b));  //乘

    这里只需要注意一点:除法的结果可能是个无限小数,如果是这样的话会报错。为了避免报错,我们可以指定精度(保留分子的精度)。 

System.out.println(a.divide(b,BigDecimal.ROUND_CEILING)); //保留分子精度

Date

第一代Date类

  引用 java.util.Date(不要引入sql的Date类)

        Date a = new Date(); 
        Date b = new Date(111111);//1970-1-1开始经过的毫秒数
        System.out.println(a); //用国外的方式输出当前日期 Wed Sep 29 21:02:51 CST 2021
        System.out.println(b);
        System.out.println(a.getTime()); //获取某个时间对应的毫秒数

第二代日期类

1. Calendar是一个抽象类,并且构造器为 private。

2. 可以通过 getInstance() 来获取实例。

3. 提供大量的方法和字段提供给程序员。

4. Calendar 没有专门的格式化方法,所以需要程序员自己来组合显示。

    public static void main(String[] args) {
        // Calendar a = new Calendar(); //报错,因为抽象类需要实现方法(但是超级多)
        Calendar a = Calendar.getInstance();// 正确的获取对象方法
        System.out.println(a); //输出全部信息
        System.out.println(Calendar.YEAR);
        System.out.println(a.get(Calendar.YEAR));  //输出年份
        System.out.println(a.get(Calendar.MONTH) + 1); // 加一是因为从0开始计数
        System.out.println(a.get(Calendar.DAY_OF_MONTH)); //输出第几天
        System.out.println(a.get(Calendar.HOUR)); //输出今天的小时(12小时表示法)
        System.out.println(a.get(Calendar.HOUR_OF_DAY)); //(24小时表示法)
        System.out.println(a.get(Calendar.MINUTE)); //小时的分
        System.out.println(a.get(Calendar.SECOND)); //分的秒
    }

    注意,如果想输出当前年份,光输出 Calendar.YEAR 是不行的,因为 Calendar.YEAR 等只是一个数,而需要调用get方法才能正确输出对应信息(里面有类似的switch语句,根据数字输出对应的东西)。

第三代日期类

1. LocalDateTime类,用于获取年月日和时分秒。

        //LocalDateTime ldt = new LocalDateTime(); //错误的构造方法
        LocalDateTime ldt = LocalDateTime.now();  //正确的构造方法,可以获取年月日和时间
        System.out.println(ldt); //输出当前完整时间信息
        System.out.println(ldt.getYear()); //输出年份
        System.out.println(ldt.getMonth()); //输出月份(英文)
        System.out.println(ldt.getMonthValue());//输出月份(阿拉伯数字)
        System.out.println(ldt.getHour()); // 输出小时(当然还能得到分和秒)
        ...

2. LocalDate类,只能获取年月日。LocalTime类,只能获取时分秒。 

        LocalDate now = LocalDate.now(); //用于获取年月日
        LocalTime now2 = LocalTime.now();//用于获取时分秒

3. DateTimeFormatter格式日期类 

public class Test{
    public static void main(String[] args) {
        LocalDateTime ldt = LocalDateTime.now();
        DateTimeFormatter dtf1 = DateTimeFormatter.ofPattern("yyyy年MM月dd日 HH小时mm分钟ss秒");
        //这里yyyy等不区分大小写,但必须是这个字母。
        DateTimeFormatter dtf2 = DateTimeFormatter.ofPattern("yyyy-mm-dd HH:mm:ss");
        //字母对应时间,剩下的可以自己定义格式
        String strDate1 = dtf1.format(ldt); //调用format方法,LocalDateTime类为参数
        String strDate2 = dtf2.format(ldt);
        System.out.println(strDate1);
        System.out.println(strDate2);
    }
}

4. 时间戳

1) 通过静态方法获取对象

        Instant now = Instant.now();
        //用静态方法 now 获取表示当前时间戳的对象
        //Instant now = new Instant();  错误
        System.out.println(now); // 2021-10-03T14:36:07.540Z

2) 通过 Date类的from静态方法 可以把 Instant类转成 Date类

    Date date = Date.from(now);
    System.out.println(date.getTime());

3) 通过 Date对象的toInstant方法可以把 date类 转换成 Instant类

Instant instant = date.toInstant();

5.  plus和minus

通过提供 plus 和 minus方法可以对当前时间进行加或

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值