面向对象1

2020-04-08  本文已影响0人  vv_64ce

java面向对象的3条主线

1.java类及类的成员、属性、方法、构造器、代码块、内部类
2.面向对象三大特征:封装性、继承性、多态性
3.其他关键字:this、super、static、final、abstract、interface、package、import等

面向对象(OOP)和面向过程(POP)

OOP:强调具备功能的对象,以类/对象为最小单位,考虑谁做
POP:强调功能行为,以函数为最小单位,考虑怎么做
eg:人把大象塞入冰箱

面向对象2要素:

类:对一类事物的描述,是抽象的、概念上的定义
对象:实际存在的该类事物的每个个体,也称为实例
创建类的对象=类的实例化=实例化类

对象的内存解析

堆(heap):唯一目的存放对象实例;对象的非static属性也存放在堆中
栈(stack):通常所说的是虚拟机栈,用于存放局部变量等。8种基本数据类,对象引用(reference类型,不等同于对象本身,是对象在堆内存的首地址)。方法执行完后,自动释放
方法区(Method Area):存储类的加载信息、常量池、静态变量、即时编译器编译后的代码等

内存解析说明:引用类型的变量,只能存储两类值:null或地址值(含变量的类型)
匿名对象:只能使用一次
new Phone().sendMessage();//方式一
PhoneMail mail= new PhoneMail();
mail.show(new Phone());//方式二:开发中常用

变量

实例(无static)变量:有默认初始化值
局部变量:没有默认初始化值,即局部变量必须赋值;特别的,形参在调用时,才去赋值
内存中的位置:实例变量加载到堆内存中;局部变量加载到栈空间

return

1.作用范围:使用在方法中
2.作用:(1)void返回时结束方法,使用“return ;”(2)针对有返回值类型的方法,使用“return 数据”方法返回需要的数据
3.注意:return关键字后不能声明执行语句

方法

1.重载

方法同名,参数个数或类型或顺序不同即可(两同一不同:同一个类、相同方法名;参数列表不同(类型或个数或顺序))

2.可变形参的方法(String... str) (jdk5.0新特性)

形参不同的方法之间也构成重载(String str和String... str);必须声明在末尾(int a,String... str);最多只能声明一个可变形参

    void find(String str){
        
    }
    void find(String... str){
        
    }
//String... str和String[] str作用等同,只能存在一个
    void find(String[] str){
        
    }
//String... str和int a,String... str同时存在时,在int a,String... str中,顺序不能颠倒
    void find(int a,String... str){
        
    }
3.方法参数的值传递机制

变量的赋值:变量是基本数据类型,保存的是数据值;变量是引用数据类型,保存的是数据地址值
形参的传递机制:值传递
(1)形参:方法定义时,声明的小括号内的参数
实参:方法调用时,实际传递给形参的数据
(2)值传递机制
若参数是基本数据类型,此时实参付给形参的是真是存储的数据值;
若参数是引用数据类型,此时实参付给形参的是变量所保存的数据地制值

//基本数据类型;传递存储的数据值
    static void swap(int i,int j){
        int temp = i;
        j = temp;
        temp = j;
    }
    //引用数据类型,此时arr代表数组对象引用地址值,i,j表示引用的位置;传递地址值
    static void swap(int[] arr,int i,int j){
        int temp = arr[i];
        arr[i] = arr[j];
        arr[j] = temp ;
    }
    public static void main(String[] args) {        
        int[] arr = new int[]{23,-5,26,-59,-42,5,86,99};
        for (int i = 0; i < arr.length - 1; i++) {
            for (int j = 0; j < arr.length - 1- i; j++) {
                if(arr[j] > arr[j + 1]){
//                   swap(arr,j,j+1);//冒泡结果正确
                    swap(j,j+1);//只是在方法内部冒泡,执行完方法后释放,仍然是原数组顺序
                }
            }
        }
        for (int i = 0; i < arr.length - 1; i++) {
            System.out.print(arr[i]+"\t");
        }   

举例:

    static class Value{
        int i = 15;
    }
    static void first(){
        int i = 5;
        Value v = new Value();
        v.i = 25;
        second(v,i);
        System.out.println(v.i);
    }
    static void second(Value v,int i ){
        i = 0;
        v.i = 20;
        Value val = new Value();
        v = val;
        System.out.println(v.i+"...."+i);
    }
    public static void main(String[] args) {    
        Array01 arr = new Array01();
        arr.first();
//结果 15....0   20
运行图.png

例题1:(*****考察重写,并不是参数传递)

    public static void main(String[] args) {    
        int a = 10;
        int b = 20;
        method(a,b);//需要在method方法调用之后,仅打印出a=100,b=200,写出method的代码
        System.out.println("a="+a);
        System.out.println("b="+b);

方法一:System.exit(0);表示终止当前jvm的执行

private static void method(int a, int b) {
        a  = a* 10;
        b = b* 10;
        System.out.println("a="+a);
        System.out.println("b="+b);
        System.exit(0);//直接在该方法执行完后退出
    }

方法二:重写println方法

private static void method(int a, int b) {
        PrintStream ps = new PrintStream(System.out){
        @Override
        public void println(String str){
            if("a=10".equals(str)){
                str = "a= 100";             
            }else if("b=20".equals(str)){
                str = "b= 200";             
            }
            super.println(str);
        }
        };
        System.setOut(ps);

    }

例题2:定义一个int型数组:int[] arr = new int[]{12,3,3,34,56,77,432};让数组的每个位置上的值去除以首位置的元素,得到的结果作为该位置上的新值。遍历新的数组。

int[] arr = new int[]{12,3,3,34,56,77,432};
        int temp = arr[0];
//错误写法,arr[0]在第一次运算后,值已经改变
        for (int i = 0; i < arr.length; i++) {
            arr[i] = arr[i] / arr[0];
        }
        //方法一:倒序相除,原因是arr[0]值到最后一次值才会改变
        for (int i = arr.length - 1; i >= 0;i--) {
            arr[i] = arr[i] / arr[0];
        }
//方法二:定义一个arr[0]空间,确保其值不变
//      for (int i = 0; i < arr.length; i++) {          
//              arr[i] = arr[i] / temp;     
//      }

        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i]+"\t");
        }

例题3:

        int[] arr1 = new int[3];
        System.out.println(arr1);//[I@15db9742
        char[] arr2 = new char[3];
        System.out.println(arr2);//口口口
        String[] arr3 = new String[3];
        System.out.println(arr3);//[Ljava.lang.String;@6d06d69c
        
        int[] arr4 = new int[]{1,2};
        System.out.println(arr4);//[I@7852e922
        char[] arr5 = new char[]{'d'};
        System.out.println(arr5);//d
        String[] arr6 = new String[]{"a"};
        System.out.println(arr6);//[Ljava.lang.String;@4e25154f
4.递归recurison:一个方法体内调用自身
static int getSum(int n){
        if(n == 1){
            return 1;
        }else{
            return n + getSum(n-1);
        }
    }
    public static void main(String[] args) {
        Array01 test = new Array01();
        System.out.println(test.getSum(100));//5050
上一篇 下一篇

猜你喜欢

热点阅读