Passing an array to a Java method
This example demonstrates passing an array to a Java method and returning a value to Mosel.
model MosJvmExample3
uses "mosjvm"
declarations
MyData: array(range) of real
result: real
end-declarations
! Create some data
forall(x in 0..5000) MyData(x) := x*5
! Calculate sum
result := jvmcallreal("com.fico.examples.MathOperations.sumOfArray", MyData)
if jvmstatus=false then
setmatherr("Java exception: "+jvmgetexceptionclass)
end-if
! Print result
writeln("Sum of values = ", result)
end-model Where the MathOperations class is defined as follows:
package com.fico.examples;
public class MathOperations {
public static double sumOfArray(double[] values) {
double tot = 0;
for (double v : values) {
tot += v;
}
return tot;
}
} Calling a Java method that returns an Object
This example demonstrates calling a Java method that returns an Object
model MosJvmExample2
uses "mosjvm"
declarations
o: jvmobject
end-declarations
writeln("Creating file")
o := jvmcallobj("com.fico.examples.FileOperations.createFile")
if jvmstatus=false then
setmatherr("Java exception: "+jvmgetexceptionclass)
end-if
writeln("Deleting file")
jvmcallvoid("com.fico.examples.FileOperations.deleteFile", o)
if jvmstatus=false then
setmatherr("Java exception: "+jvmgetexceptionclass)
end-if
end-model Where the FileOperations class is defined as follows:
package com.fico.examples;
import java.io.*;
public class FileOperations {
public static File createFile() throws IOException {
File f = (new File("testfile.txt")).getAbsoluteFile();
try (PrintWriter pw = new PrintWriter(new FileWriter(f))) {
pw.println("Hello World");
}
return f;
}
public static void deleteFile(File f) throws IOException {
if (!f.delete()) throw new IOException("Failed to delete file: "+f);
}
} © 2001-2019 Fair Isaac Corporation. All rights reserved. This documentation is the property of Fair Isaac Corporation (“FICO”). Receipt or possession of this documentation does not convey rights to disclose, reproduce, make derivative works, use, or allow others to use it except solely for internal evaluation purposes to determine whether to purchase a license to the software described in this documentation, or as otherwise set forth in a written software license agreement between you and FICO (or a FICO affiliate). Use of this documentation and the software described in it must conform strictly to the foregoing permitted uses, and no other use is permitted.
