1、参数传递

1.1 类名作为形参和返回值

  • 类名——方法形参

    方法的形参是类名,需要的是该类的对象;实际传递的是该对象的地址值

  • 类名——返回值

    方法的返回值是类名,返回的是该类的对象;实际传递的是该对象的地址值

  • 示例代码
public class Cat {
public void eat(){
System.out.println("猫吃鱼");
}
} public class CatOperator {
//类名作为方法的形参
public void useCat(Cat c){ //Cat c = new Cat();
c.eat();
} //类名作为方法的返回值
public Cat getCat(){
Cat c = new Cat();
return c;
}
} public class CatDemo {
public static void main(String[] args) {
//创建操作类对象,并调用方法
CatOperator co = new CatOperator();
Cat c = new Cat();
co.useCat(c); Cat c2 = co.getCat();
c2.eat();
}
}

1.2 抽象类作为形参和返回值(理解)

  • 抽象类作为形参和返回值

    • 方法的形参是抽象类,其实需要的是该抽象类的子类对象
    • 方法的返回值是抽象类,其实返回的是该抽象类的子类对象
  • 示例代码
public class Cat extends Animal {
@Override
public void eat() {
System.out.println("猫吃鱼");
}
} public abstract class Animal {
public abstract void eat();
} public class AnimalOperator {
public void userAnimal(Animal a){
a.eat();
} public Animal getAnimal(){
Animal a = new Cat();
return a;
}
} public class AnimalDemo {
public static void main(String[] args) {
AnimalOperator ao = new AnimalOperator();
Animal a = new Cat();
ao.userAnimal(a); Animal ao2 = ao.getAnimal();
ao2.eat();
}
}

1.3 接口作为形参和返回值(理解)

  • 接口作为形参和返回值

    • 方法的形参是接口,其实需要的是该接口的实现类对象
    • 方法的返回值是形参,其实返回的是该接口的实现类对象
  • 示例代码
public interface Jumpping {
void jump();
} public class Cat implements Jumpping{
@Override
public void jump() {
System.out.println("猫可以跳高");
}
} public class JumppingOperator {
public void useJumpping(Jumpping j){//Jumpping j = new Cat();
j.jump();
} public Jumpping getJumpping(){
Jumpping j = new Cat();
return j;
}
} public class JumppingDemo {
public static void main(String[] args) {
JumppingOperator jo = new JumppingOperator();
Jumpping j = new Cat();
jo.useJumpping(j); Jumpping j2 = jo.getJumpping();
j2.jump();
}
}

2、内部类

2.1 内部类的基本使用(理解)

  • 内部类概念

    • 在一个类中定义一个类。举例:在一个类A的内部定义一个类B,类B就被成为内部类
    • 内部类定义格式
      • 格式:
class 外部类名{
修饰符 class 内部类名{ }
}
      • 举例
public class Outer {
public class Inner{ }
}
  • 内部类的访问特点

    • 内部类可以直接访问外部类的成员,包括私有
    • 外部类要访问内部类的成员,必须创建对象
  • 示例代码
public class Outer {
private int num = 10;
public class Inner{
public void show(){
System.out.println(num);
}
} public void method(){
Inner i = new Inner();
i.show();
}
}

2.2 成员内部类(理解)

  • 成员内部类的定义位置

    • 在类中方法外,跟成员变量是一个位置
  • 外界拆功能键成员内部类格式
    • 格式:外部类名.内部类名 对象名 = 外部类对象.内部类对象;
    • 举例:Outer.Inner oi = new Outer().new Inner();
  • 示例代码
public class Outer {
private int num =10;
private class Inner {
public void show(){
System.out.println(num);
}
} public void method(){
Inner i = new Inner();
i.show();
}
} public class OuterDemo {
public static void main(String[] args) {
Outer o = new Outer();
o.method();
}
}

2.3 局部内部类(理解)

  • 定义位置

    • 定义在方法中
  • 使用方式
    • 局部内部类,外界是无法直接使用,需要在方法内部创建对象并使用
    • 该类可以直接访问外部类的成员,也可以访问方法内的局部变量
