一、static关键字

1.1、static关键字

静态:static
用法:是一个修饰符,用于修饰成员(成员变量,成员函数)
static 修饰的内容,所有对象共享
当成员被静态修饰后,就多了一个调用方式,除了可以被对象调用外,还可以被类名.静态成员


package com.day06;
/**
* 人类
* @author Administrator
*静态:static
*用法:是一个修饰符,用于修饰成员(成员变量,成员函数)
*static 修饰的内容,所有对象共享
*当成员被静态修饰后,就多了一个调用方式,除了可以被对象调用外,
*还可以被类名.静态成员
*/
public class Person {
//属性
static String country="CN"; String name;
public void show(){
System.out.println(this.name+" "+this.country);
} public static void main(String[] args) {
//多个对象使用同一个属性国家
Person p=new Person();
Person p1=new Person();
p.name="张三";
p1.name="李四";
p.show();
p1.show();
System.out.println(Person.country); //类名.静态成员变量
}
}

特点:

1.随着类的加载而加载--也就是:静态会随着类的消失而消失,它的生命周期最长。

2.优先于对象存在---

静态是先存在,对象是后存在。

3.被所有对象共享

4.可以直接被类名所调用

1.2、实例变量和类变量的区别

1.存放位置

类变量随着类的加载而加载存在方法区中。

实例变量随着对象的建立而存在于堆内存中。

2.生命周期

类变量生命周期最长,随着类的消失而消失

实例变量生命周期随着对象的消失而消失

1.3、使用注意事项

静态方法只能访问静态成员(静态成员和静态方法)

非静态方法既可以访问静态也可以访问非静态

静态方法中不可以定义this. super关键字

因为静态优先于对象存在,所以静态中不可以出现this

主函数是静态的

静态有利有弊

利处:对对象共享数据进行单独空间的存储,节省内存空间,没有必要每个对象都存储一份

可以直接被类名调用。

弊端:生命周期过长

访问出现局限性。(静态虽好,只能访问静态。)

1.4、主函数是静态的

主 函数:是一个特殊的函数,作为程序的入口,可以被JVM调用

定义:

public :代表差该该函数访问权限是最大的

static:代表主函数随着类的加载就已经存在了。

void:主函数没有具体的返回值。

main():不是关键字,但是是一个特殊的单词,可以被JVM识别。

函数的参数:String[] args--是一个数组,数组中的元素是字符串,字符串类型的数组

主函数是固定格式的,JVM识别。

args:arguments

JVM在调用主函数时,传入的是new String[0]


package com.day06;

public class MainTest {

    public static void main(String[] args) {
//遍历主函数
for (int i = 0; i < args.length; i++) {
System.out.println(args[i]);
} } } package com.day06; public class MainDemo { public static void main(String[] args) {
String [] arr={"张三","李四","王五","赵六","钱七"};
MainTest.main(arr);
} }

结果:

张三
李四
王五
赵六
钱七

1.5、什么时候使用静态

2个方面:

静态修饰的内容有成员变量和函数

什么时候定义静态变量?

当对象在出现共享数据时,该数据被static修饰

对象中的特有数据要定义成非静态,存在于堆内存,对象内部

什么时候定义静态函数
当功能内部没有访问到非静态数据(对象的特有数据)

那么该 功能可以定义成静态

1.6、静态工具类

package com.day06;

/**
* 建立一个用于操作数组的工具类, 其中包含着常见的对数组操作的函数, 如:最值,排序等。
*
* @author Denny
* @version v1.0
*/
public class ArrayTool {
/**
* 为了不让外界创建对象,将构造方法私有化
* @author Denny
*
* @version v1.0
*/
private ArrayTool() {
} /**
* 获取整型数组的最大值
*
* @param arr
* 接收一个元素为int 类型的数组
* @Return 该数组的最大的元素值
*/
public static int getMax(int[] arr) {
int maxIndex = 0;
for (int x = 1; x < arr.length; x++) {
if (arr[x] > arr[maxIndex])
maxIndex = x;
}
return arr[maxIndex];
} /**
* 对数组进行选择排序
*
* @param arr
* 接收一个元素为int 的数组
*/
public static void selectSort(int[] arr) {
for (int x = 0; x < arr.length - 1; x++) {
for (int y = x + 1; y < arr.length; y++) {
if (arr[x] > arr[y])
swap(arr, x, y);
}
}
} // 用于给数组进行元素的位置置换。
private static void swap(int[] arr, int a, int b) {
int temp = arr[a];
arr[a] = arr[b];
arr[b] = temp;
} /**
* 获取指定的元素在指定数组中的索引
*
* @param arr
* 接收一个元素为int 类型的数组
* @param key
* 要找的元素
* @return 返回该元素第一次出现的位置,如果不存在则返回 -1
*/
public static int getIndex(int[] arr, int key) {
for (int x = 0; x < arr.length; x++) {
if (arr[x] == key)
return x;
}
return -1;
}
    /**
* 将int数组转换成字符串,格式是:[e1,e2,...]
*
* @param arr
* 接收一个元素为int类型的数组
* @return 返回该数组的字符串表现形式
*/
public static String arrayToString(int[] arr) {
String str = "["; for (int x = 0; x < arr.length; x++) {
if (x != arr.length - 1)
str = str + arr[x] + ",";
else
str = str + arr[x] + "]";
}
return str;
}
}

