概述:网上流传文章大多都是编译和运行都加下面这串代码
--add-modules=jdk.incubator.vector
我估计他们大多都是复制粘贴的文章,这种东西就是电子垃圾,在idea中,大多人都习惯用maven来构建java项目,接下来我将讲解使用idea+maven去解决这种东西。
第一步,创建一个maven项目
第二步,配置pom文件
加入以下插件:
<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>
第三步,编写测试代码
package org.cyl.spaceutils;import jdk.incubator.vector.FloatVector;
import jdk.incubator.vector.VectorSpecies;public class VectorScalarOperations {public static void main(String[] args) {// 定义矢量a和bfloat[] 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