概述:网上流传文章大多都是编译和运行都加下面这串代码
ini
--add-modules=jdk.incubator.vector
我估计他们大多都是复制粘贴的文章,这种东西就是电子垃圾,在idea中,大多人都习惯用maven来构建java项目,接下来我将讲解使用idea+maven去解决这种东西。
第一步,创建一个maven项目

第二步,配置pom文件
加入以下插件:
xml
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.0</version>
<configuration>
<compilerArgs>
<arg>--enable-preview</arg>
<arg>--add-modules=jdk.incubator.vector</arg>
</compilerArgs>
<compilerVersion>17</compilerVersion>
<source>17</source>
<target>17</target>
</configuration>
</plugin>
</plugins>
</build>
第三步,编写测试代码
ini
package org.cyl.spaceutils;
import jdk.incubator.vector.FloatVector;
import jdk.incubator.vector.VectorSpecies;
public class VectorScalarOperations {
public static void main(String[] args) {
// 定义矢量a和b
float[] a = {1, 2, 3};
float[] b = {4, 5, 6};
float[] c=new float[a.length];
VectorScalarOperations v1=new VectorScalarOperations();
long startTime = System.nanoTime();
v1.vectorComputation(a,b,c);
long endTime = System.nanoTime();
System.out.println("矢量花费的时间:"+(endTime-startTime));
long startTime1 = System.nanoTime();
v1.xadd(a,b,c);
long endTime1 = System.nanoTime();
System.out.println("标量花费的时间:"+(endTime1-startTime1));
}
static final VectorSpecies<Float> SPECIES = FloatVector.SPECIES_PREFERRED;
void vectorComputation(float[] a, float[] b, float[] c) {
int i = 0;
int upperBound = SPECIES.loopBound(a.length);
for (; i < upperBound; i += SPECIES.length()) {
// FloatVector va, vb, vc;
var va = FloatVector.fromArray(SPECIES, a, i);
var vb = FloatVector.fromArray(SPECIES, b, i);
var vc = va.mul(va)
.add(vb.mul(vb));
vc.intoArray(c, i);
}
}
void xadd(float[]a,float[]b,float[]c){
for (int i=0;i<a.length;i++){
c[i] = (a[i] * a[i] + b[i] * b[i]) * -1.0f;
}
}
}
第四步,配置java运行时环境

第五步,运行项目
当然在小数据面前,java搞矢量的开销有点大,自然运行速度比标量要慢,矢量运算主要是搞大数据的。 直接以下面这种方式加入两个参数也是可以的。
这是第一次在掘金里面发博客,不知道效果如何,之前一直在csdn里面发,但csdn有个不好的东西,就是吊的博客没人看,而那些不好的博客,不厉害的人却受到吹捧,虽然我知道是互刷的,但会让新人误认为他很厉害,从而被割韭菜。要是这篇数据不行的话,我就不会再写一篇到掘金了