小李的40天java历程——Day03

前言

  • 程序=算法+数据结构;
    • 算法:怎么找书,找书的过程(顺序,分支,循环,折半…)
    • 数据结构:怎么存书,把书按类别分。(顺序,链式…)

1. 数组

  • 1.1 数组是什么:
    • 存放相同数据类型的引用(数组是一个引用类型),且数组长度是固定的,一旦声明长度就不能发生改变。
  • 1.2 数组的定义:
    • int[] arr = new int[num];
    • byte short char int long 默认值为0 float double 默认值为0.0 boolean默认值为false——>(变量使用前不是必须声明并初始化的么?这个为啥有默认值呢?那么前面的为啥没有默认值)
  • 1.3 数组的初始化:
    • 1> int[] arr = new int[num];
    • 2> int[] arr = {1,1,2};
    • 3> int[] arr = new arr[]{1,2,3}
    • 三种之间的比较:1,3都能先声明,在赋值。只有2,只能在声明的同事初始化。
  • 1.4 数组的访问:
    • 查询长度:通过数组名.length(arr.length)访问。
    • 查询数组中的元素:通过索引(下标)来访问。
      • 数组的下标从0开始–>arr.length-1结束(同random一样,【】中的数字和math.random()后乘的数字都是个数(长度))
      • 数组下标越界是编译错误。
  • 1.5 数组的遍历(用for循环——>正序倒序)
  • 1.6 数组的复制
    • 两种方法:
    • 方法1:system.arrcopy(a1(原数组),1(复制起始位置),a2(复制到数组),2(复制的位置),3(复制多少个元素))————>灵活高效,可以从任意位置复制
    • 方法2:int[] arr1(目标数组的长度) = Arrays.copyOf(a(原数组),4(目标数组的长度))————>只能从开头复制。但是常用于数组的扩容:
      • 扩容:int[] a = Arrays.copyOf(a,a.length+1)————>此时的a数组为新开辟的数组 不是原数组加了一格子来存放新的元素。
  • 1.7 数组的排序
    • 排序:(选择排序,插入排序,冒泡排序,快速排序等等)——>数组元素交换的次数来决定排序的好坏,所以经过测试数组的排序用Arrays.sort(arr);最佳。
      • 如何测试最佳的排序算法呢?——>用system.currentTimeMillis();来计算 (存放某一算法与两个currentTimeMillis之间,相减得出算法执行时间)
    • 寻早最大值算法:
      • 1)总是设置第一个值为最大值
      • 2)遇到比他大的就交换
    • 冒泡排序的工作原理( 第一层控制轮数二层控制每轮的次数) 与数组中的下标数据无关)
      • 1)arr.length-1次比较
      • 2)每次比较都是从第一位开始与下一位相比较
      • 3)比较过的就不比较了(冒出来的数字就不比较了)
  • 1.8总结:
    • 1)这种多次结果实现一次正误得用开关(false/true)来解决
    • 2)常用计数器来解决问题
    • 3)写代码要从已知到未知(多次的先从一次下手,先写框架在刨析内容)

2 方法

  • 2.1 方法是什么:
    • 用于封装一段独立逻辑功能(保持独立性,一个方法尽量干一件事)
    • 可以多次被调用,避免了代码得重复性。
  • 2.2 方法的定义(5大部分)
    • 修饰词(public static)返回类型(int)方法名(main)(参数列表(int a)){ 方法体 }
    • 方法可以有参数也可以无参数(有参数更加灵活)
    • 方法可以有返回值也可以无返回值
      • 无返回值————>返回值类型为void
      • 有返回值————>返回值类型为特定的数据类型
  • 2.3 方法的调用
    • 调用无参:直接调用
    • 调用有参:必须传值
    • 调用无返回值:方法名(有参传参)
    • 调用有返回值:数据类型 变量 = 方法名(有参传参);
  • 2.4 return
    • return 值;(返回的是相应返回值类型的值,而不是名称所以无所谓返回值和变量名字是否相同)————> 1)结束方法 2)返回一个值调用该方法的变量
    • return;(适用于无返回值类型)————>结束方法。
  • 2.5 调用方法是的内存情况在这里插入图片描述
  • 2.6 与主方法并列的方法要用Static修饰
    • 在java中static修饰的会在代码运行是首先进行初始化,在主方法运行的时候就需要调用到同一个类中的其他方法,如果不是静态方法也就是还没加载,就会找不到其方法而导致编译出错。(静态方法只能调用静态方法,普通方法可以调用静态方法)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值