JAVA基础:Arrays类

一. 概述

概述

在这里插入图片描述

package Test;

import java.util.Arrays;

public class Test {
    public static void main(String[] args){
//        目标:学会使用Arrays类的常用API,并理解其原理
        int[] arr={10,2,55,23,24,100};
        System.out.println(arr);

//        1.返回数组内容的 toString(数组)
//        String rs=Arrays.toString(arr)
//        System.out.println(rs);
        System.out.println(Arrays.toString(arr));

//        2.排序的API(默认自动对数组元素进行升序排序)
        Arrays.sort(arr);
        System.out.println(Arrays.toString(arr));

//        3.二分搜索技术(前提数组必须排好序才支持,否则出bug)
        int index=Arrays.binarySearch(arr,55);
        System.out.println(index);

//        返回不存在元素的规律:-(应该插入的位置索引+1)
        int index2=Arrays.binarySearch(arr,22);
        System.out.println(index2);

//        注意:数组如果没有排好序,可能会找不到存在的元素,从而出现bug!!
        int[] arr2={12,36,34,25,13,24,234,100};
        System.out.println(Arrays.binarySearch(arr2,36));
    }
}

排序方法

在这里插入图片描述

package Test;


import java.util.Arrays;
import java.util.Comparator;

public class Test2 {
    public static void main(String[] args) {
//        目标:自定义数组的排序规则:Comparator比较器对象
//        1.Arrays的sort方法对于有值特性的数组是默认升序排列
        int[] ages={34,12,42,23};
        Arrays.sort(ages);
        System.out.println(Arrays.toString(ages));

//        2.需求:降序排序!(自定义比较器对象,只能支持引用类型的排序!!)
        Integer[] ages1={34,12,42,23};
//        参数一:被排序的数组  必须是引用类型的元素
//        参数二:匿名内部类对象,代表了一个比较器对象

//        如果o1大就把它排在后面
        Arrays.sort(ages1, new Comparator<Integer>() {
            @Override
            public int compare(Integer o1, Integer o2) {
//                指定比较规则
                if (o1 < o2) {
                    return 1;
                }else if (o1 > o2) {
                    return -1;
                }
//                return 0;
//                return o1-o2;//默认升序
                return o2-o1;//降序

            }
        });
        System.out.println(Arrays.toString(ages1));

        System.out.println("------------------------");
        Student[] students = new Student[3];
        students[0] = new Student("吴磊",23,175.5);
        students[1] = new Student("吴磊",18,185.5);
        students[2] = new Student("吴磊",20,195.5);
        System.out.println(Arrays.toString(students));


//        Arrays.sort(students);//直接运行崩溃
        Arrays.sort(students,new Comparator<Student>() {
            @Override
            public int compare(Student t1,Student t2) {
//                自己指定比较规则
//                return t1.getAge()-t2.getAge();//按照年龄升序排序
//                return t2.getAge()-t1.getAge();//按照年龄降序排序
//                return Double.compart(t1.getHeight(),t2.getHeight());比较浮点型都可以这样写  升序
                return Double.compare(t2.getHeight(),t1.getHeight());//比较浮点型可以这样写  降序

            }
        });
        System.out.println(Arrays.toString(students));


    }
}

二,选择排序,二分查找

在这里插入图片描述

package Test;

import java.util.Arrays;

//目标:学会使用选择排序的方法对数组进行排序
public class Test2 {
    public static void main(String[] args) {
//        1.定义数组
        int[] arr={5,1,3,2};
//                 0 1 2 3

//        2.定义一个循环控制选择几轮:arr.length-1
        for (int i=0;i<arr.length-1;i++) {
//            i=0    j= 1  2  3
//            i=1    j= 2  3
//            j=2    j= 3
//            3.定义内部循环,控制选择几次
            for (int j=i+1;j<arr.length;j++){
//                当前位:arr[i]
//                如果有比当前位数据更小的,则交换
                if (arr[i]>arr[j]){
                    int temp=arr[i];
                    arr[i]=arr[j];
                    arr[j]=temp;
                }
            }
        }
        System.out.println(Arrays.toString(arr));

    }
}

