JAVA学习11/04——关键字static、单例设计模式

关键字static

static 的意义
当我们编写一个类时,其实就是在描述其对象的属性和行为,而并没有产生实质上的对象,只有通过 new 关键字才会产生出对象,这时系统才会分配内存空间给对象,其方法才可以供外部调用。

我们有时候希望无论是否产生了对象或无论产生了多少对象的情况下,某些特定的数据在内存空间里只有一份。

例如所有的中国人都有个国家名称,每一个中国人都共享这个国家名称,不必在每一个中国人的实例对象中都单独分配一个用于代表国家名称的变量。

static 关键字的使用

  • 1.static:静态的。

  • 2.static 可以用来修饰:属性、方法、代码块、内部类。

  • 3.使用 static 修饰属性:静态变量(或类变量)。

  • 3.1 属性:是否使用 static 修饰,又分为:静态属性 VS 非静态属性(实例变量)
    实例变量:我们创建了类的多个对象,每个对象都独立的拥有了一套类中的非静态属性。
    当修改其中一个非静态属性时,不会导致其他对象中同样的属性值的修饰。
    静态变量:我们创建了类的多个对象,多个对象共享同一个静态变量。当通过静态变量去修改某一个变量时,
    会导致其他对象调用此静态变量时,是修改过的。

  • 3.2 static 修饰属性的其他说明:

  • ① 静态变量随着类的加载而加载。可以通过"类.静态变量"的方式进行调用。

  • ② 静态变量的加载要早于对象的创建。

  • ③ 由于类只会加载一次,则静态变量在内存中也只会存在一次。存在方法区的静态域中。

  •  ④ 		类变量		实例变量
    
  •  	类		yes			no
    
  •  	对象		yes			yes
    
  • 3.3 静态属性举例:System.out.Math.PI;

 */
public class StaticTest {
	public static void main(String[] args) {
		
		Chinese.nation = "中国";
		
		Chinese c1 = new Chinese();
		c1.name = "姚明";
		c1.age = 40;
		c1.nation = "CHN";
		
		Chinese c2 = new Chinese();
		c2.name = "马龙";
		c2.age = 30;
		c2.nation = "CHINA";
		
		System.out.println(c1.nation); //CHINA
		
		//编译不通过
//		Chinese.name = "张继科";
		
	}
}
//中国人
class Chinese{
	
	String name;
	int age;
	static String nation;
}
  • 4.使用 static 修饰方法:静态方法

  • ① 随着类的加载而加载,可以通过"类.静态方法"的方式调用

  •  ② 			静态方法		非静态方法
    
  •  	类		yes			no
    
  •  	对象		yes			yes
    
  • ③ 静态方法中,只能调用静态的方法或属性
    非静态的方法中,可以调用所有的方法或属性

  • 5.static 注意点:

  • 5.1 在静态的方法内,不能使用 this 关键字、super 关键字

  • 5.2 关于静态属性和静态方法的使用,大家从生命周期的角度去理解。

  • 6.开发中,如何确定一个属性是否需要声明 static 的?
    》 属性是可以被多个对象所共享的,不会随着对象的不同而不同的。
    》 类中的常量也常常声明为 static

  • 开发中,如何确定一个方法是否要声明为 static 的?
    》 操作静态属性的方法,通常设置为 static 的
    》 工具类中的方法,习惯上声明为 static 的。比如:Math、Arrays、Collections

 */
public class StaticTest {
	public static void main(String[] args) {
		
		Chinese.nation = "中国";
		
		Chinese c1 = new Chinese();
		
		//编译不通过
//		Chinese.name = "张继科";
		
		c1.eat();
		
		Chinese.show();
		//编译不通过
//		chinese.eat();
//		Chinese.info();
	}
}
//中国人
class Chinese{
	
	String name;
	int age;
	static String nation;
	
	public void eat(){
		System.out.println("中国人吃中餐");
		//调用非静态结构
		this.info();
		System.out.println("name : " + name);
		//调用静态结构
		walk();
		System.out.println("nation : " + Chinese.nation);
	}
	
	public static void show(){
		System.out.println("我是一个中国人!");
//		eat();
//		name = "Tom";
		//可以调用静态的结构
		System.out.println(Chinese.nation);
		walk();
	}
	
	public void info(){
		System.out.println("name : " + name + ",age : " + age);
	}
	
	public static void walk(){
		
	}
}

类变量 vs 实例变量内存解析
在这里插入图片描述
单例设计模式
设计模式是在大量的实践中总结和理论化之后优选的代码结构、编程风格、以及解决问题的思考方式。设计模免去我们自己再思考和摸索。就像是经典的棋谱,不同的棋局,我们用不同的棋谱。”套路”

所谓类的单例设计模式,就是采取一定的方法保证在整个的软件系统中,对某个类只能存在一个对象实例。并且该类只提供一个取得其对象实例的方法。如果我们要让类在一个虚拟机中只能产生一个对象,我们首先必须将类的构造器的访问权限设置为 private,这样,就不能用 new 操作符在类的外部产生类的对象了,但在类内部仍可以产生该类的对象。因为在类的外部开始还无法得到类的对象,只能调用该类的某个静态方法以返回类内部创建的对象,静态方法只能访问类中的静态成员变量,所以,指向类内部产生的该类对象的变量也必须定义成静态的。

  • 1.所谓类的单例设计模式,就是采取一定的方法保证在整个的软件系统中,对某个类只能存在一个对象实例
  • 2.如何实现?
    饿汉式 VS 懒汉式
  • 3.区分饿汉式和懒汉式。
    饿汉式:坏处:对象加载时间过长。
    好处:饿汉式是线程安全的。
    懒汉式:好处:延迟对象的创建。
    坏处:目前的写法,会线程不安全。—》到多线程内容时,再修改
  • 单例的饿汉式
public class SingletonTest {
	public static void main(String[] args) {
//		Bank bank1 = new Bank(); 
//		Bank bank2 = new Bank(); 
		
		Bank bank1 = Bank.getInstance();
		Bank bank2 = Bank.getInstance();
		
		System.out.println(bank1 == bank2);
		
	}
}


class Bank{
	
	//1.私有化类的构造器
	private Bank(){
		
	}
	
	//2.内部创见类的对象
	//4.要求此对象也必须声明为静态的
	private static Bank instance = new Bank();
	
	//3.提供公共的静态的方法,返回类的对象。
	public static Bank getInstance(){
		return instance;
	}
}
  • 单例的懒汉式实现
public class SingletonTest2 {
	public static void main(String[] args) {
		
		Order order1 = Order.getInstance();
		Order order2 = Order.getInstance();
		
		System.out.println(order1 == order2);
	}
}
class Order{
	//1.私有化类的构造器
	private Order(){
		
	}
	
	//2.声明当前类对象,没有初始化。
	//此对象也必须声明为 static 的
	private static Order instance = null;
	
	//3.声明 public、static 的返回当前类对象的方法
	public static Order getInstance(){
		if(instance == null){
			instance = new Order();			
		}
		return instance;
	}
}

单例模式的优点

由于单例模式只生成一个实例,减少了系统性能开销,当一个对象的产生需要比较多的资源时,如读取配置、产生其他依赖对象时,则可以通过在应用启动时直接产生一个单例对象,然后永久驻留内存的方式来解决。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值