Derlemenizi yapılandırma

Android derleme sistemi, uygulama kaynakları ile kaynak kodunu derleyip bunları test edebileceğiniz, dağıtabileceğiniz, imzalayabileceğiniz ve dağıtabileceğiniz APK'lar veya Android App Bundle'lar halinde paketler.

Android Studio, derleme sürecini otomatikleştirmek ve yönetmek için gelişmiş bir derleme araç seti olan Gradle'ı kullanır. Aynı zamanda, esnek ve özel derleme yapılandırmaları tanımlamanıza olanak tanır. Her derleme yapılandırması, uygulamanızın tüm sürümlerinde ortak olan bölümleri yeniden kullanırken kendi kod ve kaynak grubunu tanımlayabilir. Android Gradle eklentisi, Android uygulamalarını derleme ve test etmeye özel işlemler ve yapılandırılabilir ayarlar sağlamak için derleme araç setiyle birlikte çalışır.

Gradle ve Android Gradle eklentisi, Android Studio'dan bağımsız olarak çalışır. Yani Android uygulamalarınızı Android Studio'dan, makinenizdeki komut satırından veya sürekli entegrasyon sunucuları gibi Android Studio'nun yüklü olmadığı makinelerde derleyebilirsiniz.

Android Studio kullanmıyorsanız uygulamanızı komut satırından nasıl oluşturacağınızı ve çalıştıracağınızı öğrenebilirsiniz. Komut satırından, uzak bir makinede veya Android Studio'yu kullanarak oluşturduğunuz projelerin çıktısı aynıdır.

Not: Gradle ve Android Gradle eklentisi Android Studio'dan bağımsız olarak çalıştığı için derleme araçlarını ayrı olarak güncellemeniz gerekir. Gradle ve Android Gradle eklentisini nasıl güncelleyeceğinizi öğrenmek için sürüm notlarını okuyun.

Android derleme sisteminin esnekliği, uygulamanızın temel kaynak dosyalarını değiştirmeden özel derleme yapılandırmaları oluşturmanıza olanak tanır. Bu sayfa, Android derleme sisteminin nasıl çalıştığını ve birden fazla derleme yapılandırmasını özelleştirmenize ve otomatikleştirmenize nasıl yardımcı olabileceğini anlamanıza yardımcı olur. Uygulamanızı dağıtma hakkında daha fazla bilgi edinmek istiyorsanız Uygulamanızı oluşturma ve çalıştırma başlıklı makaleyi inceleyin. Android Studio'yu kullanarak hemen özel derleme yapılandırmaları oluşturmaya başlamak için Derleme varyantlarını yapılandırma bölümüne bakın.

Derleme işlemi

Derleme sürecinde, projenizi Android Uygulama Paketi (APK) veya Android App Bundle'a (AAB) dönüştüren birçok araç ve işlem yer alır.

Android Gradle eklentisi, derleme işleminin büyük kısmını sizin için gerçekleştirir, ancak derleme işleminin belirli yönlerini anlamak faydalı olabilir. Böylece, derlemeyi gereksinimlerinizi karşılayacak şekilde ayarlayabilirsiniz.

Farklı projelerin farklı derleme hedefleri olabilir. Örneğin, üçüncü taraf bir kitaplığın derlemesi Android Arşivi (AAR) veya Java Arşivi (JAR) kitaplıkları üretir. Bununla birlikte, en yaygın proje türü uygulamadır. Bir uygulama projesinin derlemesi, uygulamanızın hata ayıklamasını oluşturur veya uygulamanızın APK ya da AAB'sini oluşturur. Bunları harici kullanıcılara dağıtabilir, test edebilir veya yayınlayabilirsiniz.

Bu sayfa uygulama geliştirmeye odaklanmaktadır, ancak derleme adımlarının ve kavramlarının çoğu çoğu derleme türünde ortaktır.

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ı derleyip paketlerken kullandığı belirli özellikleri tanımlar. Derleme türleri genellikle geliştirme yaşam döngünüzün farklı aşamalarına göre 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 dağıtım için uygulamanızı bir sürüm anahtarıyla küçültebilir, gizleyebilir ve imzalayabilir.