在这里插入图片描述
**注意:**如果没有排序,那就找不出来了

package Test;

import java.util.Arrays;

//目标:理解二分搜索的原理并实现
public class Test2 {
    public static void main(String[] args) {
//        1.定义数组
        int[] arr={10,14,16,25,28,30,35,88,100};
        System.out.println(binarySearch(arr,35));


    }
    /**
     * 二分查找算法的实现
     * arr  排序的数组
     * data 要找的数组
     * 索引,如果元素不存在,直接返回-1
     */
    public static int binarySearch(int[] arr,int data){
//        1.定义左边位置   和  右边位置
        int left=0;
        int right=arr.length-1;

//        2.开始循环,折半查询
        while (left<=right){
//            取中间索引
            int middleIndex=(left+right)/2;
//            3.判断当前中间位置的元素和要找的元素的大小情况
            if (data>arr[middleIndex]){
//                往右边找,左位置更新为=中间索引+1
                left=middleIndex+1;
            }else if(data<arr[middleIndex]){
//                往左边找,右边位置=中间索引-1
                right=middleIndex-1;
            }else {
                return middleIndex;
            }
        }
        return -1;//查无此元素
    }
}

三.Lambda

概述

在这里插入图片描述
在这里插入图片描述

package Test;


public class Test2 {
    public static void main(String[] args) {
//        目标:学会使用Lambda的标准格式简化匿名内部类的代码形式
//        Lambda只能简化接口中只有一个抽象方法的匿名内部类形式
//        Swimming s1=new Swimming(){
//            @Override
//            public void swim(){
//                System.out.println("老师游泳贼溜");
//            }
//        };

        Swimming s1=()->{
            System.out.println("老师游泳贼溜");
        };
        go(s1);

        System.out.println("----------------------");
//        go(new Swimming(){
//            @Override
//            public void swim(){
//                System.out.println("学生游泳很开心");
//            }
//        });

        go(()->{
            System.out.println("学生游泳很开心");
        });
    }
    public static void go(Swimming s){
        System.out.println("开始");
        s.swim();
        System.out.println("结束");
    }

}
@FunctionalInterface//一旦加上这个注释必须是函数式接口,里面只能有一个抽象方法
interface Swimming{
    void swim();
}

Lambda实战:匿名函数

概述

在这里插入图片描述

在这里插入图片描述

package Test;

import javax.swing.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.util.Arrays;
import java.util.Comparator;

public class Test4 {
    public static void main(String[] args) {
        Integer[] ages1={34,12,42,23};
        /**
         * 参数一:被排序的数组   必须是引用类型的元素
         * 参数二:匿名内部类对象,代表了一个比较器对象
         */
//        1.@FunctionalInterface : 可以简化的标志
//        灰色:也可以简化
//        Arrays.sort(ages1,new Comparator<Integer>() {
//            @Override
//            public int compare(Integer a,Integer b) {
//                return b-a;//降序
//            }
//        });
        Arrays.sort(ages1,(Integer a,Integer b)-> {
                return b-a;//降序
        });
        System.out.println(Arrays.toString(ages1));

        System.out.println("----------------------------");
        JFrame win=new JFrame("登录界面");

        JButton btn=new JButton("我是一个很大的按钮");
//        btn.addActionListener(new ActionListener() {
//            @Override
//            public void actionPerformed(ActionEvent e){
//                System.out.println("有人点我,点我,点我");
//            }
//        });

//        2.有interface就可以简化,且只有一个类
        btn.addActionListener((ActionEvent e) ->{
            System.out.println("有人点我,点我,点我");
        });

        win.add(btn);
        win.setSize(400,300);
        win.setVisible(true);



    }
}

完美简化

在这里插入图片描述

package Test;

import javax.swing.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.util.Arrays;
import java.util.Comparator;

