本文涉及Java知识点内部类和API
方法的形参是类名,其实需要的是该类的对象
实际传递的是该对象的地址值
方法的返回值是类名,其实返回的是该类的对象
实际传递的,也是该对象的地址值
示例
package com.classParams;
public class Cat {
public void eat() {
System.err.println("猫吃鱼");
}
}
package com.classParams;
public class CatOperator {
public void useCat(Cat c) {
c.eat();
}
public Cat getCat() {
Cat c = new Cat();
return c;
}
}
package com.classParams;
public class CatDemo {
public static void main(String[] args) {
// 创建操作类对象,并调用方法
CatOperator co = new CatOperator();
Cat c = new Cat();
co.useCat(c);
Cat c2 = co.getCat(); // new Cat()
c2.eat();
}
}
方法的形参是抽象类名,其实需要的是该抽象类的子类对象
方法的返回值是抽象类名,其实返回的是该抽象类的子类对象
示例
package com.abstractClassParams;
public abstract class Animal {
public abstract void eat();
}
package com.abstractClassParams;
public class Cat extends Animal {
@Override
public void eat() {
System.out.println("猫吃鱼");
}
}
package com.abstractClassParams;
public class AnimalOperator {
public void useAnimal(Animal a) {
a.eat();
}
public Ainmal getAnimal() {
Animal a = new Cat();
return a;
}
}
package com.abstractClassParams;
public class AnimalDemo {
public static void main(String[] args) {
// 创建操作类对象,并调用方法
AnimalOperator ao = new AnimalOperator();
Animal a = new Cat();
ao.useAnimal(a);
Animal a2 = ao.getAnimal();
a2.eat();
}
}
接口作为形参和返回值
方法的形参是接口名,其实需要的是该接口的实现类对象
方法的返回值是接口民该,其实需要的是该接口的实现类对象
示例
package com.InterfParams;
public interface jumping {
void jump();
}
package com.InterfParams;
public class Cat implements jumping {
@Override
public void jump() {
System.out.println("猫跳高");
}
}
package com.InterfParams;
public class JumpingOperator {
public void useJumpping(jumping j) {
j.jump();
}
public jumping getJumpping() {
jumping j = new Cat();
return j;
}
}
package com.InterfParams;
public class JumppingDemo {
public static void main(String[] args) {
// 创建操作类对象,并调用方法
JumpingOperator jo = new JumpingOperator();
jumping j = new Cat();
jo.useJumpping(j);
jumping j2 = jo.getJumpping();
j2.jump();
}
}
在一个类中定义一个类,举例:在一个类A的内部定义一个类B,类B就被称为内部类
格式&举例
/*
格式:
class 外部类名 {
修饰符 class 内部类名 {
}
}
*/
class outer {
public class Inner {
}
}
内部类的访问特点
示例
package com.InnerClass1;
/*
内部类访问特点
*/
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();
}
}
在类中方法,跟成员变量死一个位置
格式:外部类名.内部类名 对象名 = 外部类对象.内部类对象;
举例:Outer.Inner oi = new Outer().new
将一个类,设计为内部类的目的,大多数都是不想让外界去访问,所以内部类的定义应该私有化,
私有化之后,在提供一个可以让外界调用的方法,方法内部创建内部类对象并调用
示例
package com.InnerClass2;
public class Outer {
private int num = 10;
private class Inner {
private void show() {
System.out.println(num);
}
}
public void method() {
Inner i = new Inner();
i.show();
}
}
package com.InnerClass2;
public class InnerDemo {
public static void main(String[] args) {
// Outer.Inner oi = new Outer().new Inner();
// oi.show()
Outer o = new Outer();
o.method();
}
}
局部内部类是在方法中定义的类
局部内部类,外界是无法直接使用的,需要在方法内创建对象并使用
该类可以直接访问外部类的成员,也可以访问方法内的局部变量
示例
package com.IneerClass3;
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();
}
}
package com.IneerClass3;
public class OuterDemo {
public static void main(String[] args) {
Outer o = new Outer();
o.method();
}
}
存在一个类或者接口,这里的类可以是具体类以可以是抽象类
格式: new 类名() {重写方法} new 接口名() {重写方法}
举例:
new Inter() {
@override
public void method(){}
}
本质:是一个继承了该类或者实现了该接口的子类匿名对象
匿名内部类可以通过多态的形式感受
Inter i = new Inter() {
@override
public void method() {}
}
匿名内部类直接调用方法
package com.InnerClass4;
public class Test {
public static void main(String[] args) {
new Inter() {
@Override
public void method() {
System.out.println("我是匿名内部类");
}
}.method();
}
}
当发现某个方法需要,接口或者抽象类的子类对象,我么就可以传递一个匿名内部类过去,来简化传统的代码
示例
package com.InnerClass5;
public interface Jumpping {
void jump();
}
package com.InnerClass5;
public class Cat implements Jumpping {
@Override
public void jump() {
System.out.println("猫可以跳高了");
}
}
package com.InnerClass5;
public class Dog implements Jumpping{
@Override
public void jump() {
System.out.println("狗可以跳高了");
}
}
package com.InnerClass5;
public class JumppingOperator {
public void method(Jumpping j){
j.jump();
}
}
package com.InnerClass5;
public class JumppingDemo {
public static void main(String[] args) {
// 需求:创建接口操作类对象,调用method方法
JumppingOperator jo = new JumppingOperator();
Jumpping j = new Cat();
jo.method(j);
Jumpping j2 = new Dog();
jo.method(j2);
System.out.println("----------");
// 匿名内部类简化
jo.method(new Jumpping() {
@Override
public void jump() {
System.out.println("猫可以调高了");
}
});
// 匿名内部类简化
jo.method(new Jumpping() {
@Override
public void jump() {
System.out.println("狗可以跳高了");
}
});
}
}
Math包含执行基本数字运算的方法
Math类中无构造方法,但内部的方法都是静态的,可以通过类名.的方法调用
System类的常用方法
示例
package com.APITest;
/*
在控制台输出1-10000,计算这段代码执行了多少毫秒
*/
public class SystemDemo {
public static void main(String[] args) {
// 获取开始的时间节点
long start = System.currentTimeMillis();
for (int i = 0; i < 10001; i++) {
System.out.println(i);
}
// 获取代码运行结束后的时间节点
long end = System.currentTimeMillis();
System.out.println("共耗时:" + (end - start) + "毫秒");
}
}
Object是类层次结构的根,每个类都可以将Object作为超类,所有类都直接或者间接的继承自该类,
换句话说,该类所具备的方法,所有的类都会有一份
选中方法,按下Ctrl+B
Alt+String选择toString
在类的空白区域,右键->Generate->选择toString
以良好的格式,更方便的展示对象中的属性值
示例
package com.toStringTest;
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 +
'}';
}
}
package com.toStringTest;
public class StudentDemo {
public static void main(String[] args) {
Student s1 = new Student("Alice", 13);
System.out.println(s1);
System.out.println(s1.toString());
}
}
用于对象之间的比较,返回true或者false的结果 举例: s1.equals(s2); s1和s2是两个对象
不希望对比对象的地址值,想要结合对象属性进行比较的时候
alt+insert选择equals() and hashCode(), IntelliJ Default,一路next,finish即可
在类的空白区域,右键-> Generate->选择equals() and hashCode(),后面的同上
示例
package com.ObjectTest;
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 == null || getClass() != o.getClass()) return false;
Student student = (Student) o;
if (age != student.age) return false;
return name != null ? name.equals(student.name) : student.name == null;
}
}
package com.ObjectTest;
public class ObjectDemo {
public static void main(String[] args) {
Student s1 = new Student("Alice", 22);
Student s2 = new Student("Alice", 22);
System.out.println(s1.equals(s2));
}
}
冒泡排序概述
package com;
/*
冒泡排序
*/
public class BubboSort {
public static void main(String[] args) {
// 定义一个数组
int[] arr = {23, 68, 90, 47, 12};
System.out.println("排序前:" + arrayToString(arr));
// 这里减1, 是控制每轮比较的次数
for (int x = 0; x < arr.length - 1; x++) {
// 减去每轮的次数
for (int i = 0; i < arr.length - 1 - x; i++) {
if (arr[i] > arr[i + 1]) {
int tmp = arr[i];
arr[i] = arr[i + 1];
arr[i + 1] = tmp;
}
}
}
System.out.println("排序后:" + 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("]");
String s = sb.toString();
return s;
}
}
工具类设计思想