含有工具类的java文件:
class Demo
{
public static void main(String[] args)
{
System.out.println("Hello World!");
int[] arr={32,4,566,24,888,42,15,784,246,34};
int max=getMax(arr);
System.out.println("max="+max);
}
public static 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];
}
}
//抽取功能,独立封装成类,便于复用
//全封装成静态方法,因为这个工具类不需要特有数据,不需要实例化为对象!
class ArrayTool
{
//最大值
public static 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 static 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 static void selectedSort(int[] arr)
{
for(int x=0;x<arr.length-1;x++)
{
for(int y=x+1;y<arr.length;y++)
{
if(arr[y]<arr[x])
{
swap(arr,x,y);
}
}
}
}
//交换元素,注意这个不对!值传递无法达到目的,看下面的加入数组参数!!!
/*
private static void swap1(int x,int y)
{
int temp=x;
x=y;
y=temp;
}
*/
private static void swap(int[] arr,int x,int y)
{
int temp=arr[x];
arr[x]=arr[y];
arr[y]=temp;
}
//冒泡排序
public static void bubbleSort(int[] arr)
{
for(int x=0;x<arr.length-1;x++)//遍历多少遍
{
for(int y=0;y<arr.length-1-x;y++)
{
if(arr[y]>arr[y+1])
{
swap(arr,y,y+1);
}
}
}
}
}
编译后ArrayTool.class是一个单独的类文件。
调用工具类的java文件:
class ArrayToolDemo
{
public static void main(String[] args)
{
int[] arr={3,46,37,89,13,90};
int max=ArrayTool.getMax(arr);//虚拟机会先在调用类所在目录找ArrayTool.class文件(虽然ArrayTool类在Demo.java文件里,但会单独产生ArrayTool.class文件),找不到再找ArrayTool.java文件
System.out.println("max="+max);
}
}
如果调用文件直接编译运行,找不到ArrayTool.class,会自动寻找并编译ArrayTool.java文件,但如果找不到这个同名的文件,会报错提示找不到这个类:
D:\java\day05>javac ArrayToolDemo.java
ArrayToolDemo.java:7: 错误: 找不到符号
int max=ArrayTool.getMax(arr);//虚拟机会先在调用类所在目录找Arra
yTool.class文件(虽然ArrayTool类在Demo.java文件里,但会单独产生ArrayTool.class文
件),找不到再找ArrayTool.java文件
^
符号: 变量 ArrayTool
位置: 类 ArrayToolDemo
1 个错误
把ArrayTool类所在的文件改为和类同名,直接编译调用文件就可以了:
D:\java\day05>javac ArrayToolDemo.java
D:\java\day05>java ArrayToolDemo
max=90
---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------