emm...问题...不少。
1、这个构造函数问题就很大:
你传递一个r数组进来,然后你又让this.v1=v1,this.v2=v2,那么这个r的意义到底是什么?你构造出来的这个向量的v1和v2也还是根本没有任何值。
2、这。。这块问题太多了,我都不知道该怎么说,就全都不应该这么玩,下面加法也是一样的我就不圈出来了。
首先,非常不建议用null来声明任何变量,你声明r[]数组为null,下面又在循环里使用r[i],r都不是一个东西(因为它是null,还真不是个东西 手动滑稽),r[i]必然导致万恶的空指针异常NullPointerException。然后前面第一点说了,你的v1和v2根本就没有值,其实他们也是null,所以v1.length也将产生空指针异常,你的for循环根本没法进行。好,就算假设你的v1和v2都声明为new double[0]了,他们不再是null了,那么你的这个方法最终有可能返回null,又来了又来了,不要随便使用null,一不小心可能导致你main方法中调用这个方法后再次造成空指针异常。所以你非要这样写的话也建议写成return new double[0]这样即使它是一个空的数组但最起码它已经是个对象了,不再是null了。
3、main方法中null又双叒来了:
null数组不能放任何东西进去,不然将导致空指针异常。
所以现在怎么办?我估计你也发现了,因为你不知道这个数组究竟有多少个数字所以无法准确地定义这个r的长度。
本来我认为最优的做法是利用java的几种数据结构来保存输入项就好了,但是我怕你还没学到,其中这几个数据结构都不需要指定长度就能保存数据,他们能保存的最大数据量为int的最大值:java.util.List(java的集合,特别好用)、java.util.Vector(没错,java本来就有向量这种数据结构,比你这个MyVector功能要多一些)、java.util.Stack(栈其实是继承了向量,是一种特殊的向量)、java.util.Queue(java的队列),常用的就这些。
另外一种方法就是指定r[]数组有一个较大的length,也就是一开始就声明的足够大,比如直接double[] r = new double[999]但是这种是非常不好的办法,一个是如果你最终只存储两三个数字,那么数组空间就浪费太多了,另外是如果超过了999个数字,又会导致数组溢出。
所有我下面采用了第三种直截了当的方法帮你改进为,一开始你要输入向量的长度,你要说明向量到底有多长,这样不就能准确地定义r[]数组了吗?look:
这样就稳得一批了。
4、再看你main方法的最后:
你这种设计方法根本没有体现出两个向量之间的运算关系啊,根本就是只有一个向量在这里。因此,你的运算函数应该修改为传入一个新的向量,也就是这样:
这样的话,main函数里就可以这样了:
看到没,是不是一眼就能看出是向量1和向量2相加、点积?
5、审题!审题!你的toString()方法呐?结果保留两位小数呐?see:
另外题目里还说要定义一个int n的成员变量表示维度。我没太明白这个维度是啥?这不就是一维向量吗?维度不就是1吗?
综上所述,代码被我整体修改为:
public class MyVector {
private double[] array
private int n = 1
public MyVector(double[] array) {
this.array = array
}
public double[] getArray() {
return this.array
}
public double[] MyVectorDott(MyVector myVector2) {
double[] array2 = myVector2.getArray()
double[] result = new double[this.array.length]
for (int i = 0i <this.array.lengthi++) {
result[i] = this.array[i] * array2[i]
}
return result
}
public double[] MyVectorAdd(MyVector myVector2) {
double[] array2 = myVector2.getArray()
double[] result = new double[this.array.length]
for (int i = 0i <this.array.lengthi++) {
result[i] = this.array[i] + array2[i]
}
return result
}
public String toString() {
String s = "("
for (int i = 0i <this.array.lengthi++) {
if (i <this.array.length - 1) {
s += String.format("%.2f", this.array[i]) + ","
} else {
s += String.format("%.2f", this.array[i])
}
}
return s + ")"
}
public static void main(String[] args) {
System.out.print("请输入向量长度:")
Scanner input = new Scanner(System.in)
int length = input.nextInt()
double[] array1 = new double[length]
double[] array2 = new double[length]
System.out.print("请输入第一组向量值:")
input = new Scanner(System.in)
for (int i = 0i <lengthi++) {
array1[i] = input.nextDouble()
}
System.out.print("请输入第二组向量值:")
input = new Scanner(System.in)
for (int i = 0i <lengthi++) {
array2[i] = input.nextDouble()
}
input.close()
MyVector myVector1 = new MyVector(array1)
System.out.println("向量1为:")
System.out.println(myVector1.toString())
System.out.println("向量2为:")
MyVector myVector2 = new MyVector(array2)
System.out.println(myVector2.toString())
MyVector myVector3 = new MyVector(myVector1.MyVectorAdd(myVector2))
System.out.println("向量1与向量2求和为:")
System.out.println(myVector3.toString())
System.out.println("向量1与向量2点积为:")
MyVector myVector4 = new MyVector(myVector1.MyVectorDott(myVector2))
System.out.println(myVector4.toString())
}
}
运行结果:
代码老是会挤在一起,你自己整理一下
Java程序在运行时,Java运行时系统一直对所有的对象进行所谓的运行时类型标识。这项信息纪录了每个对象所属的类。虚拟机通常使用运行时类型信息选准正确方法去执行,用来保存这些类型信息的类是Class类。Class类封装一个对象和接口运行时的状态,当装载类时,Class类型的对象自动创建。Class没有公共构造方法。Class对象是在加载类时由Java虚拟机以及通过调用类加载器中的defineClass方法自动构造的,因此不能显式地声明一个Class对象。虚拟机为每种类型管理一个独一无二的Class对象。也就是说,每个类(型)都有一个Class对象。运行程序时,Java虚拟机(JVM)首先检查是否所要加载的类对应的Class对象是否已经加载。如果没有加载,JVM就会根据类名查找.class文件,并将其Class对象载入。基本的Java类型(boolean、byte、char、short、int、long、float和double)和关键字void也都对应一个Class对象。每个数组属于被映射为Class对象的一个类,所有具有相同元素类型和维数的数组都共享该Class对象。一般某个类的Class对象被载入内存,它就用来创建这个类的所有对象。