学习笔记03--Java基础

方法

  • Java方法是语句的集合,它们在一起执行一个功能
    • 方法是解决一类问题的步骤的有序集合
    • 方法包含于类或对象中
    • 方法在程序中被创建,在其他地方被引用
    • 方法命名首字母小写和驼峰命名法
  • 设计方法原则,保持方法的原子性,即一个方法只完成一个功能

方法定义

  • 定义一个方法,方法包含一个方法头和一个方法体
    • 修饰符:可选的,定义了方法的访问类型
    • 返回值类型:方法可能会产生返回值,也可能没有返回值,无返回值关键字为void
    • 方法名:是方法的实际名称
    • 参数类型:当调用方法时,传递值给参数,这个值被称为实参或变量。参数列表是指方法的参数类型、顺序和参数的个数。参数是可选的,也可以不含参数
      • 形式参数:在方法被调用时用于接收外界输入的数据
      • 实参:调用方法时实际传给方法的数据
    • 方法体:方法执行的具体语句

方法调用

  • 调用方法:对象名.方法名(实参列表)
  • 当方法返回一个值的时候,方法可以视作一个值,例如:
int larger = max(10,20);
  • 当方法返回值为void,方法调用是一条语句
System.out.println("Hello World!");

方法的重载

  • 重载就是在一个类中,有相同的函数名称,但形参不同的函数
  • 方法重载的规则:
    • 方法名称必须相同
    • 参数列表必须不同(个数不同、类型不同、参数排列顺序不同等)
    • 方法的返回值类型可以相同也可以不相同
    • 仅仅返回类型不同不足以成为方法的重载
  • 方法名称相同时,编译器会根据调用方法的参数个数,参数类型等逐个匹配,以选择对应的方法,如果匹配失败,则编译器报错

可变参数

  • JDK 1.5开始,Java支持传递同类型的可变参数给一个方法
  • 在方法声明中,在指定参数类型后加一个省略号(…)
  • 一个方法中只能指定一个可变参数,它必须是方法的最后一个参数。任何普通的参数必须在它之前声明
public static void printMax(double ... numbers){
    if(numbers.length == 0){                    //没有传入参数
        System.out.println("未检测到数字");
        return;
    }
    double result = numbers[0];
    for(int i = 1;i < numbers.length;i++){		//遍历找出最大值
        if(numbers[i] > result){
            result = numbers[i];
        }
    }
    System.out.println("最大值为:" + result);
}

递归

  • 递归就是方法自己调用自己
  • 递归可以利用简单的程序解决一些复杂问题。它通常把一个复杂问题层层转化为一个规模较小的问题来解决,大大减少了程序的代码量
  • 递归结构包括两个部分:
    • 递归头:什么时候不调用自身方法。如果没有头,会陷入死循环
    • 递归体:什么时候需要调用自身
public static int factorial(int n){			//利用递归实现阶乘
    if(n == 1){
        return 1;
    }else{
        return n * factorial(n-1);
    }
}

数组

  • 数组是相同类型数据的有序集合
  • 数组描述的是相同类型的若干个数据,按照一定的先后次序排列组合而成
  • 其中,每一个数据称作一个数组元素,每个数组元素可以通过一个下标来访问它们

声明数组

  • dataType[] arrayRefVar; //首选的方法
  • dataType arrayRefVar[]; //效果相同,但不是首选方法

创建数组

  • Java语言使用new操作符来创建数组,语法如下:

    dataType[] arrayRefVar = new dataType[arraySize];
    
  • 数组的元素是通过索引访问的,数组索引从0开始

  • 获取数组的长度:arrays.length

数组初始化

  • 静态初始化
int[] a = {1,2,3,4,5,6,7,8,9}
  • 动态初始化
int[] b = new int[10];
b[0] = 1;
  • 默认初始化,初始化默认值为0或null

数组的特点

  • 数组长度是确定的,数组一旦被创建,它的大小就是不可改变的

  • 数据元素必须是相同类型,不允许出现混合类型

  • 数组中的元素可以是任何数据类型,包括基本类型和引用类型

  • 数组变量属于引用类型,数组也可以看成是对象,数组中的每个元素相当于该对象的成员变量。数组对象本身是在堆中的

  • 下标的合法区间:[0,length - 1],如果越界就会报错:ArrayIndexOutOfBoundsException

  • 数组可以作为方法的入参和返回值

多维数组

  • 多维数组可以看成是数组的数组,比如二维数组就是一个特殊的一维数组,其每一个元素都是一个一维数组
int a[][] = new int[2][5];

arrays类

  • 数组的工具java.util.Arrays
  • 由于数组对象本身并没有什么方法可以供我们调用,但API中提供了一个工具类Arrays供我们使用,从而对数组进行一些基本的操作,可以查看JDK帮助文档
  • Arrays类中的方法都是static修饰的静态方法,在使用的时候可以直接使用类名进行调用,而不用使用对象来调用
  • 常用功能
    • 给数组赋值:通过fill方法
    • 给数组排序:通过sort方法(升序)
    • 比较元素:通过equals方法比较数组中元素值是否相等
    • 查找数组元素:通过binarySearch方法能对排序好的数组进行二分查找法操作

冒泡排序

  • 冒泡排序是八大排序中最出名的一种
  • 两层循环,外层冒泡轮数,里层依次比较
  • 时间复杂度为O(n2)
public static int[] sort(int[] array){
    int temp = 0;
    //外层循环,总共要进行多少轮比较
    for(int i = 0;i < array.length;i++){
        //内层循环,依次比较两个数,并将较小的数放在前面
        for(int j = array.length - 1;j > i;j--){
            if(array[j] < array[j - 1] ){       //交换二者的值
                temp = array[j - 1];
                array[j - 1] = array[j];
                array[j] = temp;
            }
        }
    }
    return array;
}

稀疏数组

  • 当一个数组中大部分元素为0,或者为同一值的数组时,可以使用稀疏数组来保存该数组
  • 稀疏数组的处理方式是:
    • 记录数组一共有几行几列,有多少个不同值
    • 把具有不同值的元素和行列及值记录在一个小规模的数组中,从而缩小程序的规模
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值