面向对象(上)

面向对象的特点:封装性(是面向对象的核心思想,将对象的属性和行为封装起来)、继承性(主要描述类与类之间的关系,通过继承,可以在无需重新编写原有类的情况下,对原有类的功能进行扩展)和多态性(指的是在程序中允许出现重名现象,它指在一个类中定义的属性和方法被其他类继承后,它们可以具有不同的数据类型或表现出不同的行为,使得同一个属性和方法在不同的类中具有不同的语义。例如听到cut时,理发师的行为是剪发,演员的行为是停止表演)。
一个类包含多个对象,比如动物类,包含对象有狗、狼、猫等等。
在程序中创建对象,首先需要定义一个类。类中可以定义成员变量(用于描述对象的特征)和成员方法(用于描述对象的行为)。
class Person{
    int age = 23;   //定义在类中的变量为成员变量
    //定义speak()方法
    void speak(){
        int age = 30;   //定义在方法中的变量为局部变量
        System.out.println("我今年"+age+"岁!");
        /*局部变量可以和成员变量同名,此时方法中通过变量名访问到的是局部变量*/
    }
}
class Person{
    int age;
    void speak(){
        System.out.println("我今年"+age+"岁!");
    }
}
public class Test {
    public static void main(String[] args) {
        Person p1 = new Person();
        Person p2 = new Person();
        p1.age = 23;
        p1.speak();
        p2.speak();
    }
}
运行结果
我今年23岁!
我今年0岁!
注:在实例化对象时,Java虚拟机会自动为成员变量进行初始化。但是局部变量必须赋值,否则会报错。
类的封装
是指在定义一个类时,将类中的属性私有化,即是用private关键字来修饰,私有属性只能在它所在类中被访问。
class Student{
    private int age;    //将age属性私有化
    private String name;    //将name属性私有化
    //下面是公有的获取属性值的getXxx()方法和设置属性值额setXxx()方法
    public String getName(){
        return name;
    }
    public void setName(String stuName){
        name = stuName;
    }
    public int getAge(){
        return age;
    }
    public void setAge(int stuAge){
        //下面对传入的参数进行检验
        if(stuAge<=0)
            System.out.println("年龄不合法...");
        else
            age = stuAge;
    }
    public void introduce(){
        System.out.println("大家好,我叫"+name+",今年"+age+"岁!");
    }
}
public class Test {
    public static void main(String[] args) {
        Student stu = new Student();
        stu.setAge(-30);
        stu.setName("Payne");
        stu.introduce();
    }
}
运行结果
年龄不合法...
大家好,我叫Payne,今年0岁!
构造方法
构造方法的定义:必须满足以下三个条件,
①方法名与类名相同
②在方法名的前面没有返回值类型的声明
③在方法中不能使用return语句返回一个值
无参的构造方法:
class Person{
    public Person(){
        System.out.println("无参的构造方法被调用了...");
    }
}
public class Test {
    public static void main(String[] args) {
        Person p = new Person();    //实例化Person对象
    }
}
/*Person类中定义了一个无参的构造方法Person()。“new Person()”语句除了会实例化Person对象,还会调用构造方法Person()。*/
运行结果
无参的构造方法被调用了...
有参的构造方法:
class Person{
    int age;
    public Person(int a){
        age = a;    //为age属性赋值
    }
    public void speak(){
        System.out.println("I am "+age+" years old.");
    }
}
public class Test {
    public static void main(String[] args) {
        Person p = new Person(23);    //实例化Person对象
        p.speak();
    }
}
/*Person类中定义了有参的构造方法Person(int a)。“new Person(23)”会在实例化对象的同时调用有参的构造方法,并传入参数23。*/
运行结果
I am 23 years old.
构造方法的重载:
与普通方法一样,构造方法也可以重载,在一个类中可以定义多个构造方法,只要每个构造方法的参数类型或参数个数不同即可。
class Person{
    int age;
    String name;
    //定义两个参数的构造方法
    public Person(String n,int a){
        name = n;   //为name属性赋值
        age = a;    //为age属性赋值
    }
    //定义一个参数的构造方法
    public Person(int a){
        age = a;    //为age属性赋值
    }
    public void speak(){
        System.out.println("My name is "+name+" ,"+"I am "+age+" years old.");
    }
}
public class Test {
    public static void main(String[] args) {
        Person p1 = new Person("Payne",23);
        Person p2 = new Person(23);
        p1.speak();
        p2.speak();
    }
}
/*Person类中定义了两个构造方法,它们构成了重载。*/
运行结果
My name is Payne ,I am 23 years old.
My name is null ,I am 23 years old.
注:①在Java中的每个类都至少有一个构造方法,即使没有定义构造方法,系统也会默认创建一个没有参数的构造方法。如class Person{}和class Person{public Person(){}}完全一样。
②当在类中定义了有参的构造方法后,在main函数里实例化对象是必须写参数,否则会报错,如在上面代码中添加“Person p3 = new Person();”后会报错。
③构造方法通常用public修饰,当使用private修饰时,无法在外部创建该类的实例对象。
this关键字
①通过this关键字可以明确的访问成员变量,解决与局部变量的冲突问题。
class Person{
    int age;    //定义成员变量
    public Person(int age){
        this.age = age;    //this.age代表成员变量
    }
    public int getAge(){
        return this.age;
    }
}
②通过this关键字调用成员方法。
class Person{
    public void openMounth(){
        
    }
    public void speak(){
        this.openMounth();    //调用成员方法,此处的this可以不写
    }
}
③构造方法是在实例化对象时被Java虚拟机自动调用的,在程序中不能像调用其他方法一样去调用构造方法,但可以在一个构造方法中使用“this([参数1,参数2...])”的形式来调用其他的构造方法。
class Person{
    public Person(){
        System.out.println("无参的构造方法被调用了...");
    }
    public Person(String name){
        this();     //调用无参的构造方法
        System.out.println("有参的构造方法被调用了...");
    }
}
public class Test {
    public static void main(String[] args) {
        Person p = new Person("Payne");
    }
}
运行结果
无参的构造方法被调用了...
有参的构造方法被调用了...
注:①只能在构造方法中使用this调用其他的构造方法,不能在成员方法中使用。②在构造方法中,用this调用构造方法的语句必须位于第一行,且只能出现一次。③不能在一个类的两个构造方法中使用this互相调用,会报错。(以上三点仅限于构造方法中使用this,成员方法不同)
垃圾回收
class Person{
    //下面定义的finalize方法会在垃圾回收前被调用
    public void finalize(){
        System.out.println("对象将被作为垃圾回收...");
    }
}
public class Test {
    public static void main(String[] args) {
        Person p1 = new Person();
        Person p2 = new Person();
        //将变量设置为null,让对象成为垃圾。
        p1 = null;
        p2 = null;
        System.gc();    //调用方法进行垃圾回收
    }
}
运行结果
对象将被作为垃圾回收...
对象将被作为垃圾回收...
static关键字
可以使用static关键字来修饰成员变量,该变量称作静态变量。静态变量被所有实例共享,可以使用“类名.变量名”的形式直接访问,也可以通过类的实例对象来访问。(static只能修饰成员变量,不能修饰局部变量)
class Person{
    static String sex;  //定义静态变量sex
}
public class Test {
    public static void main(String[] args) {
        Person p1 = new Person();   //创建对象p1
        Person p2 = new Person();   //创建对象p2
        Person.sex = "男";   //为静态变量赋值
        System.out.println("p1的性别是:"+p1.sex);   //打印p1的性别
        System.out.println("p2的性别是:"+p2.sex);   //打印p2的性别
    }
}
运行结果
p1的性别是:男
p2的性别是:男
静态方法,只需要在类中定义的方法前加static关键字即可,可以实现在不创建对象的情况下调用该方法。静态方法可以使用“类名.方法名”的方式来访问,也可以通过类的实例对象来访问。
class Person{
    //定义静态方法
    public static void sayHello(){
        System.out.println("Hello");
    }
}
public class Test {
    public static void main(String[] args) {
        Person.sayHello();  //调用静态方法
    }
}
运行结果
Hello
用大括号包围起来的若干行代码称为代码块,用static关键字修饰的叫静态代码块。
class Person{
    static String country;
    //静态代码块
    static {
        country = "China";
        System.out.println("Person类中的静态代码块执行了");
    }
}
public class Test {
    //静态代码块
    static {
        System.out.println("测试类的静态代码块执行了");
    }
    public static void main(String[] args) {
        //下面创建了两个Person对象,静态代码块会被执行
        Person p1 = new Person();
        Person p2 = new Person();
        //由于类只加载一次,所以静态代码块只执行一次
    }
}
运行结果
测试类的静态代码块执行了
Person类中的静态代码块执行了
单例模式
在设计一个类时,需要保证整个程序在运行期间针对该类只存在一个实例对象。就好比月亮这个类,只存在一个。
class Single{
    private static Single INSTANCE = new Single();  //在类的内部创建一个该类的实例对象,用静态变量INSTANCE引用该对象
    private Single(){}      //私有化构造方法,这样就不能在类的外部使用new关键字来创建实例对象了
    public static Single getInstance(){     //提供返回该对象的静态方法
        return INSTANCE;
    }
}
public class Test {
    public static void main(String[] args) {
        Single s1 = Single.getInstance();
        Single s2 = Single.getInstance();
        System.out.println(s1==s2);
    }
}
//getInstance()方法是获得Single类实例对象的唯一途径,因此Single类是一个单例的类。
运行结果
true
内部类
①成员内部类
class Outer{
    private int num = 23;   //定义类的成员变量
    //下面的代码定义了一个成员方法,方法中访问内部类
    public void test(){
        Inner inner = new Inner();
        inner.show();
    }
    //下面的代码定义了一个成员内部类
    class Inner{
        void show(){
            //在成员内部类的方法中访问外部类的成员变量
            System.out.println("num = "+num);
        }
    }
}
public class Test {
    public static void main(String[] args) {
        Outer outer = new Outer();  //创建外部类对象
        outer.test();   //调用test()方法
    }
}
运行结果
num = 23
也可以这样写,运行结果一样。(如果内部类被声明为私有时,外界将无法访问)
class Outer{
    private int num = 23;
    class Inner{
        void show(){
            System.out.println("num = "+num);
        }
    }
}
public class Test {
    public static void main(String[] args) {
        //外部类名.内部类名 变量名 = new 外部类名().new 内部类名()
        Outer.Inner inner = new Outer().new Inner();//这里的new Outer()也会调用构造方法
        inner.show();
    }
}
②静态内部类
可以使用static关键字来修饰一个成员内部类,该内部类称为静态内部类,它可以再不创建外部类对象的情况下被实例化。
class Outer{
//这里写static可以让静态内部类调用此变量
    private static int num = 23;
    //下面的代码定义了一个静态内部类
    static class Inner{
        void show(){
            System.out.println("num = "+num);
        }
    }
}
public class Test {
    public static void main(String[] args) {
        //外部类名.内部类名 变量名 = new 外部类名.内部类名();
        Outer.Inner inner = new Outer.Inner();  //创建内部类对象
        inner.show();   //调用内部类方法
    }
}
运行结果
num = 23
注:在静态内部类中可以定义静态成员,而在非静态的内部类中不允许定义静态的成员。下面代码是非法的:
class Outer{
    class Inner{
        static int num = 10;    //不能定义静态成员,编译会报错
        void show(){
            System.out.println("num = "+num);
        }
    }
}
③方法内部类
方法内部类是指在成员方法中定义的类,他只能在当前方法中被使用。
class Outer{
    private int num = 23;   //定义成员变量
    public void test(){
        //下面是在方法中定义的内部类
        class Inner{
          void show(){
              System.out.println("num = "+num); //访问外部类的成员变量
          }
        }
        Inner inner = new Inner();     //创建内部类对象,方法内部类只能在其定义的当前方法中进行实例化
        inner.show();      //调用内部类方法
    }
}
public class Test {
    public static void main(String[] args) {
        Outer outer = new Outer();  //创建外部类对象
        outer.test();   //调用test()方法
    }
}
运行结果
num = 23
Java的文档注释
以/* * 开头,以*/结束。
/**
* @author 用于对类的说明,表示这个程序的作者。
* @version 用于对类的说明,表示这个程序的开发版本号。
* @param 用于对方法的说明,表示方法定义的参数以及参数对应的说明。
* @return 用于对方法的说明,表示方法的返回值代表的意义。
*/

