JavaSE之类和对象的总结

目录

一、初步认识类和对象

 二、类的成员

 1.字段

2.方法

3.static 关键字

三、封装

1.什么是封装

2.private实现封装

3.getter和setter方法

四、构造方法

五、代码块

六、内部类

1.内部类的概念和分类:

2.本地内部类

3.实例内部类

4.静态内部类 

5.匿名内部类

七、补充

1.toString方法:

 2.匿名对象


一、初步认识类和对象

1.C语言是面向过程的,关注的是过程,分析出求解问题的步骤,通过函数调用逐步解决问题

JAVA 基于面向对象 的, 关注 的是 对象,将一件事情拆分成不同的对象,靠对象之间的交互完成。面向过程注重的是过程,在整个过程中所涉及的行为,就是功能。面向对象 注重的是对象,也就是参与过程所涉及到的主体。是通过逻辑将一个个功能实现连接起来
打个比方:以洗衣服为例
面向过程:人将衣服放进洗衣机,倒入洗衣粉,启动洗衣机,洗衣机就会完成洗衣过程并且甩干
面向对象:人、衣服、洗衣粉、洗衣机四个对象之间交互完成,人不需要关注洗衣机具体是如何洗衣服的,如何甩干的

 面向对象是思考问题的一种思考方式,是一种思想。比如:概念与实例。理论与实践。名和实等等。它的好处是将复杂的事情变简单了,只要面对一个对象就行。面向对象设计把握一个重要的经验:谁拥有数据,谁对外提供操作这些数据(私有)的方法(被动的一方是数据的拥有者,主动的一方是执行者)。开发时:找对象,建对象,用对象,并维护对象之间的关系

2. 类就是一类对象的统称。对象就是这一类具体化的一个实例。类相当于一个模板,对象是由模板产生的样本。一个类,可以产生无数的对象。声明一个类就是创建一个新的数据类型,而类在 Java 中属于 引用类型 Java 使用关键字 class 来声明类。
声明一个类的基本语法:
// 创建类
class <class_name>{  
    field;//成员属性
    method;//成员方法
}
// 实例化对象
<class_name> <对象名> = new <class_name>();
class 定义类的关键字, ClassName 为类的名字, {} 中为类的主体。类中的元素称为:成员属性。类中的函数称为:成员方法
3.类的实例化
用类类型创建对象的过程,称为类的实例化
(1) 类只是 一个 模型 一样的东西,限定了类有哪些成员
(2)一个类可以实例化出多个对象, 实例化出的对象 占用实际的物理空间,存储类成员变量。打 个比方。 类实例化出对象就像现实中使用建筑设计图建造出房子,类就像是设计图 ,只设计出需要什么东 西,但是并没有实体的建筑存在,同样类也只是一个设计,实例化出的对象才能实际存储数据,占用物理空间
(3) 创建一个对象需要3步:
  • 声明:声明一个对象,包括对象名称和对象类型。
  • 实例化:使用关键字 new 来创建一个对象。
  • 初始化:使用 new 创建对象时,会调用构造方法初始化对象(稍后会说)

(4)同一个类可以创建多个实例

如下代码:
class Person {
    public int age;//成员属性 实例变量
    public String name;
    public String sex;
    public void eat() {//成员方法
       System.out.println("吃饭!");  
    }
    public void sleep() {
       System.out.println("睡觉!");  
    }
}
public class Main{
    public static void main(String[] args) {
        Person person = new Person();//通过new实例化对象
        Person person2 = new Person();
      //如果改为Person person2 = person;那么它的意思是person2这个引用指向person这个引用所指向的对象,并不是“引用指向引用”
        person.eat();//成员方法调用需要通过对象的引用调用
        person.sleep();
    }
}

编译并运行该代码,输出如下:

吃饭!

睡觉!

内存布局如图所示: 

  

看这张图,我们感觉好像引用都在栈上,其实引用不一定在栈上,如:

class Person {
    public int age;
    public String name;
    public String sex;
}
public class Test{
    Person person = new Person();

    public static void main(String[] args) {
        Test test = new Test();
    }
}

 其内存布局是这样的:

 二、类的成员

