Kotlin/Native 入门
In this tutorial, you'll learn how to create a Kotlin/Native application. Choose the tool that works best for you and create your app using:
- The IDE. Here, you can clone the project template from a version control system and use it in IntelliJ IDEA.
- The Gradle build system. To better understand how things work under the hood, create build files for your project manually.
- The command line tool. You can use the Kotlin/Native compiler, which is shipped as a part of the standard Kotlin distribution, and create the app directly in the command line tool. - Console compilation may seem easy and straightforward, but it doesn't scale well for larger projects with hundreds of files and libraries. For such projects, we recommend using an IDE or a build system. 
With Kotlin/Native, you can compile for different targets, including Linux, macOS, and Windows. While cross-platform compilation is possible, which means using one platform to compile for a different one, in this tutorial, you'll be targeting the same platform you're compiling on.
If you use a Mac and want to create and run applications for macOS or other Apple targets, you also need to install Xcode Command Line Tools, launch it, and accept the license terms first.
In IDE
In this section, you'll learn how to use IntelliJ IDEA to create a Kotlin/Native application. You can use both the Community Edition and the Ultimate Edition.
Create the project
- Download and install the latest version of IntelliJ IDEA.
- Clone the project template by selecting File | New | Project from Version Control in IntelliJ IDEA and using this URL: - https://github.com/Kotlin/kmp-native-wizard
- Open the - gradle/libs.versions.tomlfile, which is the version catalog for project dependencies. To create Kotlin/Native applications, you need the Kotlin Multiplatform Gradle plugin, which has the same version as Kotlin. Ensure that you use the latest Kotlin version:- [versions] kotlin = "2.1.21"
- Follow the suggestion to reload Gradle files:  
For more information about these settings, see the Multiplatform Gradle DSL reference.
Build and run the application
Open the Main.kt file in the src/nativeMain/kotlin/ directory:
- The srcdirectory contains Kotlin source files.
- The Main.ktfile includes code that prints "Hello, Kotlin/Native!" using theprintln()function.
Press the green icon in the gutter to run the code:

IntelliJ IDEA runs the code using the Gradle task and outputs the result in the Run tab:

After the first run, the IDE creates the corresponding run configuration at the top:

