善倾的知识体系构建之路

包声明,包导入和注释以及变量

2018-09-21  本文已影响0人  善倾

注释

先讲注释,程序与注释的关系就好比人和衣服的关系。不写注释,并不会影响程序的执行,人不穿衣服也能生存,但谁会不穿衣服呢?人穿衣服的时候,还想穿的美美的呢!所以,注释也要写的美。

注释的作用?

注释的分类

关于 Javadoc

至于具体的注释风格,以及 JDK 提供的 Javadoc 程序用来生成 API 文档的相关细节,在实际编码时用到了慢慢补充就可以了。

包导入,包声明

import 和 package 都是在对字节码文件进行操作,和源码没关系,因为源码是给人看的,字节码才是给机器运行的,对机器而言根本就不存在源码这种东西。import 是用来指定去哪里找字节码文件,package 是用来指定这个 java 文件编译后的字节码放到指定的目录下。平时看到的分包管理源代码的机制,其实是 IDE 工具的一厢情愿,碰巧它能用来分类管理源代码而已。不使用 IDE 工具的时候,源代码根本就不需要按照包名来建立相应文件夹管理,同样可以直接编译,成功运行。这便是一个有力证明!

包导入 import 关键字的作用是

包声明 package 关键字有以下作用

package practice1;
import practice2.MyPoint2;

public class MyPoint1 {
    public static void main(String[] args) {
        MyPoint1 p = new MyPoint1();
        System.out.println(p.getClass().getName());
        System.out.println("MyPoint1");
        
        //同包下的类
        Person person1 = new Person();
        System.out.println(person1);
        
        //practice2包下的类
        MyPoint2 point2 = new MyPoint2();
        System.out.println(point2);
    }

}


结合以上代码,从 IDE 工具的角度来理解为什么是这样的。只有理解IDE 为你做的每一个工作,才真正达到了可以使用 IDE 的层次。

新建一个工程为 test ,在 practice1 包下新建 MyPoint1 和 Person 类,在 practice2 包下新建 MyPoint2 类。以上在文件资源管理器中看到的情况是,IDE 帮你在磁盘中创建 test 目录,并且它下面还有 bin 和 src 目录,src 目录下按照包名创建相应文件夹来放置 .java 源文件。

当你在 IDE 工具中点击运行按钮时,其实 IDE 帮你做了以下工作。首先在 test 目录下执行 javac -d bin src/*/*.java,即把 src 目录下的所有子目录以及各子目录下的 .java 都编译了,按照包名在 bin 目录下组织存放相关的 .class 文件。

然后,在 bin 目录下执行java practice1.MyPoint1,JVM 就会加载practice1.MyPoint1.class 到内存中,开始执行程序。

所以,以后在使用 IDE 工具的图形化界面操作的时候,多想想它在底层都为你做了什么?只有这样才能到达使用 IDE 工具的做高境界,使用 IDE 工具是为了帮助自己简化工作,而不是让自己依赖 IDE ,没有 IDE 就无法工作了。

变量

所谓变量就是在内存当中按照其数据类型分配固定大小的一个存储空间,专门用来存储数据,这个数据可以随时改变。与之相对应的叫做常量,即它在内存当中的值不可改变。

按照数据类型的角度分类

变量按照数据类型的角度分类,可以分为基本数据类型变量和引用数据类型变量。

基本数据类型变量

Java 中基本数据类型变量无论在哪种操作系统、哪种硬件架构中,它们都占据固定不变的存储大小。能做到这一点就是因为 java 程序是运行在虚拟机上的,这也是 java 程序移植性更好的原因之一。

引用数据类型变量

对于引用数据类型变量,如果把对象比作电视机的话,那么遥控器就是这个对象的引用。在 Java 这种完全面向对象的语言中,想要对对象进行操作,只要拥有这个对象的引用就可以了。这个引用可以任意带走,无论在哪里,都可以通过它来使用对象。这在复杂的分层项目当中,将对象引用的值,也就是对象在内存中的地址,作为参数到处传递的过程中,体现的淋漓尽致。这个比喻出自《 Java 编程思想》一书。

按照内存中的不同位置分类

变量按照内存中的不同位置分类,可以分为局部变量,实例全局变量和静态全局变量。要真正理解变量之间的区别,其实只要心中时刻想着内存图,理解它在内存当中的划分,就不可能会出错。

_Java 内存模型图.png

局部变量

局部变量定义在方法和类的语句块里面,作用范围有限,它存放在栈区。


全局变量定义在类里头,且在被创建的时候就会根据其数据类型有一个默认的初始值,它存放在堆区或者方法区。

静态全局变量

静态全局变量在类的字节码文件被加载到类代码区时,JVM 下一步要做的就是在静态数据区给静态全局变量开辟空间。

静态全局变量会和该类进行静态绑定,并且当该类的对象在堆区开辟空间时,也会有一个和静态变量同名的实例变量存在,指向静态数据区的内存空间。也就是说这个实例全局变量的值是该静态数据在静态数据区的地址!

类是通过静态绑定机制来调用静态方法和变量的,而对象则是通过引用机制实现的此功能。

由于静态全局变量是依赖于类而存在,所以它的生存周期很长,一直在内存中存在,所以没事还是不要乱用静态全局变量。同时也会增大程序的耦合性,因为这个类和这个类的所有对象都可以使用和改变这个属性。

实例全局变量

实例全局变量是依赖于对象而存在的,每一个对象都完整且单独拥有这些实例属性。理解了每一个对象在堆内存当中都有一个完整、独立的内存空间,其他好像没什么好说的了。

对象尽量不要创建在普通方法中,当该方法退栈时,局部变量消失,它在堆内存的对象会变成游离态,变成了垃圾。这一块内存区域因为没有对象的句柄而用不上,又无法用来创建其他对象,就造成了内存泄露。当一块内存没有使用价值,又无法被重新利用时,就好像这块内存没有了一样,就叫做内存泄漏。

不是有 GC 吗?不会回收啊?你还真是 too young 啊!Java 垃圾回收机制尽管有用也没有那么牛皮吧?即使是自己生产对象,使用内存的 c++ 程序员,都没法用好内存,一个不了解你的程序能这么智能?所以说,GC 只是能够改善内存,不可能那么理想化的。

Java 中只有值传递

Java 中的实参和形参中只有值传递。栈中的基本类型变量直接把它的内容给了形参,给的是值。栈中的引用类型变量给的是地址,这是因为它的内容就是对象在堆区的地址啊,他给的也是值。

上一篇下一篇

猜你喜欢

热点阅读