Android derleme sistemi, uygulama kaynaklarını ve kaynak kodunu derleyip test edebileceğiniz, dağıtabileceğiniz, imzalayabileceğiniz ve dağıtabileceğiniz APK'lar veya Android App Bundle'lar halinde paketler.
Gradle derleme genel bakışı ve Android derleme yapısı başlıklı makalelerde derleme kavramlarını ve Android uygulamasının yapısını ele almıştık. Şimdi ise derlemeyi yapılandırma zamanı.
Android derleme sözlüğü
Gradle ve Android Gradle eklentisi, derlemenizin aşağıdaki yönlerini yapılandırmanıza yardımcı olur:
- Derleme türleri
-
Derleme türleri, Gradle'ın uygulamanızı derlerken ve paketlerken kullandığı belirli özellikleri tanımlar. Derleme türleri genellikle geliştirme yaşam döngünüzün farklı aşamaları için yapılandırılır.
Örneğin, hata ayıklama derleme türü hata ayıklama seçeneklerini etkinleştirir ve uygulamayı hata ayıklama anahtarıyla imzalar. Sürüm derleme türü ise uygulamanızı dağıtım için sürüm anahtarıyla küçültebilir, karartabilir ve imzalayabilir.
Uygulamanızı oluşturmak için en az bir derleme türü tanımlamanız gerekir. Android Studio, hata ayıklama ve yayın derleme türlerini varsayılan olarak oluşturur. Uygulamanızın paketleme ayarlarını özelleştirmeye başlamak için derleme türlerini nasıl yapılandıracağınızı öğrenin.
- Ürün çeşitleri
- Ürün çeşitleri, uygulamanızın kullanıcılara sunabileceğiniz farklı sürümlerini (ör. ücretsiz ve ücretli sürümler) ifade eder. Uygulamanızın tüm sürümlerinde ortak olan kısımları paylaşırken ve yeniden kullanırken farklı kod ve kaynaklar kullanmak için ürün çeşitlerini özelleştirebilirsiniz. Ürün çeşitleri isteğe bağlıdır ve bunları manuel olarak oluşturmanız gerekir. Uygulamanızın farklı sürümlerini oluşturmaya başlamak için ürün çeşitlerini nasıl yapılandıracağınızı öğrenin.
- Varyant oluşturma
- Derleme varyantı, derleme türü ve ürün aroması arasında çapraz bir üründür ve Gradle'ın uygulamanızı derlemek için kullandığı yapılandırmadır. Derleme varyantlarını kullanarak, geliştirme sırasında ürün aromalarınızın hata ayıklama sürümünü ve dağıtım için ürün aromalarınızın imzalı yayın sürümlerini derleyebilirsiniz. Derleme çeşitlerini doğrudan yapılandırmasanız da bunları oluşturan derleme türlerini ve ürün çeşitlerini yapılandırırsınız. Ek derleme türleri veya ürün çeşitleri oluşturmak da ek derleme varyantları oluşturur. Derleme çeşitlerini oluşturma ve yönetme hakkında bilgi edinmek için Derleme çeşitlerini yapılandırma başlıklı makaleyi inceleyin.
- Manifest girişleri
- Derleme varyantı yapılandırmasında manifest dosyasının bazı özelliklerinin değerlerini belirtebilirsiniz. Bu derleme değerleri, manifest dosyasındaki mevcut değerleri geçersiz kılar. Bu, uygulamanızın farklı uygulama adı, minimum SDK sürümü veya hedef SDK sürümü içeren birden fazla varyantını oluşturmak istediğinizde kullanışlıdır. Birden fazla manifest olduğunda, manifest birleştirme aracı manifest ayarlarını birleştirir.
- Bağımlılıklar
- Derleme sistemi, yerel dosya sisteminizdeki ve uzak depolardaki proje bağımlılıklarını yönetir. Bu sayede, bağımlılıklarınızın ikili paketlerini manuel olarak aramanız, indirmeniz ve proje dizininize kopyalamanız gerekmez. Daha fazla bilgi için Derleme bağımlılıkları ekleme başlıklı makaleyi inceleyin.
- İmzalama
- Derleme sistemi, derleme yapılandırmasında imzalama ayarlarını belirtmenize olanak tanır ve derleme işlemi sırasında uygulamanızı otomatik olarak imzalayabilir. Derleme sistemi, derleme sırasında şifre istemini önlemek için bilinen kimlik bilgilerini kullanarak hata ayıklama sürümünü varsayılan bir anahtar ve sertifikayla imzalar. Bu derleme için açıkça bir imzalama yapılandırması tanımlamadığınız sürece derleme sistemi yayın sürümünü imzalamaz. Sürüm anahtarınız yoksa Uygulamanızı imzalama bölümünde açıklandığı şekilde bir tane oluşturabilirsiniz. Uygulamaların çoğu uygulama mağazası üzerinden dağıtılması için imzalı sürüm derlemeleri gerekir.
- Kod ve kaynak daraltma
- Derleme sistemi, her derleme varyantı için farklı bir ProGuard kuralları dosyası belirlemenize olanak tanır. Uygulamanızı oluştururken derleme sistemi, R8 gibi yerleşik küçültme araçlarını kullanarak kodunuzu ve kaynaklarınızı küçültmek için uygun kural grubunu uygular. Kodunuzu ve kaynaklarınızı küçültmek, APK veya AAB boyutunuzu azaltmanıza yardımcı olabilir.
- Birden fazla APK desteği
- Derleme sistemi, her biri yalnızca belirli bir ekran yoğunluğu veya Uygulama İkili Arayüzü (ABI) için gereken kodu ve kaynakları içeren farklı APK'ları otomatik olarak oluşturmanıza olanak tanır. Daha fazla bilgi için Birden fazla APK oluşturma başlıklı makaleyi inceleyin. Ancak tek bir AAB yayınlamak, ekran yoğunluğu ve ABI'ye ek olarak dile göre bölme olanağı sunduğu ve Google Play'e birden fazla yapı yükleme ihtiyacını ortadan kaldırdığı için önerilen yaklaşımdır. Ağustos 2021'den sonra gönderilen tüm yeni uygulamaların AAB kullanması gerekmektedir.
Android derlemelerindeki Java sürümleri
Kaynak kodunuz Java, Kotlin veya her ikisinde de yazılmış olsa derlemeniz için JDK ya da Java dilinin bir sürümünü seçmeniz gereken birkaç yer vardır. Ayrıntılar için Android derlemelerindeki Java sürümleri başlıklı makaleyi inceleyin.
Derleme yapılandırma dosyaları
Özel derleme yapılandırmaları oluşturmak için bir veya daha fazla derleme yapılandırma dosyasında değişiklik yapmanız gerekir. Bu düz metin dosyaları, Kotlin dilinin bir türü olan Kotlin komut dosyası kullanılarak derleme mantığını tanımlamak ve değiştirmek için alana özgü bir dil (DSL) kullanır. Derlemelerinizi yapılandırmak için Java sanal makinesi (JVM) için dinamik bir dil olan Groovy'yi de kullanabilirsiniz.
Android Gradle eklentisi, ihtiyacınız olan DSL öğelerinin çoğunu sunduğundan derlemenizi yapılandırmaya başlamak için Kotlin betiği veya Groovy bilmeniz gerekmez. Android Gradle eklentisi DSL'si hakkında daha fazla bilgi edinmek için DSL referans belgelerini inceleyin. Kotlin betiği de temel Gradle Kotlin DSL'ye dayanır.
Android Studio, yeni bir projeye başlarken bu dosyaların bazılarını sizin için otomatik olarak oluşturur ve bunları makul varsayılan değerlere göre doldurur. Oluşturulan dosyalarla ilgili genel bilgi için Android derleme yapısı başlıklı makaleyi inceleyin.
Gradle Wrapper dosyası
Gradle sarmalayıcı (gradlew
), kaynak kodunuzla birlikte gelen, Gradle'ı indirip başlatan küçük bir uygulamadır.
Bu sayede daha tutarlı bir derleme yürütme süreci elde edilir. Geliştiriciler, uygulama kaynağını indirip gradlew
komutunu çalıştırır. Bu işlem, gerekli Gradle dağıtımını indirir ve uygulamanızı oluşturmak için Gradle'ı başlatır.
gradle/wrapper/gradle-wrapper.properties
dosyası, derlemenizi çalıştırmak için hangi Gradle sürümünün kullanıldığını açıklayan bir özellik (distributionUrl
) içerir.
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-8.0-bin.zip
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
Gradle ayarları dosyası
settings.gradle.kts
dosyası (Kotlin DSL için) veya settings.gradle
dosyası (Groovy DSL için) kök proje dizininde bulunur. Bu ayarlar dosyası, proje düzeyindeki depo ayarlarını tanımlar ve Gradle'a uygulamanızı oluştururken hangi modülleri dahil etmesi gerektiğini bildirir. Çok modüllü projelerde, son derlemeye dahil edilmesi gereken her modül belirtilmelidir.
Çoğu proje için dosya varsayılan olarak aşağıdaki gibi görünür:
Kotlin
pluginManagement { /** * The pluginManagement.repositories block configures the * repositories Gradle uses to search or download the Gradle plugins and * their transitive dependencies. Gradle pre-configures support for remote * repositories such as JCenter, Maven Central, and Ivy. You can also use * local repositories or define your own remote repositories. Here we * define the Gradle Plugin Portal, Google's Maven repository, * and the Maven Central Repository as the repositories Gradle should use to look for its * dependencies. */ repositories { gradlePluginPortal() google() mavenCentral() } } dependencyResolutionManagement { /** * The dependencyResolutionManagement.repositories * block is where you configure the repositories and dependencies used by * all modules in your project, such as libraries that you are using to * create your application. However, you should configure module-specific * dependencies in each module-level build.gradle file. For new projects, * Android Studio includes Google's Maven repository and the Maven Central * Repository by default, but it does not configure any dependencies (unless * you select a template that requires some). */ repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) repositories { google() mavenCentral() } } rootProject.name = "My Application" include(":app")
Groovy
pluginManagement { /** * The pluginManagement.repositories block configures the * repositories Gradle uses to search or download the Gradle plugins and * their transitive dependencies. Gradle pre-configures support for remote * repositories such as JCenter, Maven Central, and Ivy. You can also use * local repositories or define your own remote repositories. Here we * define the Gradle Plugin Portal, Google's Maven repository, * and the Maven Central Repository as the repositories Gradle should use to look for its * dependencies. */ repositories { gradlePluginPortal() google() mavenCentral() } } dependencyResolutionManagement { /** * The dependencyResolutionManagement.repositories * block is where you configure the repositories and dependencies used by * all modules in your project, such as libraries that you are using to * create your application. However, you should configure module-specific * dependencies in each module-level build.gradle file. For new projects, * Android Studio includes Google's Maven repository and the Maven Central * Repository by default, but it does not configure any dependencies (unless * you select a template that requires some). */ repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) repositories { google() mavenCentral() } } rootProject.name = "My Application" include ':app'
Üst düzey derleme dosyası
En üst düzey build.gradle.kts
dosyası (Kotlin DSL için) veya build.gradle
dosyası (Groovy DSL için) kök proje dizininde bulunur. Genellikle projenizdeki modüller tarafından kullanılan eklentilerin ortak sürümlerini tanımlar.
Aşağıdaki kod örneğinde, yeni bir proje oluşturduktan sonra üst düzey derleme komut dosyasındaki varsayılan ayarlar ve DSL öğeleri açıklanmaktadır:
Kotlin
plugins { /** * Use `apply false` in the top-level build.gradle file to add a Gradle * plugin as a build dependency but not apply it to the current (root) * project. Don't use `apply false` in sub-projects. For more information, * see Applying external plugins with same version to subprojects. */ id("com.android.application") version "8.11.0" apply false id("com.android.library") version "8.11.0" apply false id("org.jetbrains.kotlin.android") version "2.1.20" apply false }
Groovy
plugins { /** * Use `apply false` in the top-level build.gradle file to add a Gradle * plugin as a build dependency but not apply it to the current (root) * project. Don't use `apply false` in sub-projects. For more information, * see Applying external plugins with same version to subprojects. */ id 'com.android.application' version '8.11.0' apply false id 'com.android.library' version '8.11.0' apply false id 'org.jetbrains.kotlin.android' version '2.1.20' apply false }
Modül düzeyinde derleme dosyası
Modül düzeyindeki build.gradle.kts
(Kotlin DSL için) veya build.gradle
dosyası (Groovy DSL için) her project/module/
dizininde bulunur. Bu özellik, bulunduğu modül için derleme ayarlarını yapılandırmanıza olanak tanır. Bu derleme ayarlarını yapılandırmak, ek derleme türleri ve ürün çeşitleri gibi özel paketleme seçenekleri sunmanıza ve main/
uygulama manifestindeki veya üst düzey derleme komut dosyasındaki ayarları geçersiz kılmanıza olanak tanır.
Android SDK Ayarları
Uygulamanızın modül düzeyindeki derleme dosyası, derleme sırasında kullanılan Android SDK sürümlerini, platform davranışlarını seçerken ve uygulamanızın üzerinde çalıştığı minimum sürümü belirtirken kullanılan ayarları içerir.
-
compileSdk
-
compileSdk
, kaynak kodunuz derlenirken hangi Android ve Java API'lerinin kullanılabileceğini belirler. En yeni Android özelliklerini kullanmak için derleme sırasında en yeni Android SDK'sını kullanın.Bazı Android platform API'leri eski API düzeylerinde kullanılamayabilir. Yeni özelliklerin kullanımını koşullu olarak koruyabilir veya daha düşük Android API düzeylerinde yeni özellikleri kullanmak için AndroidX uyumluluk kitaplıklarını kullanabilirsiniz.
Her Android SDK, uygulamanızda kullanılmak üzere Java API'lerinin bir alt kümesini sağlar. Java veya Kotlin kaynak kodumda hangi Java API'lerini kullanabilirim? başlıklı makaledeki tabloda, Android SDK sürümüne göre hangi Java API düzeyinin kullanılabildiği gösterilmektedir. Daha yeni Java API'leri, Android'in önceki sürümlerinde desugaring aracılığıyla desteklenir. Bu özellik, derlemenizde etkinleştirilmelidir.
Android Studio,
compileSdk
sürümünüz Android Studio'nun, AGP'nin veya projenizin kitaplık bağımlılığı gereksinimlerinin mevcut sürümüyle çakışıyorsa uyarı gösterir. -
minSdk
-
minSdk
, uygulamanızın desteklemesini istediğiniz en düşük Android sürümünü belirtir.minSdk
ayarı, uygulamanızı hangi cihazların yükleyebileceğini kısıtlar.Android'in daha eski sürümlerini desteklemek için kodunuzda daha fazla koşullu kontrol yapmanız veya AndroidX uyumluluk kitaplıklarını daha fazla kullanmanız gerekebilir. Daha eski sürümleri desteklemenin bakım maliyetini, bu eski sürümleri kullanmaya devam eden kullanıcıların yüzdesiyle karşılaştırmanız gerekir. Mevcut sürüm kullanım yüzdeleri için Android Studio'nun Yeni proje sihirbazı'ndaki sürüm grafiğine bakın.
Android Studio'da kodunuzu düzenlerken veya derlemeniz sırasında kontrolleri çalıştırırken Lint,
minSdk
'da kullanılamayan API'ler hakkında sizi uyarır. Bu sorunları yeni özellikleri koşullu hale getirerek veya geriye dönük uyumluluk içinAppcompat
kullanarak düzeltebilirsiniz. -
targetSdk
-
targetSdk
iki amaca hizmet eder:- Uygulamanızın çalışma zamanı davranışını belirler.
- Hangi Android sürümüne göre test yaptığınızı onaylar.
targetSdk
sürümünden daha yüksek bir Android sürümünün kullanıldığı bir cihazda çalışıyorsanız Android, uygulamanızıtargetSdk
içinde belirtilen daha düşük sürüme benzer şekilde davranan bir uyumluluk modunda çalıştırır. Örneğin, API 23'te çalışma zamanı izinleri modeli kullanıma sunulduğunda tüm uygulamalar bu modeli hemen kullanmaya hazır değildi.targetSdk
değeri 22 olarak ayarlandığında bu uygulamalar, çalışma zamanı izinlerini kullanmadan API 23 cihazlarda çalışabilir ve en soncompileSdk
sürümünde yer alan özellikleri kullanabilir. Google Play dağıtım politikası, hedef API düzeyiyle ilgili ek politikaları zorunlu kılar.targetSdk
değeri,compileSdk
değerinden küçük veya ona eşit olmalıdır.
Not: compileSdk
ve targetSdk
değerlerinin aynı olması gerekmez. Aşağıdaki temel ilkeleri göz önünde bulundurun:
compileSdk
, yeni API'lere erişmenizi sağlartargetSdk
, uygulamanızın çalışma zamanı davranışını belirler.targetSdk
,compileSdk
değerinden küçük veya buna eşit olmalıdır.
Örnek uygulama modülü derleme komut dosyası
Bu örnek Android uygulama modülü derleme komut dosyası, temel DSL öğelerinin ve ayarlarının bazılarını özetlemektedir:
Kotlin
/** * The first section in the build configuration applies the Android Gradle plugin * to this build and makes the android block available to specify * Android-specific build options. */ plugins { id("com.android.application") } /** * Locate (and possibly download) a JDK used to build your kotlin * source code. This also acts as a default for sourceCompatibility, * targetCompatibility and jvmTarget. Note that this does not affect which JDK * is used to run the Gradle build itself, and does not need to take into * account the JDK version required by Gradle plugins (such as the * Android Gradle Plugin) */ kotlin { jvmToolchain(11) } /** * The android block is where you configure all your Android-specific * build options. */ android { /** * The app's namespace. Used primarily to access app resources. */ namespace = "com.example.myapp" /** * compileSdk specifies the Android API level Gradle should use to * compile your app. This means your app can use the API features included in * this API level and lower. */ compileSdk = 33 /** * The defaultConfig block encapsulates default settings and entries for all * build variants and can override some attributes in main/AndroidManifest.xml * dynamically from the build system. You can configure product flavors to override * these values for different versions of your app. */ defaultConfig { // Uniquely identifies the package for publishing. applicationId = "com.example.myapp" // Defines the minimum API level required to run the app. minSdk = 21 // Specifies the API level used to test the app. targetSdk = 33 // Defines the version number of your app. versionCode = 1 // Defines a user-friendly version name for your app. versionName = "1.0" } /** * The buildTypes block is where you can configure multiple build types. * By default, the build system defines two build types: debug and release. The * debug build type is not explicitly shown in the default build configuration, * but it includes debugging tools and is signed with the debug key. The release * build type applies ProGuard settings and is not signed by default. */ buildTypes { /** * By default, Android Studio configures the release build type to enable code * shrinking, using minifyEnabled, and specifies the default ProGuard rules file. */ getByName("release") { isMinifyEnabled = true // Enables code shrinking for the release build type. proguardFiles( getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro" ) } } /** * The productFlavors block is where you can configure multiple product flavors. * This lets you create different versions of your app that can * override the defaultConfig block with their own settings. Product flavors * are optional, and the build system does not create them by default. * * This example creates a free and paid product flavor. Each product flavor * then specifies its own application ID, so that they can exist on the Google * Play Store or an Android device simultaneously. * * If you declare product flavors, you must also declare flavor dimensions * and assign each flavor to a flavor dimension. */ flavorDimensions += "tier" productFlavors { create("free") { dimension = "tier" applicationId = "com.example.myapp.free" } create("paid") { dimension = "tier" applicationId = "com.example.myapp.paid" } } /** * To override source and target compatibility (if different from the * toolchain JDK version), add the following. All of these * default to the same value as kotlin.jvmToolchain. If you're using the * same version for these values and kotlin.jvmToolchain, you can * remove these blocks. */ //compileOptions { // sourceCompatibility = JavaVersion.VERSION_11 // targetCompatibility = JavaVersion.VERSION_11 //} //kotlinOptions { // jvmTarget = "11" //} } /** * The dependencies block in the module-level build configuration file * specifies dependencies required to build only the module itself. * To learn more, go to Add build dependencies. */ dependencies { implementation(project(":lib")) implementation("androidx.appcompat:appcompat:1.7.1") implementation(fileTree(mapOf("dir" to "libs", "include" to listOf("*.jar")))) }
Groovy
/** * The first line in the build configuration applies the Android Gradle plugin * to this build and makes the android block available to specify * Android-specific build options. */ plugins { id 'com.android.application' } /** * Locate (and possibly download) a JDK used to build your kotlin * source code. This also acts as a default for sourceCompatibility, * targetCompatibility and jvmTarget. Note that this does not affect which JDK * is used to run the Gradle build itself, and does not need to take into * account the JDK version required by Gradle plugins (such as the * Android Gradle Plugin) */ kotlin { jvmToolchain 11 } /** * The android block is where you configure all your Android-specific * build options. */ android { /** * The app's namespace. Used primarily to access app resources. */ namespace 'com.example.myapp' /** * compileSdk specifies the Android API level Gradle should use to * compile your app. This means your app can use the API features included in * this API level and lower. */ compileSdk 33 /** * The defaultConfig block encapsulates default settings and entries for all * build variants and can override some attributes in main/AndroidManifest.xml * dynamically from the build system. You can configure product flavors to override * these values for different versions of your app. */ defaultConfig { // Uniquely identifies the package for publishing. applicationId 'com.example.myapp' // Defines the minimum API level required to run the app. minSdk 21 // Specifies the API level used to test the app. targetSdk 33 // Defines the version number of your app. versionCode 1 // Defines a user-friendly version name for your app. versionName "1.0" } /** * The buildTypes block is where you can configure multiple build types. * By default, the build system defines two build types: debug and release. The * debug build type is not explicitly shown in the default build configuration, * but it includes debugging tools and is signed with the debug key. The release * build type applies ProGuard settings and is not signed by default. */ buildTypes { /** * By default, Android Studio configures the release build type to enable code * shrinking, using minifyEnabled, and specifies the default ProGuard rules file. */ release { minifyEnabled true // Enables code shrinking for the release build type. proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' } } /** * The productFlavors block is where you can configure multiple product flavors. * This lets you create different versions of your app that can * override the defaultConfig block with their own settings. Product flavors * are optional, and the build system does not create them by default. * * This example creates a free and paid product flavor. Each product flavor * then specifies its own application ID, so that they can exist on the Google * Play Store or an Android device simultaneously. * * If you declare product flavors, you must also declare flavor dimensions * and assign each flavor to a flavor dimension. */ flavorDimensions "tier" productFlavors { free { dimension "tier" applicationId 'com.example.myapp.free' } paid { dimension "tier" applicationId 'com.example.myapp.paid' } } /** * To override source and target compatibility (if different from the * tool chain JDK version), add the following. All of these * default to the same value as kotlin.jvmToolchain. If you're using the * same version for these values and kotlin.jvmToolchain, you can * remove these blocks. */ //compileOptions { // sourceCompatibility JavaVersion.VERSION_11 // targetCompatibility JavaVersion.VERSION_11 //} //kotlinOptions { // jvmTarget = '11' //} } /** * The dependencies block in the module-level build configuration file * specifies dependencies required to build only the module itself. * To learn more, go to Add build dependencies. */ dependencies { implementation project(":lib") implementation 'androidx.appcompat:appcompat:1.7.1' implementation fileTree(dir: 'libs', include: ['*.jar']) }
Gradle özellikleri dosyaları
Gradle, Gradle derleme araç setinin ayarlarını belirtmek için kullanabileceğiniz, kök proje dizininizde bulunan iki özellik dosyası da içerir:
-
gradle.properties
- Gradle daemon'ın maksimum yığın boyutu gibi proje genelindeki Gradle ayarlarını buradan yapılandırabilirsiniz. Daha fazla bilgi için Build Environment (Derleme Ortamı) başlıklı makaleyi inceleyin.
-
local.properties
-
Aşağıdakiler de dahil olmak üzere derleme sistemi için yerel ortam özelliklerini yapılandırır:
ndk.dir
- NDK'nın yolu. Bu özelliğin desteği sonlandırıldı. NDK'nın indirilen tüm sürümleri, Android SDK dizinindekindk
dizinine yüklenir.sdk.dir
- Android SDK'sının yolu.cmake.dir
- CMake'in yolu.ndk.symlinkdir
- Android Studio 3.5 ve sonraki sürümlerde, NDK'ye, yüklenen NDK yolundan daha kısa olabilen bir sembolik bağlantı oluşturur.
NDK'yı daha kısa bir yola yeniden eşleme (yalnızca Windows)
Windows'da, yüklenen NDK klasöründeki ld.exe
gibi araçlar uzun yollarla sonuçlanır. Araçlar uzun yolları iyi desteklemez.
Daha kısa bir yol oluşturmak için local.properties
içinde ndk.symlinkdir
özelliğini, Android Gradle eklentisinin NDK'ye sembolik bağlantı oluşturmasını isteyecek şekilde ayarlayın. Bu sembolik bağlantının yolu, mevcut NDK klasöründen daha kısa olabilir.
Örneğin, ndk.symlinkdir = C:\
aşağıdaki sembolik bağlantıyla sonuçlanır:
C:\ndk\19.0.5232133
Projeyi Gradle dosyalarıyla senkronize etme
Projenizdeki derleme yapılandırma dosyalarında değişiklik yaptığınızda Android Studio, derleme yapılandırma değişikliklerinizi içe aktarabilmesi ve yapılandırmanızın derleme hatalarına neden olmadığından emin olmak için bazı kontroller yapabilmesi amacıyla proje dosyalarınızı senkronize etmenizi gerektirir.
Proje dosyalarınızı senkronize etmek için değişiklik yaptığınızda görünen bildirim çubuğunda Şimdi Senkronize Et'i (Şekil 2'de gösterildiği gibi) veya menü çubuğundan Projeyi Senkronize Et'i tıklayın. Android Studio, yapılandırmanızda herhangi bir hata bulursa (ör. kaynak kodunuz yalnızca
compileSdkVersion
sürümünden daha yüksek bir API düzeyinde kullanılabilen API özelliklerini kullanıyorsa) Messages (Mesajlar) penceresinde sorun açıklanır.

Kaynak grupları
Android Studio, her modülün kaynak kodunu ve kaynaklarını mantıksal olarak kaynak kümeleri halinde gruplandırır. Yeni bir modül oluşturduğunuzda Android Studio, modül içinde bir main/
kaynak grubu oluşturur. Bir modülün main/
kaynak kümesi, tüm derleme varyantları tarafından kullanılan kod ve kaynakları içerir.
Ek kaynak grubu dizinleri isteğe bağlıdır ve Android Studio, yeni derleme varyantları yapılandırdığınızda bunları sizin için otomatik olarak oluşturmaz. Ancak main/
gibi kaynak kümeleri oluşturmak, Gradle'ın yalnızca uygulamanızın belirli sürümlerini oluştururken kullanması gereken dosyaları ve kaynakları düzenlemeye yardımcı olur:
-
src/main/
- Bu kaynak grubu, tüm derleme varyantlarında ortak olan kod ve kaynakları içerir.
-
src/buildType/
- Bu kaynak kümesini yalnızca belirli bir derleme türüne ait kod ve kaynakları içerecek şekilde oluşturun.
-
src/productFlavor/
-
Bu kaynak grubunu yalnızca belirli bir ürün aroması için kod ve kaynak içerecek şekilde oluşturun.
Not: Derlemenizi birden fazla ürün çeşidini birleştirecek şekilde yapılandırırsanız çeşit boyutları arasındaki her bir ürün çeşidi kombinasyonu için kaynak grubu dizinleri oluşturabilirsiniz:
src/productFlavor1ProductFlavor2/
. -
src/productFlavorBuildType/
- Bu kaynak grubunu yalnızca belirli bir derleme varyantına ait kod ve kaynakları içerecek şekilde oluşturun.
Örneğin, uygulamanızın "fullDebug" sürümünü oluşturmak için derleme sistemi, aşağıdaki kaynak kümelerindeki kodu, ayarları ve kaynakları birleştirir:
-
src/fullDebug/
(derleme varyantı kaynak grubu) -
src/debug/
(derleme türü kaynak grubu) -
src/full/
(ürün aroması kaynak grubu) -
src/main/
(ana kaynak kümesi)
Not: Android Studio'da yeni bir dosya veya dizin oluştururken Dosya > Yeni menü seçeneklerini kullanarak belirli bir kaynak grubu için oluşturun. Seçebileceğiniz kaynak kümeleri, derleme yapılandırmalarınıza bağlıdır ve Android Studio, gerekli dizinler mevcut değilse bunları otomatik olarak oluşturur.
Farklı kaynak kümeleri aynı dosyanın farklı sürümlerini içeriyorsa Gradle, hangi dosyanın kullanılacağına karar verirken aşağıdaki öncelik sırasını kullanır. Sol taraftaki kaynak kümeler, sağ taraftaki kaynak kümelerin dosyalarını ve ayarlarını geçersiz kılar:
build variant > build type > product flavor > main source set > library dependencies
Bu sayede Gradle, uygulamanızın diğer sürümlerinde ortak olan etkinlikleri, uygulama mantığını ve kaynakları yeniden kullanırken oluşturmaya çalıştığınız derleme varyantına özgü dosyaları kullanabilir.
Gradle, birden fazla manifesti birleştirirken aynı öncelik sırasını kullanır. Böylece her derleme varyantı, son manifestte farklı bileşenler veya izinler tanımlayabilir. Özel kaynak kümeleri oluşturma hakkında daha fazla bilgi edinmek için Kaynak kümeleri oluşturma başlıklı makaleyi inceleyin.
Sürüm katalogları
Derlemeniz ortak bağımlılıkları olan birden fazla modül içeriyorsa veya ortak bağımlılıkları olan birden fazla bağımsız projeniz varsa ortak sürümleri belirtmek için sürüm kataloğu veya malzeme listesi (BOM) kullanmanızı öneririz.
Diğer derleme sistemleri
Bazel ile Android uygulamaları oluşturmak mümkündür ancak resmi olarak desteklenmez. Android Studio, Bazel projelerini resmi olarak desteklemez.
Bazel ile derleme yapmanın mevcut sınırlamalarını daha iyi anlamak için bilinen sorunlar bölümüne bakın.