使用类名.静态方法

二、静态代码块

2.1、静态代码块

static{

代码块;

}


package com.day06;

/**
* 静态代码块
*
* @author Denny static{ 静态代码块中的语句 }
* 特点:随着类的加载而执行, 只执行一次 用于给类进行初始化
* 并优先于主函数
*/
class StaticDemo { static {
System.out.println("static code A");
} }
public class StaticCode{
static {
System.out.println("static code B");
} static {
System.out.println("static code C");
}
public static void main(String[] args) { //2个匿名对象
new StaticDemo();
new StaticCode(); }
}

结果:

static code B
static code C
static code A

只执行一次就不在执行了

三、对象初始化过程

3.1、初始化过程

package com.day06;

/**
* 静态代码块
*
* @author Denny
* static{ 静态代码块中的语句 }
* 特点:随着类的加载而执行, 只执行一次 用于给类进行初始化 并优先于主函数
*/
public class StaticCode {
int num=9;
public StaticCode() {
System.out.println("static code A");
} static {
System.out.println("static code B");
} {
System.out.println("con code C "+this.num);
} public StaticCode(int num) {
System.out.println("con code D");
}
public static void show(){
System.out.println("E");
} public static void main(String[] args) { new StaticCode(4); }
}
 

结果:

static code B
con code C  9
con code D

四、对象调用成员过程

4.1、初始化过程

1.因为new 用到了类.class,所以会先找到类.class

2.执行该类中的static代码块,如果有的话,给类.class进行初始化

3.堆内存中开辟空间,分配内存地址,

4.在堆内存中建立对象的特有属性,并默认初化成员变量

5.对对象进行显示初始化

6.对对象进行构造代码块初始化

7.对对象进行对应的构造函数初始化。

8.将内存地址赋给内存中的对象变量

五、单例模式

设计模式:对问题行之有效的解决方式,其实,它是一种思想。

单例设计模式解决的问题:就是可以保证一个类在内存中的对象唯一性。
    比如多个程序使用同一个配置信息对象时,就需要保证该对象的唯一性。

    如何保证对象唯一性呢?
    1、不允许其他程序用new创建该类对象。
    2、在该类创建一个本类实例。
    3、对外提供一个方法让其他程序可以获取该对象。

步骤:
    1、私有化该类构造函数。
    2、通过new在本类中创建一个本类对象。
    3、定义一个公有的方法,将创建的对象返回。

5.1、饿汉式


package com.day06;
/**
* 饿汉式
* @author denny
*
*/
public class SingleDemo {
private String name;
private int age;
private static SingleDemo singleDemo=new SingleDemo(); //私有 构造方法
private SingleDemo(){ }
//提供公有的访问
public static SingleDemo getNewIntance(){
return singleDemo;
} public static void main(String[] args) {
SingleDemo s1=SingleDemo.getNewIntance();
SingleDemo s2=SingleDemo.getNewIntance();
System.out.println(s1==s2); } }
 

结果:true

5.2、懒汉式


package com.day06;
/**
* 饿汉式
* @author denny
*
*/
public class SingleDemo2 {
private String name;
private int age;
private static SingleDemo2 singleDemo2; //私有 构造方法
private SingleDemo2(){ }
//提供公有的访问
public static SingleDemo2 getNewIntance(){
if(singleDemo2==null){
singleDemo2=new SingleDemo2();
}
return singleDemo2;
} public static void main(String[] args) {
SingleDemo2 s1=SingleDemo2.getNewIntance();
SingleDemo2 s2=SingleDemo2.getNewIntance();
System.out.println(s1==s2); } }

结果:true