public class Outer {
private int num = 10;
public void method(){
int num2 = 20;
class Inner{
public void show(){
System.out.println(num);
System.out.println(num2);
}
} Inner i = new Inner();
i.show();
}
} public class OuterDemo {
public static void main(String[] args) {
Outer o = new Outer();
o.method();
}
}

2.4 匿名内部类(应用)

  • 匿名内部类的前提

    • 存在一个类或接口,这里的类可以是具体类也可以是抽象类
  • 匿名内部类的格式
    • 格式:new 类名(){重写方式}  /new 接口名 () {重写方法}
    • 举例
new Inter(){
@Override
public void method(){}
}
  • 匿名内部类的本质

    • 本质:是一个继承了该类或者实现类该接口的子类匿名对象
  • 匿名内部类的细节
    • 匿名内部类可以通过多态的形式接受
Inter i = new Inter(){
@Override
public void method(){ }
}
  • 匿名内部类直接调用方法
public interface Inner {
public void method();
} public class InnerDemo {
public static void main(String[] args) {
new Inner(){
@Override
public void method(){
System.out.println("我是匿名内部类");
}
}.method();
}
}

2.4 匿名内部类在开发中的使用(应用)

  • 使用

    • 当发现某个方法需要,接口或抽象类的子类对象,我们就可以传递一个匿名内部类过去,来简化传统代码
  • 示例代码
public interface Jumpping {
void jump();
} public class Cat implements Jumpping{
@Override
public void jump() {
System.out.println("猫可以跳高了");
}
} public class Dog implements Jumpping{
@Override
public void jump() {
System.out.println("狗可以跳高了");
}
} public class JumppingOperator {
public void method(Jumpping j){
j.jump();
}
} public class JumppingDemo {
public static void main(String[] args) {
//创建接口操作类对象调用method方法
JumppingOperator jo = new JumppingOperator(); //方式一:传统方式
//操作猫的行为
Jumpping j1 = new Cat();
jo.method(j1);
//操作狗的行为
Jumpping j2= new Dog();
jo.method(j2); //方式二:匿名内部类的方式
//操作猫的行为
jo.method(new Jumpping() {
@Override
public void jump() {
System.out.println("猫可以跳高了");
}
});
//操作狗的行为
jo.method(new Jumpping() {
@Override
public void jump() {
System.out.println("狗可以跳高了");
}
});
}
}

3、常用API

3.1 Math(应用)

  • 概述:Math包含执行基本数字的方法
  • 方法的调用方式:Math类中无构造方法,但内部的方法都静态的,则可以通过 类名进行调用
  • 常用方法:

3.2 System(应用)

  • 常用方法

  • 示例代码

    • 需求:在看控制台输出1-10000,计算这段代码执行了多少毫秒
public class SystemDemo {
public static void main(String[] args) {
//需求:在控制台输出1-10000,计算这段代码执行了多少毫秒
//获取开始的时间节点
long start = System.currentTimeMillis();
for (int i = 1; i <= 10000; i++) {
System.out.println(i);
}
long end = System.currentTimeMillis();
System.out.println("这段代码执行耗时:"+(end-start)+"ms");
}
}

3.3 Object类的toString方法(应用)

  • 概述:

    • Object是类层次结构的跟,所有类都直接或间接的继承自Object类。
  • 重写toString()
    • Alt+Insert选择toString()
  • toString()的作用
    • 以良好的格式,更方便的展示对象中的属性值
  • 示例代码:
public class Student extends Object{
private String name;
private int age; 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;
} @Override
public String toString() {
return "Student{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
} public class ObjectDemo {
public static void main(String[] args) {
Student s = new Student();
s.setName("林青霞");
s.setAge(30);
System.out.println(s);
System.out.println(s.toString());
}
}
  • 运行结果:
Student{name='林青霞', age=30}
Student{name='林青霞', age=30}

