基础(二)

思想

面向过程的思想: 怎么按步骤把问题解决, 并将步骤编程方法, 一步一步事项, 适合简单不需要协作的任务
面向对象的思想: 怎么设计这个事务

区别与联系

  • 都是解决问题的思维方式, 都是代码组织的方式
  • 解决简单问题可以使用面向过程的思维方式
  • 解决复杂问题时, 宏观上使用面向对象的思想来把握, 微观处理时使用面向过程的思想

类: 可以看作是一个模板, 或者图纸, 系统根据类的定义来创造对象
对象: 依据类创造出来的实体

面向对象的内存分析

Java虚拟机的内存可分为三个区域: 栈(stack), 堆(heap), 方法区(method area)
方法区实际也在堆里

栈的特点:

  • 描述的是方法执行的内存模型; 每个方法被调用都会创建一个栈帧(存储局部变量, 操作数, 方法, 出口等)
  • JVM为每个线程创建一个栈, 用于存放该线程执行方法的信息(实际参数, 局部变量等)
  • 栈属于线程私有, 不能实现线程间的共享
  • 栈的存储特性: 先进后出, 后进先出
  • 栈由系统自动分配, 熟读块, 栈是一个连续的内存空间内存模型

堆的特点

  • 用于存储创建好的对象和数组(数组也是对象)
  • JVM只有一个堆, 被所有线程共享
  • 堆是一个不连续的内存看空间, 分配灵活, 速度慢

方法区(又叫静态区)的特点:

  • JVM只有一个方法区, 被所有线程共享
  • 方法区实际也是堆, 只是用于存储类, 常量等相关的信息
  • 用来存放程序中永远不变或者唯一的内容(类信息[class对象], 静态变量, 字符串常量等)

内存管理:Java的内存管理很大程度指的是对象的管理, 其中包括对象空间的分配和释放

对象空间的分配: 使用new关键字创建对象
对象空间的释放: 将对象赋值null即可, 垃圾回收器将负责回收所有"不可达"对象的内存空间

构造方法

构造器也叫构造方式, 用于对象的初始化

使用要点

  • 通过关键字new来调用
  • 虽有返回值, 但不能定义返回值类型(返回值的类型肯定是本类), 不能再构造器里使用return返回某个值
  • 如果没有定义构造器, 则编译器会自动定义一个无参的构造函数, 如果已定义则编译器不会自动添加
  • 构造器的方法名必须和类名一致

误区:对象的创建完全是构造方法实现的
其实并不是, 构造方法创建Java对象的重要途径, 通过new关键字调用构造器时, 构造器已确定了返回该类对象, 但这个对象并不是完全由构造器负责创建的

对象创建过程与this用法

创建一个对象分如下4骤(静态初始化块在构造方法之前执行):

  1. 分配对象空间, 并将对象成员变量初始化为0或空
  2. 执行属性的显式初始化,包括静态初始化块
  3. 执行构造方法
  4. 返回对象的地址给相关变量

构造方法的重载: 构造方法也是方法, 只不过有特殊作用而已, 与普通方法一样, 构造方法也可以重载
误区: 如果构造方法中形参名与属性名相同时, 需要使用this关键字区分属性与形参

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

class Test1{
    int i = 1;
    Test1(int i) {
        System.out.println(i);      // 输出的是形参 
        System.out.println(this.i); // 输出的是累属性
    }
}

this的本质就是"创建好的对象的地址", 由于在构造方法调用之前, 对象已经创建, 因此, 在构造方法中可以使用this代表"当前对象"

this常见用法

  1. 在程序中产生歧义之处, 应使用this来指明当前对象
    普通方法中, this总是指向调用该方法的对象
    构造方法中, this总是指向正要初始化的对象
  2. 使用this关键字调用重载的构造方法时, 避免相同的初始化代码. 但只能在构造方法中, 并且必须位于构造方法的第一句
  3. this不能用于static方法中

static关键字

在类中, 用static声明的成员变量为静态成员变量, 也称为类变量. 类变量的生命周期和类相同, 在整个应用程序执行期间都有效

static修饰的成员变量和方法 ---------> 类
普通变量和方法 --------->对象

特点:

  1. 生命的变量为该类的公用变量, 从属于类, 被该类的所有实例共享, 在类被载入时被显式初始化
  2. 对于该类的所有对象来说, static成员变量只有一份, 被该类的所有对象共享
  3. 一般使用"类名.类属性/类方法"来调用(也可以通过对象引用或类名(不需要实例化)访问静态成员)
  4. static方法中不能直接访问非static成员方和法
  5. 静态方法中不能使用this关键字, 调用静态成员使用"类名.类属性/类方法"

静态初始化块
构造方法用于对象的初始化操作
静态初始化块用于类的初始化操作, 在静态初始化块中不能直接访问非static成员

public class Test {
    public static void main(String[] args){
        Test2 test = new Test2();
        System.out.println("****************");
        Test2 test_1 = new Test2();
    }
}

class Test1{
    Test1 (){
        System.out.println("Test1构造方法初始化操作");
    }
    static {
        System.out.println("Test1静态初始化块初始化操作");
    }
}

class Test2 extends Test1{
    Test2 (){
        System.out.println("Test2构造方法初始化操作");
    }
    static {
        System.out.println("Test2静态初始化块初始化操作");
    }
}
/*
Test1静态初始化块初始化操作
Test2静态初始化块初始化操作
Test1构造方法初始化操作
Test2构造方法初始化操作
****************
Test1构造方法初始化操作
Test2构造方法初始化操作
*/  

参数的值传递

Java中,方法中所有参数都是"值传递", 也就是传递值的副本.

Java中包机制与导入

包机制是Java中管理类的重要手段. 开发中会遇到大量同名的类, 通过包可以很容易解决类名重名的问题, 也可以实现对类的有效管理. 包对于类, 相当于文件夹对于文件的作用

使用要点

通常是类的第一句非注释型语句
包名: 域名倒着写, 再加上模块名, 便于内部管理类
写项目时都要加包, 不要使用默认包
con.zpy和com.zpy.model这两个包没有包含关系, 是两个完全独立的包, 只是逻辑上看起来后者是前者的一部分

使用其他包的类需要使用import导入, 从而可以在本类中直接通过类名来调用, 否则需要书写类的完整包名和类名

注意:

Java默认导入java.lang包下所有的类
如果导入两个同名的类, 智能用包名+类名来显示调用相关包

静态导入: 是在JDK1.5新增加的功能, 其作用是用于导入指定类的静态属性, 这样可以直接使用类的静态属性

猜你喜欢

转载自www.cnblogs.com/hesper/p/9690612.html