Calling Java “Hello World” from .NET in simple C# Console Application

With Javonet, .NET developers can easily invoke Java methods from .NET applications by referencing Java JARs, setting and getting fields, passing arguments, and retrieving results. Here’s a quick guide with code to help you get started.

You can also check this sample in our GitHub repository:
https://github.com/Javonet/tutorials/tree/master/DotNet/HelloWorld_Calling_Java

Folders structure

We will take care of the folder structure first to keep everything organised. In our main folder (we’ve named it HelloWorldFromJavaConsoleApp) we should create two folders:

  • JavaHelloWorld – this will containt Java files
  • NetCoreConsoleApp – this will be .NET Core main folder
HelloWorldFromJavaConsoleApp
├── JavaHelloWorld
├── NetCoreConsoleApp
└── .gitignore

Java Code (SampleJavaClass.java)

We should now move to JavaHelloWorld folder and create SampleJavaClass.java file. Inside that file, we create a simple static method called “HelloWorld”, that returns “Hello World from Java!” greeting

public class SampleJavaClass {
    public static String HelloWorld() {
        return "Hello World from Java!";
    }
}

This Java code has to be compiled. In order to do this, you have to run this command from terminal from JavaHelloWorld folder:

javac *.java

Now, package the .class file into a JAR. Run the following command:

jar cvf JavaHelloWorld.jar *.class

After these steps, you should see JavaHelloWorld.jar file in your folder.

C# Code (Program.cs)

Now let’s move to our .NET folder (NetCoreConsoleApp) and run the command from terminal:

dotnet new console

This should create Program.cs file, which will be our entry point for the application. We now need to add Javonet SDK to the project. In the same terminal, run this command:

dotnet add package Javonet.Netcore.Sdk

Now we can edit Program.cs file. The C# example demonstrates using Javonet to call Java methods within a .NET console application. Each line has comments, explaining what is happening and Key Points, which can be found below the code.

// Activate Javonet using your license key
Javonet.Netcore.Sdk.Javonet.Activate("n9B5-Km7g-Pp69-j9FE-e9A5");

// Initialize Java runtime environment
var rtmCtx = Javonet.Netcore.Sdk.Javonet.InMemory().Jvm();

// Load Java JAR file
rtmCtx.LoadLibrary("../JavaHelloWorld/JavaHelloWorld.jar");

// Access Java class
var javaType = rtmCtx.GetType("SampleJavaClass").Execute();

// Call HelloWorld method
var result = javaType.InvokeStaticMethod("HelloWorld").Execute();

// Show the result (Hello World)
Console.WriteLine(result.GetValue());

Key Points

  • Javonet Activation: Call Javonet.Activate with your license key. This only needs to be done once in the application.
  • Java Runtime Initialization: Use Javonet.InMemory().Jvm() to initialize the Java runtime.
  • Library Loading: LoadLibrary method points to the JAR file containing your Java code.
  • Method Invocation: Use InvokeStaticMethod to call static methods on the Java class, passing arguments as needed.

The final structure of the project should look like this:

HelloWorldFromJavaConsoleApp
├── JavaHelloWorld
│   ├── JavaHelloWorld.jar
│   ├── SampleJavaClass.class
│   └── SampleJavaClass.java
├── NetCoreConsoleApp
│   ├── NetCoreConsoleApp.csproj
│   └── Program.cs
└── .gitignore

Sample Source Code

This simple example demonstrates how easy it is to call Java methods from .NET and achieve cross-platform integration with just a few lines of code and minimal setup.
You can also checkout or fork this sample from our GitHub repository:
https://github.com/Javonet/tutorials/tree/master/DotNet/HelloWorld_Calling_Java