3.4 Object类的equals方法(应用)

  • equals方法的作用

    • 用于对象之间的比较,返回true和false的结果
    • 举例:s1.equals(s2); s1和s2是两个对象
  • 重写equals方法的场景
    • 不希望比较对象的地址值,想要结合对象属性进行比较的时候。
  • 重写equals方法的方式
    • 1.alt + insert选择equals()and hashCode(), InteliJ Default
  • 示例代码
public class Student {
private String name;
private int age; 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;
} @Override
public boolean equals(Object o) {
if (this == o) return true;
if (!(o instanceof Student)) return false; Student student = (Student) o; if (getAge() != student.getAge()) return false;
return getName() != null ? getName().equals(student.getName()) : student.getName() == null;
} @Override
public int hashCode() {
int result = getName() != null ? getName().hashCode() : 0;
result = 31 * result + getAge();
return result;
}
} public class ObjectDemo {
public static void main(String[] args) {
Student s1 = new Student();
s1.setName("林青霞");
s1.setAge(30); Student s2 = new Student();
s2.setName("林青霞");
s2.setAge(30); //需求:比较两个对象的内容是否相同
System.out.println(s1.equals(s2));
}
}

3.5 冒泡排序原理(理解)

  • 概述: 一种排序的方式,对要进行排序的数据中相邻的数据进行两两比较,将较大的数据放在后面,依次对所
    有的数据进行操作,直至所有数据按要求完成排序
  • 如果有n个数据进行排序,总共需要n-1轮排序
  • 每一次比较完毕,下一次的比较就会少一个数据参与

3.6 冒泡排序的实现(理解)

  • 代码实现
public class ArrayDemo {
public static void main(String[] args) {
//定义一个数组
int[] arr = {24, 69, 80, 57, 13};
System.out.println("排序前:"+ArrayDemo.arrayToString(arr));
//排序的轮数
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]){
int temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
System.out.println("排序后:"+ArrayDemo.arrayToString(arr));
} public static String arrayToString(int[] arr){
StringBuilder sb = new StringBuilder();
sb.append("[");
for (int i = 0; i < arr.length; i++) {
if (i == arr.length-1){
sb.append(arr[i]);
}else {
sb.append(arr[i]).append(",");
}
}
sb.append("]");
return sb.toString();
}
}

3.7 Array(应用)

  • Arrays的常用方法

  • 工具类设计思想

    1、构造方法用private修饰

    2、成员用public static修饰

public class ArrayDemo {
public static void main(String[] args) {
//定义一个数组
int[] arr = {26,69,80,57,13};
System.out.println("排序前:"+ Arrays.toString(arr));
//使用sort方法进行排序
Arrays.sort(arr);
System.out.println("排序后:"+ Arrays.toString(arr));
}
}

day12_内部类&API的更多相关文章

  1. spark之JDBC开发(实战)

    一.概述 Spark Core.Spark-SQL与Spark-Streaming都是相同的,编写好之后打成jar包使用spark-submit命令提交到集群运行应用$SPARK_HOME/bin#. ...

  2. Java基础第三天--内部类、常用API

    形参和返回值 抽象类名作为形参和返回值 方法的形参是抽象类名,其实需要的是该抽象类的子类对象 方法的返回值是抽象类名,其实返回的是该抽象类的子类对象 接口名作为形参和返回值 方法的形象是接口名,其实需 ...

  3. PHP反射API

    近期忙着写项目,没有学习什么特别新的东西,所以好长时间没有更新博客.我们的项目用的是lumen,是基于laravel的一个轻量级框架,我看到里面用到了一些反射API机制来帮助动态加载需要的类.判断方法 ...

  4. Android多媒体--MediaCodec 中文API文档

    *由于工作需要,需要利用MediaCodec实现Playback及Transcode等功能,故在学习过程中翻译了Google官方的MediaCodec API文档,由于作者水平限制,文中难免有错误和不 ...

  5. Java中的内部类(回调)

    一.内部类的主要作用如下: 1. 内部类提供了更好的封装,可以把内部类隐藏在外部类之内,不允许同一个包中的其他类访问该类 2. 内部类的方法可以直接访问外部类的所有数据,包括私有的数据 3. 内部类所 ...

  6. Unit05 - 抽象类、接口和内部类(上)

    Unit05 - 抽象类.接口和内部类(上) 1.static final常量:  1)必须声明同时初始化  2)通过类名来访问,不能被改变  3)建议:常量名所有字母都大写(多个单词间用_)  4) ...

  7. PHP : Reflection API

    PHP Reflection API是PHP5才有的新功能,它是用来导出或提取出关于类.方法.属性.参数等的详细信息,包括注释. PHP Reflection API有: class Reflecti ...

  8. [转载] 3. JebAPI 之 jeb.api.ast

    本文转载自: https://www.zybuluo.com/oro-oro/note/143651 0. 序 Jeb 本身是支持变量重命名的,所以,混淆了的变量名.类名可以修改. 实际上,它还可以做 ...

  9. 黑马程序员——【Java基础】——面向对象(一)概述、类与对象、继承、抽象类、接口、多态、内部类

    ---------- android培训.java培训.期待与您交流! ---------- 一.面向对象概述 1.面向对象:是一个很抽象的概念,它相对面向过程而言,是一种程序设计的思想. 2.面向对 ...

  10. Android开发-API指南-创建 Content Provider

    Creating a Content Provider 英文原文:http://developer.android.com/guide/topics/providers/content-provide ...