基础学习day06---面向对象二---static,类的初始化和调用顺序、单例模式的更多相关文章

  1. jvm的学习笔记:二、类的初始化,代码实战(3)

    首次主动此用导致类的初始化 MyParent4 myParent4 = new MyParent4(); MyParent4 myParent5 = new MyParent4(); 输出: MyPa ...

  2. jvm的学习笔记:二、类的初始化,代码实战(1)

    对于静态字段来说,直接定义该字段的类才会被初始化 System.out.println(MyChild1.str); 输出: myParent1 static block hello myParent ...

  3. jvm的学习笔记:二、类的初始化,代码实战(2)

    常量在编译阶段,会存在调用这个常量的方法的所在的类的常量池当中 System.out.println(MyParent2.str); 输出: hello parent2 依据:在MyTest2类调用M ...

  4. jvm的学习笔记:二、类的初始化,代码实战(4)

    当接口被初始化的时候,不要求其父类被初始化 System.out.println(MyChild5.c); 输出: MyChild5 1 依据:new Random().nextInt(3)并非编译区 ...

  5. 078 01 Android 零基础入门 02 Java面向对象 01 Java面向对象基础 01 初识面向对象 03 创建类

    078 01 Android 零基础入门 02 Java面向对象 01 Java面向对象基础 01 初识面向对象 03 创建类 本文知识点:创建类 说明:因为时间紧张,本人写博客过程中只是对知识点的关 ...

  6. Java学习笔记11---静态成员变量、静态代码块、成员变量及构造方法的初始化或调用顺序

    当创建一个对象时,各种成员变量及构造方法的初始化或调用顺序是怎样的呢? (1).如果类尚未加载,则先初始化静态成员变量和静态代码块,再初始化成员变量,最后调用相应的构造方法: (2).如果类已经加载过 ...

  7. Java基础学习笔记十二 类、抽象类、接口作为方法参数和返回值以及常用API

    不同修饰符使用细节 常用来修饰类.方法.变量的修饰符 public 权限修饰符,公共访问, 类,方法,成员变量 protected 权限修饰符,受保护访问, 方法,成员变量 默认什么也不写 也是一种权 ...

  8. Java基础学习(三)—面向对象(上)

    一.理解面向对象       面向对象是一种思想,是基于面向过程而言的,就是说面向对象是将功能等通过对象来实现,将功能封装进对象之中,让对象去实现具体的细节:这种思想是将数据作为第一位,而方法或者说是 ...

  9. java基础学习05(面向对象基础01)

    面向对象基础01 1.理解面向对象的概念 2.掌握类与对象的概念3.掌握类的封装性4.掌握类构造方法的使用 实现的目标 1.类与对象的关系.定义.使用 2.对象的创建格式,可以创建多个对象3.对象的内 ...

随机推荐

  1. codeforces MUH and Important Things

    /* 题意:给一个序列,表示每一项任务的难度,要求完成每一项任务的循序是按照难度由小到大的!输出三种符合要求的工作顺序的序列! 思路:直接看代码.... */ 1 #include<iostre ...

  2. Windows7 x64 系统下安装 Nodejs 并在 WebStorm 9.0.1 下搭建编译 LESS 环境

    1. 打开Nodejs官网http://www.nodejs.org/,点“DOWNLOADS”,点64-bit下载“node-v0.10.33-x64.msi”. 2. 下载好后,双击“node-v ...

  3. [前端]分享一个Bootstrap可视化布局的网站

    如果你像我一样:是个前端渣,能看懂css和html,略懂Bootstarp,懒! 当你每次都想独立完成一个web页面而不知道从哪里下手的时候,那么下面的这个网站,就是你所以需要的! http://ww ...

  4. 《敏捷个人-认识自我、管理自我.pdf》更新至 v0.7

    更新版1400多页,原价10元,现在 1元淘宝再次上架 http://t.cn/zT8GOa7 , 活动截止时间到:2013-8-18日 v0.7增加16期敏捷个人周刊,15天的每日认识练习,10天的 ...

  5. CentOS6.5菜鸟之旅:关于搜索的shell命令

    一.locate命令 用于模糊搜索文件(目录)的绝对路径. 示例1: // 凡是绝对路径当中含jdk字符串的文件(目录)均被搜索出来 fsjohnhuang@fsjohnhuang~# locate ...

  6. CentOS6.5菜鸟之旅:U盘安装CentOS64位

    一.前言 之前下载了个CentOS7 32位版,一下就安装成功了,但由于其目录结构等与之前的CentOS版本有很大的不同,加上教程不多不利于我这种菜鸟学习,于是决定重装CentOS6.5来学习.本篇用 ...

  7. ActiveMQ学习(四)——应用程序接口

    在 Java 里有 JMS的多个实现.其中 apache 下的 ActiveMQ就是不错的选择. 用 ActiveMQ最好还是了解下 JMS JMS 公共 点对点域 发布/订阅域 Connection ...

  8. 【第二课】深入理解Handler

    简要讲解Handler是做什么的 我们知道,在Android中,app启动会启动一个进程一个线程——UI线程,UI线程是主线程,并且不允许这个线程阻塞超过5秒,一旦超过5秒就会ANR. 所以较为耗时的 ...

  9. Github教程(1)

    Git基本命令 git diff:查看工作树,暂存区,最新提交之间的差别 举例: 在README.MD中增加一行 ## This is the subtitle 执行git diff 命令,查看当前工 ...

  10. 关于 CommonJS AMD CMD UMD 规范的差异总结

    一.CommonJS 主要是用于服务器端的规范,比如目前的nodeJS. 根据CommonJS规范,一个单独的文件就是一个模块.每一个模块都是一个单独的作用域,也就是说,在一个文件定义的变量(还包括函 ...