Casting Java from .NET Framework DLL

This article provides an introduction to cross-technology handling of casting mechanism. Casting is necessary in statically-typed languages like C, C++, Java, and C#, where the data type of a variable is known at compile time. In these languages, if you want to assign a value of one type to a variable of another type, you need to perform a cast.

For example, if you have an integer and you want to use it as a float, you would need to cast it to a float. This is done because different data types may be represented differently in memory, and casting ensures that the data is interpreted correctly.

In contrast, dynamically-typed languages like Python or JavaScript perform most of the casting automatically, and explicit casting is less common.

Javonet allows you to reference and use modules or packages written in (Java/Kotlin/Groovy/Clojure, C#/VB.NET, Ruby, Perl, Python, JavaScript/TypeScript) like they were created in your technology. If have not yet created your first project check Javonet overview and quick start guides for your technology.

With Javonet you can interact with objects and methods from .NET Framework DLL like they were available in Java but invocation must be performed through Javonet SDK API.

Custom Java showing .NET Framework DLL casting

With Javonet it is possible to reference any custom .NET Framework DLL and interact with its methods declared on types defined within that module almost the same as with any other Java library.

Snippet below represents the sample code from .NET Framework DLL which contains a few methods with the same name but different parameter type. Each of these methods can perform different logic so it is necessary to invoke intended method.

public static string CastSampleMethod(System.UInt32 value)
{
	return "CastSampleMethod with System.UInt32 called";
}

public static string CastSampleMethod(System.Single value)
{
	return "CastSampleMethod with System.Single called";
}

public static string CastSampleMethod(System.Double[] value)
{
	return "CastSampleMethod with System.Double[] called";
}

It is possible to invoke each of these methods by casting the value from java to proper type specified in .NET Framework DLL.

// use activate only once in your app
Javonet.activate("your-license-key");

// create called runtime context
RuntimeContext calledRuntime = Javonet.inMemory().clr();

// set up variables
String libraryPath = resourcesDirectory + "/TestClass.dll";
String className = "TestClass.TestClass";

// load custom library
calledRuntime.loadLibrary(libraryPath);

// get type from runtime
InvocationContext calledRuntimeType = calledRuntime.getType(className).execute();

//get type for casting
InvocationContext targetType = calledRuntime.getType("System.UInt32");

// invoke type's method
InvocationContext response = calledRuntimeType.
        invokeStaticMethod("CastSampleMethod", calledRuntime.cast(targetType, 5.2)).
        execute();

// get value from response
String result = (String) response.getValue();

// write result to console
System.out.println(result);

In the snippet above, user intended to invoke CastSampleMethod with argument of specific type. Value from java has been casted to proper type and passed to CastSampleMethod. Second example shows the same steps but for different parameter type.

// use activate only once in your app
Javonet.activate("your-license-key");

// create called runtime context
RuntimeContext calledRuntime = Javonet.inMemory().clr();

// set up variables
String libraryPath = resourcesDirectory + "/TestClass.dll";
String className = "TestClass.TestClass";

// load custom library
calledRuntime.loadLibrary(libraryPath);

// get type from runtime
InvocationContext calledRuntimeType = calledRuntime.getType(className).execute();

//get type for casting
InvocationContext targetType = calledRuntime.getType("System.Single");

// invoke type's method
InvocationContext response = calledRuntimeType.
        invokeStaticMethod("CastSampleMethod", calledRuntime.cast(targetType, 5)).
        execute();

// get value from response
String result = (String) response.getValue();

// write result to console
System.out.println(result);

In the snippet above, user intended to invoke CastSampleMethod with argument of specific type. Value from java has been casted to proper type and passed to CastSampleMethod.

The same operation can be performed remotely by just changing the new Runtime Context invocation from in memory to tcp that will create and interact with your .NET Framework DLL objects on any remote node, container or service that hosts Javonet Code Gateway. This way you can preserve the same logic in your application and instantly switch between monolithic and microservices architecture without the need to implement the integration layer based on web services or other remote invocation methods.

Read more about use cases and software architecture scenarios where Javonet runtime bridging technology can support your development process.