类的成员可以包含以下:字段、方法、代码块、内部类和接口等。但是本笔记重点总结前3种

 1.字段

  • 定义在类中, 但是方法外部定义的变量. 这样的变量我们称为 "字段" "属性" "成员变量"(三种称呼都可以, 一般不会严格区分),成员变量又分为普通成员变量(普通成员变量都属于对象)和静态成员变量类变量),以下类中的是普通成员,笔记的后面会遇到静态成员变量。
  • 局部变量:在方法、构造方法或者语句块中定义的变量被称为局部变量。变量声明和初始化都是在方法中,方法结束后,变量就会自动销毁。
class Person {
    public String name;   // 字段/属性/成员变量
    public int age; 
}
class Test {
    public static void main(String[] args) {
        Person person = new Person();
        System.out.println(person.name);
        System.out.println(person.age);
   }
}

编译并运行该代码,输出如下:

null

0

 (1)使用 . 访问对象的字段,"访问" 既包含读, 也包含写

(2)对于一个对象的字段如果没有显式设置初始值 , 那么会被设置一个默认的初值。
默认规则:
对于各种数字类型, 默认值为 0
②对于 boolean 类型, 默认值为 false
对于引用类型(String, Array, 以及自定制类), 默认值为 null
很多时候我们不希望字段使用默认值 , 而是需要我们显式设定初值:(字段就地初始化)
class Person {
    public String name = "张三";  
    public int age = 18; 
}
class Test {
    public static void main(String[] args) {
        Person person = new Person();
        System.out.println(person.name);
        System.out.println(person.age);
   }
}

我们并不建议这么初始化,因为当我们new多个对象时,不见得每个对象都叫张三,都是18岁。我们可以这样初始化:

class Person {
    public String name;  
    public int age; 
}
class Test {
    public static void main(String[] args) {
        Person person = new Person();
        person.name = "张三";
        person.age = 18;
        System.out.println(person.name);
        System.out.println(person.age);
   }
}

编译并运行该代码,输出如下:

张三

18

2.方法

 用于描述一个对象的行为

方法又分为普通方法和静态方法,以下类中的是普通方法,笔记的后面会遇到静态方法

使用 . 访问对象的方法

class Person {
    public int age;
    public String name;
    public void show() {
   System.out.println("我叫" + name + ", 今年" + age + "岁");
   }
}
class Test {
    public static void main(String[] args) {
        Person person1 = new Person();
        Person person2 = new Person();
        person1.age = 18;
        person1.name = "张三";
        person2.age = 19;
        person2.name = "李四";
        person1.show();
        person2.show();
   }
}

编译运行该代码,输出如下:

我叫张三,今年18岁

我叫李四,今年19岁

此处的 show 方法 , 表示 Person 这个对象具有一个 " 展示自我 " 的行为 . 这样的 show 方法是和 person 实例相关联的 . 如果创建了其他实例 , 那么 show 的行为就会发生变化
方法中还有一种特殊的方法称为 构造方法,这个在笔记的后面再总结。

3.static 关键字

 它可以修饰属性,修饰方法,修饰代码块,修饰类