随机推荐

  1. MySQL单表查询(分组-筛选-过滤-去重-排序-分页-判断-正则)

    目录 一:单表查询 1.单表查询(前期准备) 2.插入记录(写入数据) 3.查询关键字 二:查询关键字之where 1.查询id大于等于3小于等于6的数据 2.查询薪资是20000或者18000或者1 ...

  2. vue实现移动端左右菜单双向联动效果

    话不多说,上demo <template> <div id="app"> <header>左右列表双向联动</header> < ...

  3. STL list容器API

    list容器:链表容器,不支持随机遍历.不能用通用的sort算法(要有随机访问迭代器),容器自己有排序算法 #define _CRT_SECURE_NO_WARNINGS #include<io ...

  4. ARL灯塔系统搭建

    前言 ARL(Asset Reconnaissance Lighthouse)资产侦查灯塔,是一个良好的资产收集系统,旨在为渗透测试人员以及安全团队基于企业的网络安全能快速查找到指定企业资产中的脆弱点 ...

  5. flutter系列之:flutter中listview的高级用法

    目录 简介 ListView的常规用法 创建不同类型的items 总结 简介 一般情况下,我们使用Listview的方式是构建要展示的item,然后将这些item传入ListView的构造函数即可,通 ...

  6. 在 C# 9 中使用 foreach 扩展

    在 C# 9 中,foreach 循环可以使用扩展方法.在本文中,我们将通过例子回顾 C# 9 中如何扩展 foreach 循环. 代码演示 下面是一个对树形结构进行深度优先遍历的示例代码: usin ...

  7. [C++]我的理解之内存对齐

    问题1:为什么要内存对齐? 平台原因:不是所有的平台都能访问到任意地址上的任何数据,如果在特定的地址上找不到数据的话就会抛出硬件异常. 性能问题:简单的来说如果没有使用内存对齐的话,相对于内存对齐,C ...

  8. P5687 [CSP-S2019 江西] 网格图

    题面 给定一个 \(n\times m\) 的网格图,行从 \(1\sim n\) 编号,列从 \(1\sim m\) 编号,每个点可用它所在的行编号 \(r\) 与所在的列编号 \(c\) 表示为 ...

  9. Scrapy爬虫框架快速入门

    安装scrapy pip install scrapy -i https://pypi.douban.com/simple/ 安装过程可能遇到的问题 版本问题导致一些辅助库没有安装好,需要手动下载并安 ...

  10. python实战-基于正交实验(工具:allpairs)自动生成接口异常测试用例

    实现思路 1.抓取api信息(目前公司用的swagger),uri.method.params.response,解析完成后写入excle 2.读取抓取完毕的api信息,处理为allpairs所需要的 ...