Examples
Topics covered in this chapter:
Passing values to a Java method
This example demonstrates calling a Java method and returning a value to Mosel.
model MosJvmExample1
uses "mosjvm"
parameters
SRC_VALUE=5
end-parameters
writeln(SRC_VALUE, "*2=",
jvmcallint("com.fico.examples.MathOperations.multiply", SRC_VALUE, 2))
if jvmstatus=false then
setmatherr("Java exception: "+ jvmgetexceptionclass)
end-if
end-model Where the MathOperations class is defined as follows:
package com.fico.examples;
public class MathOperations {
public static int multiply(int v1,int v2) {
return v1*v2;
}
} Calling a void Java method
This example demonstrates calling a Java method and displaying a value to the Mosel output stream.
model MosJvmExample2
uses "mosjvm"
parameters
SRC_VALUE=5
end-parameters
jvmcallvoid("com.fico.examples.MathOperations.multiplyAndDisplay", SRC_VALUE, 2)
if jvmstatus=false then
setmatherr("Java exception: "+jvmgetexceptionclass)
end-if
end-model Where the MathOperations class is defined as follows:
package com.fico.examples;
public class MathOperations {
public static void multiplyAndDisplay(int v1,int v2) {
System.out.println("The result of "+v1+"*"+v2+" is "+(v1*v2));
}
} 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);
}
} Creating and calling methods on Java objects
This example demonstrates calling a Java method that creates an Object, then calls an instance method on that Object.
model MosJvmExample2
uses "mosjvm"
declarations
o: jvmobject
end-declarations
writeln("Creating File object")
o := jvmnewobj("java.lang.File","myfile.txt")
if jvmstatus=false then
setmatherr("Java exception: "+jvmgetexceptionclass)
end-if
writeln("Absolute file path = ", jvmcallstr(o, "getAbsolutePath"))
if jvmstatus=false then
setmatherr("Java exception: "+jvmgetexceptionclass)
end-if
end-model © 2001-2025 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.