(1)修饰属性(Java静态属性和类相关, 和具体的实例无关. 换句话说, 同一个类的不同实例共用同一个静态属性

class Test{
    public int a;//普通成员变量  实例变量  存放在对象中
    public static int count;//类变量也叫静态成员变量 
    public final SIZE;//被final修饰的叫常量,也属于对象。 被final修饰,后续不可更改
    public static final int  COUNT = 99;//静态的常量,属于类本身,只有一份 被final修饰,后续不可更改
}
public class Main{
    public static void main(String[] args) {
        Test t1 = new Test();
        t1.a++;
        Test.count++;
        System.out.println(t1.a);
        System.out.println(Test.count);
        System.out.println("---------------");
        Test t2 = new Test();
        t2.a++;
        Test.count++;
        System.out.println(t2.a);
        System.out.println(Test.count);
   }
}

编译并运行该代码,输出如下:

1

1

---------------

1

2

注意:countstatic所修饰,所有类共享。且不属于对象,访问方式为:类名 . 属性 

内存解析如下:

 (2)修饰方法

如果在任何方法上应用 static 关键字,此方法称为静态方法
①静态方法属于类,而不属于类的对象
②可以直接调用静态方法,而无需创建类的实例
③静态方法可以访问静态数据成员,并可以更改静态数据成员的值
注意:
(i) 静态方法和实例无关 , 而是和类相关 . 因此这导致了两个情况:a.静态方法不能直接使用非静态数据成员或调用非静态方法 ( 非静态数据成员和方法都是和实例相关的)b. this super 两个关键字不能在静态上下文中使用 (this 是当前实例的引用 , super 是当前实例父类实例的引用 , 是和当前实例相关 )
(ii)一个方法具体要不要带 static, 都需要是情形而定
(iii)main是不是静态方法都可以,这取决于我们的JVM
(iv)普通方法不可以有静态的变量(静态的变量属于类变量)
class TestDemo{
    public int a;
    public static int count;
    
    public static void change() {
        count = 100;
        //a = 10; error 不可以访问非静态数据成员
   }
}
public class Main{
   public static void main(String[] args) {
        TestDemo.change();//无需创建实例对象 就可以调用
        System.out.println(TestDemo.count);   
   }
}

编译并运行该代码,输出如下:

100

三、封装

1.什么是封装

在我们写代码的时候经常会涉及两种角色: 类的实现者类的调用者. 封装的本质就是让类的调用者不必太多的了解类的实现者是如何实现类的, 只要知道如何使用类就行了. 这样就降低了类使用者的学习和使用成本, 从而降低了复杂程度

2.private实现封装

private/ public 这两个关键字表示 " 访问权限控制 "
(1)被 public 修饰的成员变量或者成员方法 , 可以直接被类的调用者使用
(2)被 private 修饰的成员变量或者成员方法 , 不能被类的调用者使用( 类的使用者根本不需要知道, 也不需要关注一个类都有哪些 private 的成员. 从而让类调用者以更低的成本来使用类)
class Person { 
     private String name = "张三"; 
     private int age = 18; 
 
     public void show() { 
     System.out.println("我叫" + name + ", 今年" + age + "岁"); 
     } 
} 
class Test { 
     public static void main(String[] args) { 
     Person person = new Person(); 
     //person.name = "张三";//error
     person.show(); 
     } 
}
如果类的实现者修改了字段的名字 , 类的调用者不需要做出任何修改 ( 类的调用者根本访问不到 name, age这样的字段).但是 类的实现者万一修改了 public 方法 show 的名字, 岂不是类的调用者仍然需要大量修改代码吗?这件事情确实如此, 但是一般很少会发生. 一般类的设计都要求类提供的 public 方法能比较稳定, 不应该频繁发生大的改变. 尤其是对于一些基础库中的类, 更是如此. 每次接口的变动都要仔细考虑兼容性问题

3.gettersetter方法

当我们使用 private 来修饰字段的时候 , 就无法直接使用这个字段了。此时如果需要获取或者修改这个 private 属性 , 就需要使用 getter / setter 方法
(1)getName 即为 getter 方法 , 表示获取这个成员的值
(2)setName 即为 setter 方法 , 表示设置这个成员的值
  • set方法的形参名字和类中的成员属性的名字一样的时候,如果不使用this, 相当于自赋值. this 表示当前实例的引用
  • 不是所有的字段都一定要提供 setter / getter 方法, 而是要根据实际情况决定提供哪种方法
  • IDEA 中可以使用 alt + insert (或者 alt + F12) 快速生成 setter / getter 方法. VSCode 中可以使用鼠标右键菜单 -> 源代码操作中自动生成 setter / getter 方法
class Person { 
    private String name;//实例成员变量
    private int age; 
  
    public void setName(String name){ 
    //name = name;//不能这样写,此时3个name都是同一个name,因为局部变量优先
    this.name = name;//this引用,表示调用该方法的对象
    } 
    public String getName(){ 
       return name; 
    } 
 
     public void show(){ 
       System.out.println("name: "+name+" age: "+age); 
     } 
} 
public static void main(String[] args) { 
    Person person = new Person(); 
    person.setName("xiaoxiao"); 
    String name = person.getName(); 
    System.out.println(name); 
    person.show(); 
}

编译并运行该代码,输出如下:

xiaoxiao

name: xiaoxiao age: 0

四、构造方法

1.构造方法是一种特殊方法, 使用关键字 new 实例化新对象时会被自动调用 , 用于完成初始化操作
2.new的执行过程:①为对象分配内存空间     ②调用对象的构造方法
3.语法规则:
(1)方法名称必须与类名称相同
(2)构造方法没有返回值类型声明
(3) 每一个类中一定至少存在一个构造方法(没有明确定义,则系统自动生成一个无参构造)
4.注意:
(1)如果类中没有提供任何的构造函数,那么编译器会默认生成一个不带有参数的构造
(2)若类中定义了构造方法,则默认的无参构造将不再生成
(3)构造方法支持重载 . 规则和普通方法的重载一致
(4)构造方法是用来构造对象的
5.this关键字: this 表示当前对象引用 ( 注意不是当前对象 ). 可以借助 this 来访问对象的字段和方法。 我们在构造函数的内部,我们可以使用this关键字,构造函数是用来构造对象的,对象还没有构造好, 我们就使用了this,那this还代表当前对象吗?当然不是,this代表的是当前对象的引用
this一般可以这样用:
(1)this.data      调用当前对象的属性
(2)this.func()       调用当前对象的方法
(3)this()      调用当前对象的其他构造方法    只能放在构造函数当中
class Person { 
     private String name;//实例成员变量
     private int age; 
     private String sex; 
     
     public Person() { //默认构造函数 构造对象    此处的public不能修改为private,一旦这样修改在类外就无法实例化对象了,不过在类内可以
     this.name = "caocao"; 
     this.age = 10; 
     this.sex = "男"; 
     } 
 
     public Person(String name,int age,String sex) { //带有3个参数的构造函数   两个构造方法之间构成重载
     this.name = name; 
     this.age = age; 
     this.sex = sex;
     } 
     public void show(){ 
         System.out.println("name: "+name+" age: "+age+" sex: "+sex); 
     } 
 
} 
public class Main{ 
    public static void main(String[] args) { 
         Person p1 = new Person();//调用不带参数的构造函数 如果程序没有提供会调用不带参数的构造函数
         p1.show(); 
         Person p2 = new Person("zhangfei",80,"男");//调用带有3个参数的构造函数
         p2.show(); 
   } 
}

编译并运行该代码,输出如下:

name: caocao age: 10 sex:
name: zhangfei age: 80 sex:
class Person{ 
    private String name;

    public Person(){
       //this();//error   调用对象的其他构造方法,构成了无限递归
       this("xiaoxiao");//调用带有一个参数的构造方法    必须放在第一行
       System.out.println("Person()-->不带参数的构造方法");
    }
    public Person(String name){
       this.name = name;
       System.out.println("Person(String)-->带1个参数的构造方法");
    }
    public void show() { 
       System.out.println("name: "+name); 
   }
       
}
public class Test{
    public static void main(String[] args){
        Person person = new Person();
        person.show();
        System.out.println(person);
    }
}

编译并运行该代码,输出如下:

xiaoxiao

Person(String)-->带1个参数的构造方法

Person()-->不带参数的构造方法

五、代码块

1.字段的初始化方式有: (1)就地初始化 (2)使用构造方法初始化 (3)使用代码块初始化。前两种方式前面已经总结过了, 接下来我们介绍第三种方式, 使用代码块初始化

2.根据代码块定义的位置以及关键字,又可分为四种:本地代码块(普通代码块)、静态代码块、构造代码块、同步代码块

(1)本地代码块:定义在方法中的代码块

public class Main{ 
    public static void main(String[] args) { 
        {                          //直接使用{}定义,普通方法块
            int x = 10 ; 
            System.out.println("x1 = " +x); 
        } 
        int x = 100 ; 
        System.out.println("x2 = " +x); 
    } 
}

编译并运行该代码,输出如下:

x1 = 10

x2 = 100 

这种用法比较少见 

(2)构造代码块

构造块:定义在类中的代码块 ( 不加修饰符 ) 。也叫: 实例代码块 。构造代码块一般用于初始化实例成员变量
注意:在new对象的时候才触发实例代码块执行, 且在对象产生之前就执行了 实例代码块的执行与构造方法密切相关,只要是构造方法执行了,那么就会先执行实例代码块当中的语句,紧接着再执行相应的构造方法
class Person{ 
     private String name;//实例成员变量
     private int age; 
     private String sex; 
 
     public Person() { 
         System.out.println("I am Person init()!"); 
    } 
 
    //实例代码块
    { 
         this.name = "bit"; 
         this.age = 12; 
         this.sex = "man"; 
         System.out.println("I am instance init()!"); 
    } 
 
    public void show(){ 
         System.out.println("name: "+name+" age: "+age+" sex: "+sex); 
    } 
 
} 
public class Main { 
     public static void main(String[] args) { 
          Person p1 = new Person(); 
          p1.show(); 
     } 
}

编译并运行该代码,输出如下:

I am instance init()!
I am Person init()!
name: bit age: 12 sex: man
(3)静态代码块
使用 static 定义的代码块。 一般用于初始化静态成员属性
注意: 静态代码块不管生成多少个对象,其只会执行一次,且是最先执行的。静态代码块执行完毕后 , 实例代码块(构造块)执行,再然后是构造函数执行。静态代码块不用实例化对象都可以被执行
class Person{
    private String name;//实例成员变量
    private int age; 
    private String sex; 
    private static int count = 0;//静态成员变量 由类共享数据 方法区
 
    public Person(){ 
    System.out.println("I am Person init()!"); 
    } 
 
    //实例代码块
   { 
        this.name = "bit"; 
        this.age = 12; 
        this.sex = "man"; 
        System.out.println("I am instance init()!"); 
   } 
 
   //静态代码块
   static { 
        count = 10;//只能访问静态数据成员 
        System.out.println("I am static init()!"); 
   } 
 
   public void show(){ 
        System.out.println("name: "+name+" age: "+age+" sex: "+sex); 
   } 
 
} 
public class Main { 
   public static void main(String[] args) { 
       Person p1 = new Person(); 
       Person p2 = new Person();//该静态代码块不会被执行
   } 
}

编译并运行该代码,输出如下:

I am static init()!

I am instance init()!

I am Person init()! 

还有一个点:如果都是静态成员变量,那么其执行的顺序要看定义的顺序

class Person1{
   public static int count1 = 10;
   static{
      count1 = 99;
   }
}
class Person2{
   static{
      count2 = 99;
   }
   public static int count2 = 10;
}
class Person3{
   static{
      count3 = 99;
   }
   public static int count3;
}
class Person4{
   public static int count4;
   static{
      count4 = 99;
   }
}
public class Test{
    public static void main(String[] args) { 
       System.out.println(Person1.count1);
       System.out.println(Person2.count2);
       System.out.println(Person3.count3);
       System.out.println(Person4.count4);
    }
}

编译并运行该代码,输出如下:

99

10

99

99 

由这个结果可以看到有个例外,那就是当count没有被初始化时,默认值就是99 

(4)同步代码块 
后续笔记中将会总结

六、内部类

1.内部类的概念和分类:

定义在类内部的类。分为4种:①本地内部类②静态内部类③实例内部类④匿名内部类

2.本地内部类

本地内部类:定义在方法中的类

public class TestDemo {
    public void func(){
        class Test{
            public int a;
        }
        //本地内部类只能在当前方法中使用
    }
}

本地内部类用得很少,因为它只能在当前方法中使用 

3.实例内部类

 实例内部类:定义在类内部的一个普通的类

注意:

(1)在实例内部类中不能定义一个静态的成员变量,如果非要定义,只能定义1个,而且它是静态常量

(2)实例化内部类的对象:

外部类名.内部类名 变量 = 外部类对象的引用.new 内部类();

(3)最终生成的字节码文件

 (4)实例内部类当中包含两个this,一个是外部类的this,一个是内部类的this

interface A{

}
class OuterClass{
    public int data1 = 1;
    private int data2 = 2;
    public static int data3 = 3;
    //实例内部类,我们可以把它当成外部类的一个普通实例的成员
    class InnerClass implements A{//内部类实现接口(只要是类肯定会有类的特性)
        public int data1 = 999;
        public int data4 = 4;
        private int data5 = 5;
        //private static int data6 = 6;//error  data6是属于类的,但是InnerClass的调用需要依赖于对象
        private static final int DATA6 = 6;

        public InnerClass(){
            System.out.println("不带参数的内部类的构造方法");
        }
        public void test(){
            System.out.println(OuterClass.this.data1);//外部类的this
            System.out.println(this.data1);//内部类的this
            System.out.println(DATA6);
            System.out.println("InnerClass::test()");
        }
    }
    public void func1(){
        System.out.println("OuterClass::func1()");
    }
}
public class TestDemo extends OuterClass.InnerClass{//内部类的继承(只要是类肯定会有类的特性)

    public TestDemo(OuterClass out){
        out.super();
    }
    public static void main(String[] args) {
        OuterClass outerClass = new OuterClass();
        OuterClass.InnerClass innerClass = outerClass.new InnerClass();
        innerClass.test();
    }
}

编译并运行该代码,输出如下:

 

 (5)一般什么时候用到内部类?

//之前我们写链表的时候是这样写的
class Node{

}
class MyLinkedList{

}
//其实可以这样写(“某个东西是由什么什么组成”的关系可以用到内部类,如:链表由一个一个的节点组成)
class MyLinkedList{
    class Node{

    }
}

4.静态内部类 

定义在类内部并且被static修饰
注意:
(1)实例静态内部类对象:外部类名.内部类名 变量 = new 外部类对象的引用.内部类();
(2)访问外部类的普通成员变量:
class OuterClass2{
    public int data1 = 1;
    private int data2 = 2;
    public static int data3 = 3;
    //静态内部类
    static class InnerClass{
        public int data4 = 4;
        private int data5 = 5;
        public static int data6 = 6;

        //写法二:
        public OuterClass out = new OuterClass();
        public void test(){
            //System.out.println(data1);//error  data1、data2的调用时依赖于外部类的引用来调用的,并且访问data2还要提供getter和setter方法
            //System.out.println(data2);//error
            System.out.println(new OuterClass2().data1);//写法一
            System.out.println(out.data1);//写法二
            System.out.println(data3);
            System.out.println(data4);
            System.out.println(data5);
            System.out.println(data6);
            System.out.println("InnerClass::test()");
        }
    }
}
public class TestDemo2 {
    public static void main(String[] args) {
        OuterClass2.InnerClass innerClass = new OuterClass2.InnerClass();
        innerClass.test();
    }
}

5.匿名内部类

匿名内部类:顾名思义,就是没有名字的内部类

class Test{
    public void test(){
        System.out.println("test()haha!");
    }
}
public class TestDemo2 {
    public static void main(String[] args) {
        new Test(){
            @Override
            public void test(){
                System.out.println("我是重写的test方法!");
            }
        }.test();
    }
}

编译并运行该代码,输出如下:

我是重写的test方法!  

七、补充

1.toString方法:

(1)toString 方法会在 println 的时候被自动调用.

(2)将对象转成字符串这样的操作我们称为 序列化

(3)toString 是 Object 类提供的方法, 我们自己创建的 Person 类默认继承自 Object , 可以重写 toString 方法实现我们自己版本的转换字符串方法

(4)IDEA快速生成ObjecttoString方法快捷键:alt+f12(insert)

不用快捷键也行,右键找到generate,然后找到toString(),最后点ok即可

class Person { 
    private String name; 
    private int age; 
    public Person(String name,int age) { 
    this.age = age; 
    this.name = name; 
    } 
    public void show() { 
       System.out.println("name:"+name+" " + "age:"+age); 
    } 
} 
public class Main { 
    public static void main(String[] args) { 
    Person person = new Person("caocao",19); 
    person.show(); 
     //我们发现这里打印的是一个地址的哈希值 原因:调用的是Object的toString方法
    System.out.println(person); 
    } 
}

编译并运行该代码,输出如下:

name caocao age 19
Person@1c168e5
我们可以看一下println的源码:

 重写toString方法:

class Person { 
     private String name; 
     private int age; 
     public Person(String name,int age) { 
     this.age = age; 
     this.name = name; 
 } 
     public void show() { 
         System.out.println("name:"+name+" " + "age:"+age); 
     } 
     //重写Object的toString方法
     @Override//@Override 在 Java 中称为 "注解", 此处的 @Override 表示下面实现的 toString 方法是重写了父类的方法 
     public String toString() { 
         return "Person{" + 
                "name='" + name + '\'' + 
                ", age=" + age + 
                '}'; 
    } 
} 
public class Main { 
    public static void main(String[] args) { 
        Person person = new Person("caocao",19); 
        person.show(); 
        System.out.println(person); 
    } 
}

编译并运行该代码,输出如下:

name caocao age 19
Person{name='caocao', age=19}

 2.匿名对象

(1)没有引用的对象称为匿名对象

(2)匿名对象只能在创建对象时使用

(3)如果一个对象只是用一次, 后面不需要用了, 可以考虑使用匿名对象

class Person { 
     private String name; 
     private int age; 
     public Person(String name,int age) { 
     this.age = age; 
     this.name = name; 
     } 
     public void show() { 
         System.out.println("name:"+name+" " + "age:"+age); 
     } 
} 
public class Main { 
    public static void main(String[] args) { 
         new Person("caocao",19).show();//通过匿名对象调用方法
    } 
}

编译并运行该代码,输出如下:

name caocao age 19
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值