/*
static修饰符用于修饰成员变量和函数。
被static修饰的就不在堆内存中了。每个对象都能访问静态成员。
当成员被静态修饰后,就多了一个调用方式,除了可以被对象调用外,
还可以直接被类名调用,类名.静态成员。
static特点:
1.随着类的加载而加载,随着类的消失而消失
2.优先于对象存在,被所有对象所共享
3.可以直接被类名所调用
实例变量和类变量的区别:
1.存储位置
类变量随着类的加载而存在于方法区中。
实例变量随着对象的建立而存在于堆内存中。
2.生命周期
类变量生命周期最长,随着类的消失而消失
实例变量生命周期随着对象的消失而消失
静态使用注意事项:
1.静态方法只能访问静态成员
非静态方法既可以访问静态也可以访问非静态
2.静态方法中不能定义this,super关键字
因为静态优先于对象存在,所以静态方法中不可以出现this
3.主函数是静态的
*/
class Person{
String name;
static String country = "CN";
public void show{
System.out.println(name + ":" + country);
}
}
class StaticDemo{
public static void main(String[] args){
Person p = new Person();
p.name = "zhangsan";
p.show();
System.out.println(Person.country);
}
}
特有内容随着对象存储,在堆内存当中。
方法区(共享区或者数据区):存放类中的方法、共享数据
什么时候使用静态?
要从两方面下手:
因为静态修饰的内容有成员变量和函数
什么时候定义静态变量呢?
当对象中的出现共享数据时,该数据被静态所修饰
对象中的特有数据要定义成非静态存在于堆内存中
什么时候定义静态函数?
当功能内部没有访问到非静态数据(对象的特有数据),那么该功能可以定义成静态的。
静态的应用:
每一个程序中豆邮共性的功能,可以将这些功能进行抽取,独立封装。以便复用。
class ArrayTool{
public int getMax(int[] arr){
int max = 0;
for(int x = 1; x<arr.length;x++){
if(arr[x]>arr[max])
max =x;
}
return arr[max];
}
public int getMin(int[] arr){
int min = 0;
for(int x = 1; x<arr.length;x++){
if(arr[x]>arr[min])
min =x;
}
return arr[min];
}
public 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]){
}
}
}
}
}
class ArrayToolDemo{
public static void main(String[] args){
int[] arr = {1,2,3,4,5};
ArrayTool Tool = new ArrayTool();
int max = Tool(arr);
}
}
虽然可以通过建立ArrayTool的对象使用这些工具方法,对数组操作发现了问题:
1.对象是用于封装数据的,可是ArrayTool并未封装特有数据
2.操作数组的每一个方法都没有用到ArrayTool对象中的特有数据
这是就可考虑,让程序更严谨,不需要对象
可以将ArrayTool中的方法都定义成静态的,直接通过类名调用即可。
所以程序应该在ArrayTool中的方法改成静态方法
将ArrayTool.class发给其他人,其他人只要将该文件所在路径设置到
classpath路径下就可以使用该工具类。
该类中的方法使用者不清楚,所以要创建该工具类的说明书。java的说明书通过文档的注释来完成。
javadoc -d myhelp。
如果当前目录中没有myhelp文件夹,则会自动建该文件夹。从index.html开始看帮助。
一个类中默认会有一个空参数的构造函数。这个默认的构造函数的权限和所属类权限一致。
/**
这是一个可以对数组进行操作的工具类,该类中提供了,获取最值方法
@author 张三
@version v1.1
*/
class ArrayTool{
/**
获取一个整形数组中的最大值。
@param arr接收一个int类型的数组
@return会返回该数组的最大值
*/
public int getMax(int[] arr){
int max = 0;
for(int x = 1; x<arr.length;x++){
if(arr[x]>arr[max])
max =x;
}
return arr[max];
}
public int getMin(int[] arr){
int min = 0;
for(int x = 1; x<arr.length;x++){
if(arr[x]>arr[min])
min =x;
}
return arr[min];
}
public 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]){
}
}
}
}
}