public class Test4 {
    public static void main(String[] args) {
        Integer[] ages1={34,12,52,23};
//        简化案例一:
        Arrays.sort(ages1,(Integer o1,Integer o2)->{
            return o2-o1;
        });
//        极致简化
        Arrays.sort(ages1,(o1,o2)->{
            return o2-o1;
        });
//        极致简化
        Arrays.sort(ages1,(o1,o2)->o2-o1);

//        简化案列二:
        JFrame win=new JFrame("登录界面");
        JButton btn=new JButton("我是一个很大的按钮");
        btn.addActionListener((ActionEvent e)->{
            System.out.println("有人点我,点我,点我");
        } );
//        极致简化
        btn.addActionListener(( e)->{
            System.out.println("有人点我,点我,点我");
        } );
//        极致简化
        btn.addActionListener( e->{
            System.out.println("有人点我,点我,点我");
        } );
//        极致简化
        btn.addActionListener( e-> System.out.println("有人点我,点我,点我"))

    }
}

四.正则表达式

初体验

在这里插入图片描述

package Test;

import java.util.Arrays;

public class Test {
    public static void main(String[] args){
//        需求:校验qq号码,必须全部数字6-20位
        System.out.println(checkQQ("251425998"));
        System.out.println(checkQQ("251425a98"));
        System.out.println(checkQQ(null));
        System.out.println(checkQQ("2344"));

        System.out.println("----------------------");
//        正则表达式的初体验
        System.out.println(checkQQ2("251425998"));
        System.out.println(checkQQ2("251425a98"));
        System.out.println(checkQQ2(null));
        System.out.println(checkQQ2("2344"));


    }

    public static boolean checkQQ2(String qq){
        return qq!=null && qq.matches(("\\d{6,20}"));
    }
    public static boolean checkQQ(String qq){
//        1.判断qq号码的长度是否满足要求
        if (qq==null||qq.length()<6||qq.length()>20){
            return false;
        }
//        2.判断qq中是否全部是数字,不是返回false
//        251425a87
        for (int i=0;i<qq.length();i++){
//            获取每位数字
            char ch=qq.charAt(i);//charAt用来取字符串
//            判读这个字符是否不是数字,不是数字直接返回false
            if (ch<'0' || ch>'9' ){
                return false;
            }
        }
        return true;//肯定合法
    }
}

常用规则

在这里插入图片描述

package Test;

import java.util.Arrays;
//目标:全面,深入学习正则表达式的规则
public class Test {
    public static void main(String[] args){
//        public Boolean matches(String regex):判断是否与正则表达式匹配,匹配返回true
//        只能是a  b  c
        System.out.println("a".matches("[abc]"));//true
        System.out.println("z".matches("[abc]"));//false

//        不能出现a  b  c
        System.out.println("a".matches("[^abc]"));//false
        System.out.println("z".matches("[^abc]"));//true

        System.out.println("a".matches("\\d"));//false
        System.out.println("3".matches("\\d"));//true
        System.out.println("333".matches("\\d"));//false
        System.out.println("z".matches("\\w"));//true
        System.out.println("2".matches("\\w"));//ture
        System.out.println("21".matches("\\w"));//false
        System.out.println("你".matches("\\w"));//false
        System.out.println("你".matches("\\w"));//true
        System.out.println("--------------------------------");
//        以上正则匹配只能检验单个字符

//        校验密码
//        必须是数字   字母   下划线    至少6位
        System.out.println("2442fsfsf".matches("\\w{6,}"));
        System.out.println("244f".matches("\\w{6,}"));

//        验证码  必须是数字和字符   必须是4位
        System.out.println("23dF".matches("[a-zA-Z0-9]{4}"));
        System.out.println("23_F".matches("[a-zA-Z0-9]{4}"));
        System.out.println("23dF".matches("[\\w&&[^_]]{4}"));
        System.out.println("23_F".matches("[\\w&&[^_]]{4}"));


    }
}