Java学习笔记(面向对象上)的更多相关文章

  1. 0030 Java学习笔记-面向对象-垃圾回收、(强、软、弱、虚)引用

    垃圾回收特点 垃圾:程序运行过程中,会为对象.数组等分配内存,运行过程中或结束后,这些对象可能就没用了,没有变量再指向它们,这时候,它们就成了垃圾,等着垃圾回收程序的回收再利用 Java的垃圾回收机制 ...

  2. 0028 Java学习笔记-面向对象-Lambda表达式

    匿名内部类与Lambda表达式示例 下面代码来源于:0027 Java学习笔记-面向对象-(非静态.静态.局部.匿名)内部类 package testpack; public class Test1{ ...

  3. 0025 Java学习笔记-面向对象-final修饰符、不可变类

    final关键字可以用于何处 修饰类:该类不可被继承 修饰变量:该变量一经初始化就不能被重新赋值,即使该值跟初始化的值相同或者指向同一个对象,也不可以 类变量: 实例变量: 形参: 注意可以修饰形参 ...

  4. 0013 Java学习笔记-面向对象-static、静态变量、静态方法、静态块、单例类

    static可以修饰哪些成员 成员变量---可以修饰 构造方法---不可以 方法---可以修饰 初始化块---可以修饰 内部类(包括接口.枚举)---可以修饰 总的来说:静态成员不能访问非静态成员 静 ...

  5. 程序设计基础·Java学习笔记·面向对象(下)

    Java程序设计基础之面向对象(下) (补充了上的一些遗漏的知识,同时加入了自己的笔记的ヾ(•ω•`)o) (至于为什么分P,啊大概是为了自己查笔记方便(?)应该是("` 3′") ...

  6. 程序设计基础·Java学习笔记·面向对象(上)

    Java程序设计基础之面向对象(上) (自适应学习进度而进行记录的笔记,希望有一些小小的用处吧(^∀^●)ノシ) (新人上路,望多指教,如有错误,望指正,万分感谢(o゚v゚)ノ) 目录 一.面向对象 ...

  7. 0029 Java学习笔记-面向对象-枚举类

    可以创建几个对象? n多个:大部分的类,都可以随意创建对象,只要内存不爆掉 1个:比如单例类 有限的几个:采用单例类的设计思路,可以只允许创建少数的几个特定的对象:还有就是枚举类. 创建少数几个对象, ...

  8. 0021 Java学习笔记-面向对象-包、构造器

    封装 面向对象的三大特征: 封装 继承 多态 封装: 将对象的状态信息隐藏,不允许外部程序直接访问 通过该类提供的方法来访问和操作 有啥用: 隐藏类的实现细节 在方法中加入控制逻辑,限制对成员变量的不 ...

  9. 0019 Java学习笔记-面向对象-方法

    方法属于谁 方法要么属于类,要么属于对象 static修饰的方法属于类 没有static修饰的方法属于对象 方法只能定义在类里面,不能独立定义 不能独立的执行方法,要么通过类调用,要么通过方法调用 一 ...

  10. java学习笔记 --- 面向对象2

    一.匿名对象 (1)没有名字的对象 (2)应用场景   A:调用方法,仅仅只调用一次的时候. class Car { //描述属性.颜色,轮胎数. String color; int number; ...

随机推荐

  1. Ubuntu18.04 安装MySQL(Linux)解决登陆权限问题及Navicat for mysql 中文乱码问题

    一.MySQL(Linux)解决登陆权限问题 Ubuntu18.04 安装mysql或者mariadb之后,发现普通用户和远程都没有权限连接. ERROR 1045: Access denied fo ...

  2. [考试反思]1013csp-s模拟测试71:徘徊

    分差好大...但是从排名上看也许还可以接受? 不算太炸 但是这个还是算了吧... 其实状态不是很好. T1不会,打的搜索,想到一个剪枝但是感觉没什么用,所以没打. 考后打上,85了...打上另一个就9 ...

  3. Blue:贪心,单调队列

    考场上什么都没想. 显然在扯淡了,应该说是刚开始想了一些没用的. 有决策单调性,所以二分答案? 好,那就二分答案.想想怎么检查每只蛤能不能都跳到终点? 那么每只蛤都不能掉队啊. 如果你现在遇到了一个石 ...

  4. 百度艾尼(ERNIE)常见问题汇总及解答

    一.ERNIE安装配置类问题 Q1:最适合ERNIE2.0的PaddlePaddle版本是?A1:PaddlePaddle版本建议升级到1.5.0及以上版本. Q2:ERNIE可以在哪些系统上使用?A ...

  5. csp-s m 80 题解

    写在前面:(扯淡话) 这次考试是AB组分开考,但是觉得题目并不是很水,所以就来写一下题解,其实这次由于翘掉了午休,所以考试的前半部分还是比较困的(越做越清醒!)今天调完还是很有感触的! 正文: T1 ...

  6. Hybrid App: 了解JavaScript如何与Native实现混合开发

    一.简介 Hybrid Development混合开发是目前移动端开发异常火热的新兴技术,它能够实现跨平台开发,极大地节约了人力和资源成本.跨平台开发催生了很多新的开源框架,就目前而言,在混合开发中比 ...

  7. 详解Kafka Producer

    上一篇文章我们主要介绍了什么是 Kafka,Kafka 的基本概念是什么,Kafka 单机和集群版的搭建,以及对基本的配置文件进行了大致的介绍,还对 Kafka 的几个主要角色进行了描述,我们知道,不 ...

  8. 小白学 Python(23):Excel 基础操作(上)

    人生苦短,我选Python 前文传送门 小白学 Python(1):开篇 小白学 Python(2):基础数据类型(上) 小白学 Python(3):基础数据类型(下) 小白学 Python(4):变 ...

  9. 重写equals方法,也应该重写hashcode方法,反之亦然

    yls 2019年11月07日 一方面 hashcode原则:两个对象equals相等,hashcode值一定相等 默认的hashcode是Object类通过对象的内存地址得到的 若重写equals而 ...

  10. [WPF] Caliburn Micro学习二 Infrastructure

    Caliburn Micro学习一 Installation http://blog.csdn.net/alvachien/article/details/12985415 Step 1. 无论是通过 ...