• 7天学完Java基础之4/7


    静态static

    如果一个成员变量使用了static关键字,那么这个变量不再属于对象自己,而是属于所在的类,多个对象共享同一份数据

    静态static 关键字修饰成员变量

    public class Student {
        private String name;
        private int age;
        static String room;
        public Student() {
        }
    
        public Student(String name, int age) {
            this.name = name;
            this.age = age;
        }
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public int getAge() {
            return age;
        }
    
        public void setAge(int age) {
            this.age = age;
        }
    }
    
    
    public static void main(String[] args){
        Student one = new Student("郭靖",18);
        //用对象名.变量名给变量赋值
        one.room = "101";
        Student two = new Student("黄蓉",16);
         //姓名:郭靖  年龄18  教室105
        System.out.println("姓名:" +one.getName()+"  年龄"+one.getAge()+"  教室"+one.room);
        
        //没有对two.room赋值但是也输出了教室101,可见被static修饰过的变量的数据是共享的
        //姓名:黄蓉  年龄16  教室105
        System.out.println("姓名:" +two.getName()+"  年龄"+two.getAge()+"  教室"+two.room);
        }
    

    静态static关键字修饰成员方法

    一旦使用static修饰成员方法,那么这就成为了静态方法,静态方法不属于对象,而是属于类的

    如果没有static关键字,那么必须首先创建对象,然后通过对象才可以使用他

    有static关键字可以通过类名.静态方法名调用方法

    public class MethodDemo {
       public void method(){
           System.out.println("这是一个成员方法");
       }
       public static void method1(){
           System.out.println("这是一个静态方法");
       }
    }
    
    public class MethodTest {
        public static void main(String[] args){
            MethodDemo one = new MethodDemo();
            //对象名调用方法
            one.method();
            //对象名调用方法
            one.method1();
            //类名调用静态方法
            MethodDemo.method1();
        }
    

    如果有了static,都推荐使用类名称来调用

    注意事项

    1. 静态不能直接访问非静态
    public class MethodDemo {
        int num ;
        static int num1;
       public void method(){
           System.out.println("这是一个成员方法");
           //成员方法访问成员变量和静态变量
           System.out.println(num);
           System.out.println(num1);
           
       }
       public static void method1(){
           System.out.println("这是一个静态方法");
           //静态方法访问静态变量
           System.out.println(num1);
           //静态方法不能够访问非静态变量
           //System.out.println(num);编译报错
       }
    
    
    1. 静态方法不能使用this,因为this代表当前对象,而静态方法属于类。
    静态代码块

    特点,当第一次用到本来的时候,静态代码块执行唯一一次

    /*格式
    public class 类名{
    	static{}
    }*/
    public class StaticDemo {
        static{
            System.out.println("静态代码块执行了");
        }
        public StaticDemo(){
            System.out.println("构造方法执行了");
        }
    }
    
    public class StaticDemotest {
        public static void main(String[] args) {
            //静态代码块只会执行一次,并且优先于其他语句执行
            StaticDemo one =new StaticDemo();
            StaticDemo two = new StaticDemo();
        }
    
    }
    //输出结果
    静态代码块执行了
    构造方法执行了
    构造方法执行了
    
    Arrays工具类

    public static String toStirng(数组),将参数数组变成字符串

    public static void main(String[] args) {
            int[] arrays= new int[]{1,2,3,4,5};
            String[] arrays1 = new String[]{"骐骥一跃","不能十步","驽马十驾","功在不舍"};
            //调用Arraysd的toString方法把数组变成字符串
            String str = Arrays.toString(arrays);
            String str1 = Arrays.toString(arrays1);
            //打印字符串
            System.out.println(str);
            System.out.println(str1);
    
        }
    

    public static void sort(数组),按照默认升序,对数组元素排序

    public static void main(String[] args) {
            int[] arrays= new int[]{1,63,45,55,88};
            String[] arrays1 = new String[]{"骐骥一跃","不能十步","驽马十驾","功在不舍"};
    
            //对数组进行排序
            Arrays.sort(arrays);
            Arrays.sort(arrays1);
            //排序完之后,把他变成字符串,打印输出
            System.out.println(Arrays.toString(arrays));
            System.out.println(Arrays.toString(arrays1));
    //输出结果如下
    //[1, 45, 55, 63, 88]
    //[不能十步, 功在不舍, 驽马十驾, 骐骥一跃]
        }
    
    Arrays字符串倒序练习
    public static void main(String[] args) {
            //先创建一个字符串
            String str = "ERsdf485dfW";
            //要排序字符串,需要把字符串变成char数组,可以使用toCharArray方法
            char[] chars = str.toCharArray();
            //把字符串用sort方法排序好
            Arrays.sort(chars);
            //然后就可以for循环遍历来倒序
            //chars数组的最大索引为长度减一,索引为0也有元素,索引需要>=0
            for(int i=chars.length-1;i>=0;i--){
                System.out.println(chars[i]);
            }
    
        }
    
    继承

    继承的格式

    public class zi extends fu{}
    

    继承中成员变量的访问特点

    在子父类的继承关系当中,如果有成员变量重名,则创建子类对象时,访问有两种方式

    直接通过子类对象访问成员变量

    等号左边是谁,就优先有谁,没有则向上找

    public class Fu {
        //父类
        int num = 100;
    }
    
    public class Zi extends Fu{
        //子类
        int num = 200;
    }
    
    public static void main(String[] args) {
         Zi zi = new Zi();
        //输出的时100还是200?
         System.out.println(zi.num);//200
        }
    

    间接通过成员方法访问成员变量

    方法属于谁,就优先用谁,没有则向上找

    public class Fu {
        //父类
        int num = 100;
        public void methodFu(){
            System.out.println(num);
        }
    }
    
    public class Zi extends Fu{
        int numZi = 10;
        int num = 200;
        public void methodzi(){
            System.out.println(num);
        }
    
    public static void main(String[] args) {
            Zi zi = new Zi();
            //输出的时100还是200?
            System.out.println(zi.num);//200
            //这个方法是子类的,优先使用子类的成员变量
            zi.methodzi();//200
            //这个方法是父类的,优先使用父类的成员变量
            zi.methodFu();//100
        }
    

    区分子类方法中重名的三种变量

    public class Fu {
        int num = 10;
    }
    
    public class Zi extends Fu{
        int num = 20;
        public void method(){
            int num = 30;
            //输出局部变量
            System.out.println(num);
            //输出本类变量
            System.out.println(this.num);
            //输出父类变量
            System.out.println(super.num);
        }
    }
    
    /*
    *局部变量:
    * 本类的成员变量
    * 父类的成员变量
    * */
    public class ExtendsTest {
        public static void main(String[] args) {
            Zi zi = new Zi();
            //调用Zi类方法
            zi.method();
        }
    }
    

    继承中成员方法的访问特点

    public class Fu {
        public void methodFu(){
            System.out.println("父类方法");
        }
        public void method(){
            System.out.println("父类重名方法执行");
        }
    }
    
    public class Zi extends Fu{
        public void methodZi(){
            System.out.println("子类方法执行");
        }
        public void method(){
            System.out.println("子类重名方法执行");
        }
    }
    
    public class ExtendsTest {
        public static void main(String[] args) {
            Zi zi = new Zi();
            //调用Zi类方法
            zi.methodFu();
            zi.methodZi();
            //方法重名,优先使用子类方法
            zi.method();
        }
    }
    

    重写(Override)

    概念:在继承关系当中,方法的名称一样,参数列表也一样

    重写(Override),方法的名称一样,参数列表也一样

    重载(Overload),方法的名称一样,参数列表不一样

    继承中构造方法的访问特点

    public class Fu {
        public Fu(){
            System.out.println("我是无参数的父类构造方法");
        }
        public Fu(int num){
            System.out.println("我是有参数的父类重载构造");
        }
    }
    
    public class Zi extends Fu{
    
        public Zi(){
            //在继承关系中,编译器都会默认赠送一个super()父类构造方法;
            //而且还是在子类构造方法的第一行,所以在new对象的时候会先执行
            // 父类的构造方法
            // super();
            super(5);
            //在继承关系中,子类会有一个默认的super();
            System.out.println("子类构造方法");
        }
    }
    
    /*
    继承关系中,父子类构造方法的访问特点
    1.子类构造方法当中有一个默认隐含的"super()"调用
    2.子类构造可以通过super关键字来调用父类重载构造
    super的父类构造调用,必须在构造方法的第一句
     */
    public class ConstructorDemo {
        public static void main(String[] args) {
            Zi zi = new Zi();
            //父类构造方法
            //子类构造方法
        }
    }
    

    super关键字的三种用法

    1.在子类的成员方法中,访问父类的成员变量。super.numFu

    2.在子类的成员方法中,访问父类的成员方法。super.methodFu

    3.在子类的构造方法中,访问父类的构造方法。

    this关键字的三种用法

    super关键字用来访问父类内容,而this关键字用来访问本类内容,用法也有三种

    1.在本类中的成员方法中,访问本类的成员变量

    public class Zi extends Fu {
        int num = 55;
    public void athis() {
        int num = 66;
        System.out.println(num);//66
        System.out.println(this.num);//55
       }
    }
    

    2.在本类的成员方法中,访问本类的另一个成员方法,

        int num = 55;
        public void athis() {
            int num = 66;
            System.out.println(num);//66
            System.out.println(this.num);//55
        }
        public void bthis(){
            System.out.println("bbb");
        }
        public void cthis(){
            this.athis();
            System.out.println("ccc");
        }
    
     public static void main(String[] args) {
            new Zi().cthis();//输出结果为66 55 ccc
        }
    

    3.在本类的构造方法中,访问本类的另一个构造方法

    public Zi(){
        	//重载构造方法两个
        	//调用下一个构造方法
           this(123);
        }
        public Zi(int n){
            //调用下一个构造方法
           this(1,2);
        }
        public Zi(int a,int b){
            
        }
    //注意this()调用跟super()一样也必须是构造方法的第一个语句,super和this两张构造调用,不可以同时使用。
    

    练习

    public class Fu {
        int num = 5;
        public Fu(){
            System.out.println("我是构造方法");
        }
        public void method(){
            System.out.println("我是父类");
        }
    }
    
    
    public class Zi extends Fu {
        int num = 6;
    
        public void method1(){
            int num = 7;
            System.out.println(num);
            System.out.println(this.num);
            System.out.println(super.num);
        }
        @Override
        public void method(){
            super.method();
            System.out.println("我是子类");
        }
    }
    
    public class ConstructorDemo {
        public static void main(String[] args) {
            Zi zi = new Zi();
            zi.method1();
            zi.method();
    		//我是构造方法
    		//7
    		//6
    		//5
    		//我是父类
        }
    }
    

    Java继承的三个特点

    1.Java语言是单继承的,一个类的直接父类只有由唯一一个

    1. Java语言可以多级继承,也就是A类继承B类,B类继承C类
    2. 一个类的直接父类是唯一的,但是父类可以由很多个子类,

    抽象类

    public abstract class 类名{
        public abstract void 方法名(){}
        //抽象类中也可以定义普通成员方法
        public void 方法名(){}
    }
    

    抽象方法和抽象类的使用

    1. 抽象类不能够直接new的抽象类对象
    2. 必须用一个子类继承抽象类才可以使用
    3. 子类必须重写抽象父类当中的所有抽象方法
    4. 创建子类对象进行使用

    抽象方法和抽象类的注意事项

    1. 抽象类不能够创建对象

    2. 抽象类,可以有构造方法的,是供子类创建对象时,初始化成员使用的

    3. 抽象类中,不一定包含抽象方法,但是抽象方法一定包含在抽象类中

    4. 抽象类的子类,必须重写抽象父类的所有抽象方法

    红包案例

    public class AUser {
        private int money ;
        private String name ;
    
        public AUser() {
        }
    
    
        public AUser(int money, String name) {
            this.money = money;
            this.name = name;
        }
    
        public int getMoney() {
            return money;
        }
    
        public void setMoney(int money) {
            this.money = money;
        }
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public void show(){
            System.out.println("我"+name+"现在的余额是"+money);
        }
    }
    
    
    import java.lang.reflect.Array;
    import java.util.ArrayList;
    
    public class Admin extends AUser{
        public Admin() {
        }
    
        public Admin(int aBalance, String aName) {
            super(aBalance, aName);
        }
    
        public ArrayList<Integer> send(int totalMoney, int count){
            ArrayList<Integer> redList = new ArrayList<>();
            int  i= totalMoney/count;
            //判断群主有多少钱
            int leftMony = super.getMoney();
            if(totalMoney>leftMony){
                System.out.println("余额不足");
                return redList;
            }
            //扣钱
            super.setMoney(leftMony -totalMoney);
            int avg = totalMoney/count;
            int mod = totalMoney%count;
    
            for(int d=0;d<count-1;d++){
                redList.add(avg);
            }
            int last=  avg+mod;
            redList.add(last);
            return redList;
        }
    }
    
    
    import java.util.ArrayList;
    import java.util.Random;
    
    public class Menber extends  AUser{
        public Menber() {
        }
    
        public Menber(int money, String name) {
            super(money, name);
        }
        public void receive(ArrayList<Integer> list){
            int index = new Random().nextInt(list.size());
            int delta = list.remove(index);
            int money = super.getMoney();
            super.setMoney(money+delta);
    
        }
    
    }
    
    
    import java.util.ArrayList;
    
    public class RedPacket {
        public static void main(String[] args) {
            Admin admin = new Admin(100,"群主");
            Menber one = new Menber(0,"aaa");
            Menber two = new Menber(0,"aaa");
            Menber three = new Menber(0,"aaa");
            admin.show();
            one.show();
            two.show();
            three.show();
    
            ArrayList<Integer> redList = admin.send(20,3);
            one.receive(redList);
            two.receive(redList);
            three.receive(redList);
    
            admin.show();
            one.show();
            two.show();
            three.show();
        }
    }
    
    
  • 相关阅读:
    Java实现监控目录下文件变化
    Postgresql 修改用户密码
    Swing清空jtable中的数据
    delphi登录用友的信息
    用友U8的SQL SERVER 数据库结构说明表
    候老师的讲堂:视频录制、笔记软件、思维导图、画图等工具
    DELPHI 关于内存数据与 JSON
    Delphi国内优秀网站及开源项目
    SQL Server 阻止了对组件Ad Hoc Distributed Queries访问的方法
    SQL Server跨服务器查询
  • 原文地址:https://www.cnblogs.com/train99999/p/10884447.html
Copyright © 2020-2023  润新知