案例

在这里插入图片描述

package Test;

import java.util.Arrays;
import java.util.Scanner;

public class Test {
    public static void main(String[] args){
//        目标:检验  手机号码  邮箱  电话号码
//        checkPhone();
//        checkEmail();
        checkTel();

//        同学可以完成检验金额是否格式金额:99 0.5 99.5 019   |0.3.3

    }
    public static void checkTel(){
        Scanner sc=new Scanner(System.in);
        while(true){
            System.out.println("请您输入您的电话号码:");
            String tel=sc.next();
//            判断邮箱格式是否正确   027-3572457   0273572457
            if (tel.matches("0\\a{2,6}-?\\d{5,20}")){
                System.out.println("格式正确,注册完成");
                break;
            }else {
                System.out.println("格式有误");
            }
        }
    }
    public static void checkEmail(){
        Scanner sc=new Scanner(System.in);
        while(true){
            System.out.println("请您输入您的注册邮箱:");
            String email=sc.next();
//            判断邮箱格式是否正确   3268847878@qq.com
//            判断邮箱格式是否正确   3268847dsda87@163.com
//            判断邮箱格式是否正确   3268847dsda878@pci.com.cn
            if (email.matches("\\w{1,30}@[a-zA-Z0-9]{2,20}(\\.[a-zA-Z0-9]{2,20}){1,2}")){
                System.out.println("邮箱格式正确,注册完成");
                break;
            }else{
                System.out.println("格式有误");
            }
        }
    }
    public static void checkPhone(){
        Scanner sc=new Scanner(System.in);
        while (true){
            System.out.println("请您输入您的注册手机号码:");
            String phone=sc.next();
//            判断手机号码的格式是否正确
            if (phone.matches("1[3-9]\\d{9}")){
                System.out.println("手机号码格式正确,注册完成");
                break;
            }else {
                System.out.println("格式有误");
            }
        }
    }
}

正则表达式方法

在这里插入图片描述

package Test;

import java.util.Arrays;
import java.util.Scanner;

/**
 * 目标:正则表达式方法的应用。
 *      public String[] split(String regx):
 *             --按照正则表达式匹配的内容进行分割字符串,返回一个字符串数组
 *      public String replace(String regx, String newStr):
 *             --按照正则表达式匹配的内容进行替换)
 */
public class Test {
    public static void main(String[] args){
        String names="小路dhdfhdf342蓉儿43fdffdfbjdfaf过儿";
        String[] arrs=names.split("\\w+");
        for (int i=0;i<arrs.length;i++){
            System.out.println(arrs[i]);
        }
        String names2=names.replaceAll("\\w+","  ");
        System.out.println(names2);
    }
}

正则表达式爬取信息

在这里插入图片描述

package Test;

import java.util.regex.Matcher;
import java.util.regex.Pattern;

/**
 * 拓展:正则表达式爬取信息中的内容。(了解)
 */
public class Test {
    public static void main(String[] args){
        String rs="来黑马程序学习Java,电话020-43422424,或者联系邮箱"+
                "itcast@itcase.cn,电话18762832633,0203232323"+
                "邮箱bozai@itcast.cn,400-100-3233,4001003232";
//        需求:从上面的内容中爬取出  电话号码和邮箱
//        1.定义爬取规则,字符串形式
        String regx="(\\w{1,30}@[a-zA-Z0-9]{2,20}(\\.[a-zA-Z0-9]{2,20}){1,2})|(1[3-9]\\d{9})"+
                "|(0\\d{2,6}-?\\d{5,20})|(400-?\\d{3,9}-?\\d{3,9})";

//        2.把这个爬取规则编译成匹配对象
        Pattern pattern=Pattern.compile(regx);

//        3.得到一个内容匹配器对象
        Matcher matcher=pattern.matcher(rs);

//        4.开始找了
        while (matcher.find()){
            String rs1=matcher.group();
            System.out.println(rs1);
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值