javaSE之第2讲 静态的应用
来源:互联网 发布:vb 线程钩子实例 编辑:程序博客网 时间:2024/06/18 00:17
74-79 静态的应用
static :是一个修饰符,用于修饰成员(成员变量,成员方法); 当成员被静态修饰后,就多了一个调用方式,除了可以被对象调用外,还可以直接被类名调用;类名.静态成员
特点 :1.随着类的加载而加载,随着类的消失而消失;
2.优先于对象存在;
3.静态修饰的内容被所有对象所共享;
4.可以直接被类名调用;
实例(成员)变量和类(静态)变量的区别:
1.存放位置:类变量随着类的加载而存在于方法区中,实例变量随着对象的建立而存在于堆内
存中;
成员变量可以称为对象的特有数据,静态变量称为对象的共享数据。
2.生命周期:类变量生命周期最长,随着类的消失而消失;
实例变量生命周期随着对象的消失而消失。
静态使用注意事项:
1.静态方法只能访问静态成员(因为非静态成员是随着对象的建立而存在,没对象哪来的非静态成员)
2.非静态方法既可以访问静态也可以访问非静态;
3.静态方法中不可以定义this super关键字;因为静态优先于对象存在
静态有利有弊:
利:对对象的共享数据进行单独空间的存储,节省空间;可以直接被类名调用;
弊:生命周期过长;访问出现局限性(只能访问静态);
class person
{
String name;//(成员变量,实例变量),有对象才有它
static String country = "CN";//(静态的成员变量,类变量),在没有建立对象的时候就
已经存在于内存中了
public static void show()
{
System.out.println(name+" :"+country);//error
}
}
class A74
{
public static void main(String[] args)
{
person p = new person();//新建一个叫p的对象
p.name = "zhangsan";
p.show();
System.out.println( person.country );//类名.静态成员
}
}
什么时候使用静态?
要从两方面下手:
1.什么时候定义静态变量(类变量)呢?
当对象中出现共享数据时,该数据就需要被静态所修饰,
而对象中的特有数据需要定义成非静态存在于堆内存中;
2.什么时候定义静态方法呢?
当方法内部没有访问到非静态数据(对象的特有数据时), 那么该方法可以定义成静态的;(因为当方法内部没有访问到非静态数据时,就不需要通过建立对象,调用对象里的方法来访问方法,只需要将 该方法定义成静态的,直接通过类名.方法的形式来访问)
classperson
{
String name;
public staticvoid show()
{
System.out.println("HelloWorld!");
}
}
classA76
{
public staticvoid main(String[] args)
{
//person p= new person();
//p.show();
person.show();
}
}
静态的应用: 定义工具类
每一个应用程序中都有共性的功能,可以将这些功能进行抽取,独立封装,以便使用;
虽然可以通过建立A77_Tool的对象来使用定义的那些工具,对数组进行操作,但是发现了问题:
1.对象是用于封装数据的,可是A77_Tool类的对象并没有封装特有数据;
2.操作数组的每一个方法都没有用到A77_Tool对象中的特有数据;
所以,可以不通过建立A77_Tool的对象来使用定义的那些工具,直接通过类名调用即可
当方法都静态后,可以方便使用,但是该类还是可以被其他程序建立对象的;
为了更为严谨,需强制让该类不能建立对象;可以通过将构造函数私有化来完成;
class A77_Tool
{
private A77_Tool(){}
public static int getMax(int[] arr )
{
int max = 0;
for (int x = 0;x<arr.length ;++x )
{
if (arr[x] > arr[max])
{
max = x;
}
}
return arr[max];
}
public static int getMin(int[] arr )
{
int min = 0;
for (int x = 0;x<arr.length ;++x )
{
if (arr[x] < arr[min])
{
min = x;
}
}
returnarr[min];
}
}
class A77
{
public static void main(String[] args)
{
int[] arr = {3,5,6,2};
A77_Tool tool = new A77_Tool();
int max = tool.getMax(arr);
int min = A77_Tool.getMin(arr);//不用建立对象
System.out.println("max ="+max);
System.out.println("min ="+min);
}
}
javaSE 74-79
- javaSE之第2讲 静态的应用
- #笔记#圣思园 JavaSE 第66讲——静态 、 动态 代理模式
- #笔记#圣思园 JavaSE 第51讲——策略模式和在集合中的应用
- 第07讲 mysql的应用案例
- #笔记#圣思园 JavaSE 第9讲——面向对象之 封装 encapsulation
- #笔记#圣思园 JavaSE 第10讲——面向对象之 封装 encapsulation 续
- #笔记#圣思园 JavaSE 第11讲——面向对象之 封装 encapsulation 续二
- JavaSE之静态代理模式
- #笔记#圣思园 JavaSE 第57讲——增强的for循环、自动装箱拆箱
- #笔记#圣思园 JavaSE 第59讲——类型安全的枚举
- JavaSE第九讲:面向对象之封装
- #笔记#圣思园 JavaSE 第55讲——泛型详解(2)
- JavaSE第六十五讲:静态代理模式深度剖析
- JavaSE第一百讲:线程同步问题深度剖析
- #笔记#圣思园 JavaSE 第4讲——运算符
- #笔记#圣思园 JavaSE 第17讲——继承剖析
- #笔记#圣思园 JavaSE 第44讲——栈、队列
- #笔记#圣思园 JavaSE 第48讲——Map映射
- json对象
- Java SE、Java EE和Java ME有什么区别
- day12网络编程
- Linux下安装mysql
- JVM 堆内存设置原理
- javaSE之第2讲 静态的应用
- 动画重定向技术分析和Unity中的应用
- 51NOD
- 关于Mat与IplImage之间的转换
- Unix网络编程5种IO模型
- 3:AngularJS:模糊查询过滤内容,下拉菜单排序,过滤敏感字符,验证判断后添加表格信息
- Goland 编辑器更换安装新的主题
- iOS多线程——你要知道的NSThread都在这里
- 基于landmark的疲劳检测