面向对象特点:封装,继承,多态
封装
将某一类对象作为一个类,将它的所有共性封装在一起,有自己私有的属性和方法,但只对外提供一些公共方法,这个过程就是一个封装的过程。
构造函数
初始化对象,如果没有构造函数,对象将无法创建,一般我们没有显示创建构造函数时,java有自带的隐含构造函数,如果我们想在初始话对象时给对象添加一些初始值,那么可以自定义构造函数,在创建对象时,显示调用。
构造代码块
在构造函数运行前运行。
this关键字
看上去是用于区分局部变量和成员变量情况
实际this代表它所在函数所属对象的引用
this关键字在构造函数间调用,并且this语句只能定义在构造函数的第一行,因为初始化要先执行
this关键字在构造函数间调用,并且this语句只能定义在构造函数的第一行,因为初始化要先执行
static关键字
用法:是一个修饰符,用于修饰成员(成员变量、成员函数)。
当成员被静态修饰后,就多了一个调用方式,除了可以被对象调用外,还可以直接被类名调用。
类名.静态成员。
static 特点
随着类的加载而加载,随着类的消失而消失。说明它的生命周期最长
优先于对象存在
被所有对象所共享
注意事项:静态方法只能访问静态成员,非静态方法既可以访问非静态成员,也可以访问静态成员
静态方法中不可以定义this,super关键字。因为静态优先于对象存在,所以静态方法中不可以用this
静态有利有弊:
利处:对对象的共享数据进行单独空间存储,节省空间。没有必要每一个对象中都存储一份。
弊端:生命周期过长,访问出现局限性。(静态虽好,只能访问静态)
主函数
是一个特殊的函数。作为程序的入口,可以被jvm调用。
主函数的定义:
public:代表着该函数访问权限是最大的。
static:代表主函数随着类的加载就已经存在了
void:主函数没有具体的返回值
main:不是关键字,但是是一个特殊的单词,可以被jvm识别
(string[] arr):函数的参数,参数类型是一个数组,该数组中的元素是字符串。字符串类型的数据
主函数是固定格式的:jvm 识别
javadoc:帮助文档的制作
静态代码块
随着类的加载而执行,只执行一次
用于给类初始化,并优先于主函数
对象的初始化过程
class Person { private Person(){} private String name = "hah"; private int age; private static String country = "cn"; Person(String name,int age) { this.name = name; this.age = age; } //构造函数代码块 { System.out.println(name+".."+age); } public void setName(String name) { this.name = name; } public void speak() { System.out.println(this.name+"..."+this.age); } public static void showCountry() { System.out.println("country="+Person.country); Person.method(); } public static void method() { System.out.println("method run"); } } class PersonDemo { public static void main(String[] args) { Person p = new Person("zhangsan",20); p.setName("lisi"); new Person(); } } /* Person p = new Person("zhangsan",20);
该句话都做了什么事情?
1,因为new用到了Person.class.所以会先找到Person.class文件并加载到内存中。
2,执行该类中的static代码块,如果有的话,给Person.class类进行初始化。
3,在堆内存中开辟空间,分配内存地址。
4,在堆内存中建立对象的特有属性。并进行默认初始化。
5,对属性进行显示初始化。
6,对对象进行构造代码块初始化。
7,对对象进行对应的构造函数初始化。
8,将内存地址付给栈内存中的p变量。
*/
对象调用成员过程