Uygulamanızı derlemek için en az bir derleme türü tanımlamanız gerekir. Android Studio, varsayılan olarak hata ayıklama ve sürüm derleme türlerini 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 aromaları
Ürün çeşitleri, uygulamanızın kullanıcılara yayınlayabileceğiniz ücretsiz ve ücretli sürümleri gibi farklı sürümlerini temsil eder. Uygulamanızın tüm sürümlerinde ortak olan bölümleri paylaşıp yeniden kullanırken ürün çeşitlerini farklı kod ve kaynaklar kullanacak şekilde özelleştirebilirsiniz. Ürün çeşitleri isteğe bağlıdır ve manuel olarak oluşturmanız gerekir. Uygulamanızın farklı sürümlerini oluşturmaya başlamak için ürün aromalarını yapılandırmayı öğrenin.
Varyant oluşturma
Derleme varyantı, derleme türü ve ürün çeşidinin çapraz ürünleridir. Gradle'ın uygulamanızı oluşturmak için kullandığı yapılandırmadır. Derleme varyantlarını kullanarak, ürün çeşitlerinizin hata ayıklama sürümünü geliştirme sırasında oluşturabilir ve ürün çeşitlerinizin imzalı sürüm sürümlerini dağıtabilirsiniz. Derleme varyantlarını 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şturduğunuzda ek derleme varyantları da oluşturulur. Derleme varyantları oluşturmayı ve yönetmeyi öğrenmek için Derleme varyantlarını yapılandırma genel bakışını okuyun.
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ı bir uygulama adına, minimum SDK sürümüne veya hedef SDK sürümüne sahip birden fazla varyantını oluşturmak istiyorsanız yararlı olur. Birden fazla manifest varsa manifest birleştirme aracı, manifest ayarlarını birleştirir.
Bağımlılıklar
Derleme sistemi, proje bağımlılıklarını yerel dosya sisteminizden ve uzak depolardan 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 edinmek için Derleme bağımlılıkları ekleme bölümüne bakın.
İ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 sürüm sürümünü imzalamaz. Sürüm anahtarınız yoksa Uygulamanızı imzalama bölümünde açıklandığı gibi bir tane oluşturabilirsiniz. İmzalı sürüm derlemeleri, uygulamaların çoğu uygulama mağazası üzerinden dağıtılması için gereklidir.
Kod ve kaynak küçültme
Derleme sistemi, her derleme varyantı için farklı bir ProGuard kural dosyası belirtebilmenizi sağlar. Derleme sistemi, uygulamanızı derlerken R8 gibi yerleşik küçültme araçlarını kullanarak kodunuzu ve kaynaklarınızı küçültmek için uygun kural kümesini uygular. Kodunuzu ve kaynaklarınızı küçültmek, APK veya AAB boyutunu küçültmenize yardımcı olabilir.
Birden fazla APK desteği
Derleme sistemi, her biri yalnızca belirli bir ekran yoğunluğu veya Uygulama İkili Arabirimi (ABI) için gereken kod ve kaynakları içeren farklı APK'ları otomatik olarak oluşturmanıza olanak tanır. Daha fazla bilgi için Birden çok APK oluşturma bölümüne bakın. Bununla birlikte, tek bir AAB yayınlamak önerilen yaklaşımdır. Çünkü bu yöntem, ekran yoğunluğunun ve ABI'nin yanı sıra dile göre bölme olanağı sunar ve Google Play'e birden fazla yapı yükleme ihtiyacını ortadan kaldırır. Ağustos 2021'den sonra gönderilen tüm yeni uygulamaların AAB kullanması gerekir.

Android derlemelerindeki Java sürümleri

Kaynak kodunuzun Java, Kotlin veya her ikisinde birden yazılmış olmasına bakılmaksızın derlemeniz için JDK veya Java dili sürümü seçmeniz gereken birkaç yer vardır. Ayrıntılar için Android derlemelerindeki Java sürümleri konusuna bakın.

Yapılandırma dosyaları oluşturun

Ö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 diline özgü Kotlin komut dosyası ile derleme mantığını tanımlamak ve değiştirmek için Alana Özgü 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 kullanıma sunduğundan derlemenizi yapılandırmaya başlamak için Kotlin komut dosyasını veya Groovy'yi bilmeniz gerekmez. Android Gradle eklentisi DSL hakkında daha fazla bilgi edinmek için DSL referans belgelerini okuyun. Kotlin komut dosyası, temeldeki Gradle Kotlin DSL'sini de kullanır.

Yeni bir projeye başlarken Android Studio, bu dosyalardan bazılarını sizin için otomatik olarak oluşturur ve makul varsayılanlara göre doldurur. Proje dosya yapısı aşağıdaki düzene sahiptir:

└── MyApp/  # Project
    ├── gradle/
    │   └── wrapper/
    │       └── gradle-wrapper.properties
    ├── build.gradle(.kts)
    ├── settings.gradle(.kts)
    └── app/  # Module
        ├── build.gradle(.kts)
        └── build/
            ├── libs/
            └── src/
                └── main/  # Source set
                    ├── java/
                    │   └── com.example.myapp
                    ├── res/
                    │   ├── drawable/
                    │   ├── values/
                    │   └── ...
                    └── AndroidManifest.xml

Android uygulamalarının standart proje yapısının parçası olan birkaç Gradle derleme yapılandırma dosyası vardır. Derlemenizi yapılandırmaya başlamadan önce bu dosyaların her birinin kapsamını, amacını ve tanımladıkları temel DSL öğelerini anlamanız önemlidir.

Gradle Wrapper dosyası

Gradle sarmalayıcı (gradlew), Gradle'ı indirip başlatan ve kaynak kodunuzla birlikte sunulan küçük bir uygulamadır. Bu, daha tutarlı bir derleme yürütme işlemi oluşturur. Geliştiriciler uygulama kaynağını indirir ve gradlew uygulamasını çalıştırır. Bu işlem, gerekli Gradle dağıtımını indirir ve uygulamanızı derlemek 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 distributionUrl özelliğini 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 yer alır. Bu ayar dosyası, proje düzeyindeki depo ayarlarını tanımlar ve Gradle'a uygulamanızı derlerken hangi modülleri dahil etmesi gerektiğini bildirir. Çok modüllü projelerin, son derlemeye geçmesi gereken her bir modülü belirtmesi gerekir.

Çoğu projede 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. The code below
      * defines 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")

Modern

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. The code below
      * defines 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ı

Ü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 yaygın sürümlerini tanımlar.

Aşağıdaki kod örneğinde, yeni proje oluşturulduktan 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.2.0" apply false
    id("com.android.library") version "8.2.0" apply false
    id("org.jetbrains.kotlin.android") version "1.9.20" apply false
}

Modern

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.2.0' apply false
    id 'com.android.library' version '8.2.0' apply false
    id 'org.jetbrains.kotlin.android' version '1.9.20' apply false
}