IntelliJ IDEA Ultimate users can install the Native Debugging Support plugin that allows debugging compiled native executables and also automatically creates run configurations for imported Kotlin/Native projects.
You can configure IntelliJ IDEA to build your project automatically:
- Go to Settings | Build, Execution, Deployment | Compiler.
- On the Compiler page, select Build project automatically.
- Apply the changes.
Now, when you make changes in the class files or save the file (
Update the application
Let's add a feature to your application so it can count the number of letters in your name:
- In the - Main.ktfile, add code to read the input. Use the- readln()function to read the input value and assign it to the- namevariable:- fun main() { // Read the input value. println("Hello, enter your name:") val name = readln() }
- To run this app using Gradle, specify - System.inas the input to use in the- build.gradle.ktsfile and load the Gradle changes:- kotlin { //... nativeTarget.apply { binaries { executable { entryPoint = "main" runTask?.standardInput = System.`in` } } } //... }
- Eliminate the whitespaces and count the letters: - Use the replace()function to remove the empty spaces in the name.
- Use the scope function letto run the function within the object context.
- Use a string template to insert your name length into the string by adding a dollar
sign $and enclosing it in curly braces –${it.length}.itis the default name of a lambda parameter.
 - fun main() { // Read the input value. println("Hello, enter your name:") val name = readln() // Count the letters in the name. name.replace(" ", "").let { println("Your name contains ${it.length} letters") } }
- Use the 
- Run the application. 
- Enter your name and enjoy the result:  
Now let's count only the unique letters in your name:
- In the - Main.ktfile, declare the new extension function- .countDistinctCharacters()for- String:- Convert the name to lowercase using the .lowercase()function.
- Convert the input string to a list of characters using the toList()function.
- Select only the distinct characters in your name using the distinct()function.
- Count the distinct characters using the count()function.
 - fun String.countDistinctCharacters() = lowercase().toList().distinct().count()
- Convert the name to lowercase using the 
- Use the - .countDistinctCharacters()function to count the unique letters in your name:- fun String.countDistinctCharacters() = lowercase().toList().distinct().count() fun main() { // Read the input value. println("Hello, enter your name:") val name = readln() // Count the letters in the name. name.replace(" ", "").let { println("Your name contains ${it.length} letters") // Print the number of unique letters. println("Your name contains ${it.countDistinctCharacters()} unique letters") } }
- Run the application. 
- Enter your name and see the result:  
Using Gradle
In this section, you'll learn how to manually create a Kotlin/Native application using Gradle. It's the default build system for Kotlin/Native and Kotlin Multiplatform projects, which is also commonly used in Java, Android, and other ecosystems.
Create project files
- To get started, install a compatible version of Gradle. See the compatibility table to check the Kotlin Gradle plugin (KGP) compatibility with available Gradle versions.
- Create an empty project directory. Inside it, create a build.gradle(.kts)file with the following content:
【Kotlin】
   // build.gradle.kts
   plugins {
       kotlin("multiplatform") version "2.1.21"
   }
   repositories {
       mavenCentral()
   }
   kotlin {
       macosArm64("native") {  // on macOS
       // linuxArm64("native") // on Linux
       // mingwX64("native")   // on Windows
           binaries {
               executable()
           }
       }
   }
   tasks.withType<Wrapper> {
       gradleVersion = "8.10"
       distributionType = Wrapper.DistributionType.BIN
   }
【Groovy】
   // build.gradle
   plugins {
       id 'org.jetbrains.kotlin.multiplatform' version '2.1.21'
   }
   repositories {
       mavenCentral()
   }
   kotlin {
       macosArm64('native') {  // on macOS
       // linuxArm64('native') // on Linux
       // mingwX64('native')   // on Windows
           binaries {
               executable()
           }
       }
   }
   wrapper {
       gradleVersion = '8.10'
       distributionType = 'BIN'
   }
   You can use different target names, such as macosArm64, iosArm64 linuxArm64,
   and mingwX64 to define the targets for which you are compiling your code.
   These target names can optionally take the platform name as a parameter, which in this case is native.
   The platform name is used to generate the source paths and task names in the project.
- Create an empty settings.gradle(.kts)file in the project directory.
- Create a - src/nativeMain/kotlindirectory and place a- hello.ktfile inside with the following content:- fun main() { println("Hello, Kotlin/Native!") }
By convention, all sources are located in the src/<target name>[Main|Test]/kotlin directories, where Main is for the
source code and Test is for tests. <target name> corresponds to the target platform (in this case, native),
as specified in the build file.
Build and run the project
- From the root project directory, run the build command: - ./gradlew nativeBinaries- This command creates the - build/bin/nativedirectory with two directories inside:- debugExecutableand- releaseExecutable. They contain the corresponding binary files.- By default, the name of the binary file is the same as the project directory. 
- To run the project, execute the following command: - build/bin/native/debugExecutable/<project_name>.kexe
The terminal prints "Hello, Kotlin/Native!".
Open the project in IDE
Now, you can open your project in any IDE that supports Gradle. If you use IntelliJ IDEA:
- Select File | Open.
- Select the project directory and click Open. IntelliJ IDEA automatically detects if it's a Kotlin/Native project.
If you encounter a problem with the project, IntelliJ IDEA displays the error message in the Build tab.
Using the command-line compiler
In this section, you'll learn how to create a Kotlin/Native application using the Kotlin compiler in the command line tool.
Download and install the compiler
To install the compiler:
- Go to the Kotlin's GitHub releases page.
- Look for a file with kotlin-nativein the name and download one that is suitable for your operating system, for examplekotlin-native-prebuilt-linux-x86_64-2.0.21.tar.gz.
- Unpack the archive to a directory of your choice.
- Open your shell profile and add the path to the compiler's - /bindirectory to the- PATHenvironment variable:- export PATH="/<path to the compiler>/kotlin-native/bin:$PATH"
Although the compiler output has no dependencies or virtual machine requirements, the compiler itself requires Java 1.8 or higher runtime. It's supported by JDK 8 (JAVA SE 8) or later versions.
Create the program
Choose a working directory and create a file named hello.kt. Update it with the following code:
fun main() {
    println("Hello, Kotlin/Native!")
}
Compile the code from the console
To compile the application, execute the following command with the downloaded compiler:
kotlinc-native hello.kt -o hello
The value of the -o option specifies the name of the output file, so this call generates the hello.kexe binary file
on macOS and Linux (and hello.exe on Windows).
For the full list of available options, see Kotlin compiler options.
Run the program
To run the program, in your command line tool, navigate to the directory containing the binary file and run the following command:
【macOS and Linux】
./hello.kexe
【Windows】
./hello.exe
The application prints "Hello, Kotlin/Native" to the standard output.
下一步做什么?
- Complete the Create an app using C interop and libcurl tutorial that explains how to create a native HTTP client and interoperate with C libraries.
- Learn how to write Gradle build scripts for real-life Kotlin/Native projects.
- Read more about the Gradle build system in the documentation.