Android studio: novo projeto vs novo módulo

141

O Android Studio usa o conceito de modules, enquanto outros IDEs como o Eclipse usam projects. No entanto, o Filemenu AS tem a opção de criar um New Modulee um new Project.

Quais são as diferenças entre esses dois, se houver?

Qual é recomendado usar?

Paschalis
fonte

Respostas:

102

Na documentação (o Android Studio é baseado no Intellij IDEA):

Tudo o que você faz no IntelliJ IDEA, você faz isso no contexto de um projeto. Um projeto é uma unidade organizacional que representa uma solução completa de software.

Seu produto final pode ser decomposto em uma série de módulos isolados e discretos, mas é uma definição de projeto que os reúne e os une a um todo maior.

Para Android, significa um projeto por aplicativo e um módulo por biblioteca e por aplicativo de teste.

Existem vários problemas se você tentar criar vários aplicativos no mesmo projeto. É possível, mas se você tentar (como eu fiz), verá que quase tudo foi projetado para funcionar com um único aplicativo por projeto.

Por exemplo, existe uma opção para "reconstruir o projeto", o que não faz sentido em vários aplicativos, muitas outras configurações do projeto seriam inúteis e o sistema VCS embutido não é ótimo quando você tem vários repositórios.

Dalmas
fonte
1
"Significa um projeto por aplicativo, e um módulo por biblioteca e por aplicativo de teste" ... O que isso significa? Se um "aplicativo de teste" for um aplicativo, haverá apenas dois módulos por projeto, um para um aplicativo (regular ou aplicativo de teste) e outro para uma biblioteca.
Larsh
2
@LarsH, eu a reformularia como: "um projeto por aplicativo principal"
Nico
4
Esta não é a resposta. resposta incorreta
metis
169

Resposta do KISS:

módulo no Android Studio é como um projeto no Eclipse

projeto no Android Studio é como uma área de trabalho no Eclipse

Oded Breiner
fonte
8
Eu mesmo tenho lutado com esse problema e, embora esse pareça ser o caso conceitual, estou confuso. Quando crio um novo 'Projeto' no Android Studio, recebo um assistente que me pergunta sobre temas como Tema, uso do ActionBar, Grid Layout e outros. Eu teria pensado que essas coisas seriam deixadas para o módulo. Se essas perguntas são apenas para que as bibliotecas de suporte apropriadas sejam adicionadas ao 'Projeto', então eu entendo, mas também vejo as mesmas coisas ao criar um novo módulo. Bastante confuso.
Scott Naef 01/01
2
Você tem razão, mas a resposta aceita apenas observa os problemas ao tentar trabalhar com o android studio como se fosse um eclipse. A maioria das pessoas que procuram essa pergunta só precisa saber qual é a analogia.
Oded Breiner
Criar um novo projeto no Android não se parece mais com um aplicativo com manifest / res / e src - ao contrário de um "espaço de trabalho". Ao criar um módulo, dois dos tipos oferecidos são 1) módulo de aplicativo e 2) módulo de biblioteca do Android. O número 1 parece redundante para "novo projeto" e os números 1 e 2 parecem iguais.
User1679130
oO é realmente um módulo ?!
Martin Pfeffer
1
@MartinPfeffer - não, mas essa é a analogia mais próxima, leia mais aqui: jetbrains.org/intellij/sdk/docs/basics/project_structure.html
Oded Breiner
35

Um projeto no Android Studio representa um aplicativo Android completo. Os projetos do Android Studio consistem em um ou mais módulos .

Um módulo é um componente do seu aplicativo que você pode criar, testar ou depurar independentemente.

Os módulos contêm o código-fonte e os recursos do seu aplicativo.

Chulo
fonte
10

Dos documentos atualizados [2019]:

Os módulos fornecem um contêiner para o código-fonte, os arquivos de recursos e as configurações no nível do aplicativo, como o arquivo de construção no nível do módulo e o arquivo de manifesto do Android. Cada módulo pode ser construído, testado e depurado independentemente.

O Android Studio usa módulos para facilitar a adição de novos dispositivos ao seu projeto. Seguindo algumas etapas simples no Android Studio, você pode criar um módulo para conter o código específico de um tipo de dispositivo, como Wear OS ou Android TV. O Android Studio cria automaticamente diretórios de módulos, como diretórios de origem e de recursos, e um arquivo build.gradle padrão apropriado para o tipo de dispositivo. Além disso, o Android Studio cria módulos de dispositivo com configurações de compilação recomendadas, como o uso da biblioteca Leanback para módulos de TV Android.

Ex:

  • Módulo de telefone e tablet
  • Módulo Android Wear
  • Módulo de TV Android
  • Módulo de vidro

Além destes, você também pode ter um "módulo de biblioteca local". Por exemplo, você desenvolve uma Estrutura de gerenciamento de contas como um módulo de biblioteca para ser usado no seu aplicativo, você pode fazê-lo como um módulo separado no mesmo projeto. Para incluir isso no seu aplicativo, você teria que escrever algo como,

compile project(':mylibrary')

Os médicos dizem,

Isso declara uma dependência de um módulo de biblioteca do Android chamado "mylibrary" (esse nome deve corresponder ao nome da biblioteca definido como uma inclusão no seu arquivo settings.gradle). Ele requer que o sistema de compilação compile o módulo da biblioteca com o módulo do aplicativo e inclua o arquivo AAR resultante no APK.

Por fim, o Intellij menciona mais alguns detalhes sobre os arquivos de configuração do módulo:

As informações de configuração de um módulo são armazenadas em um arquivo .iml arquivo de módulo . Por padrão, esse arquivo está localizado na pasta raiz do conteúdo do módulo.

As equipes de desenvolvimento, normalmente, compartilham os .imlarquivos do módulo através do controle de versão.

Este .imlarquivo é um pouco assustador de se ver. Aqui está um exemplo do meu projeto:

<?xml version="1.0" encoding="UTF-8"?>
<module external.linked.project.id=":app" external.linked.project.path="$MODULE_DIR$" external.root.project.path="$MODULE_DIR$/.." external.system.id="GRADLE" external.system.module.group="LearnCity" external.system.module.version="unspecified" type="JAVA_MODULE" version="4">
  <component name="FacetManager">
    <facet type="android-gradle" name="Android-Gradle">
      <configuration>
        <option name="GRADLE_PROJECT_PATH" value=":app" />
      </configuration>
    </facet>
    <facet type="android" name="Android">
      <configuration>
        <option name="SELECTED_BUILD_VARIANT" value="debug" />
        <option name="ASSEMBLE_TASK_NAME" value="assembleDebug" />
        <option name="COMPILE_JAVA_TASK_NAME" value="compileDebugSources" />
        <afterSyncTasks>
          <task>generateDebugSources</task>
        </afterSyncTasks>
        <option name="ALLOW_USER_CONFIGURATION" value="false" />
        <option name="MANIFEST_FILE_RELATIVE_PATH" value="/src/main/AndroidManifest.xml" />
        <option name="RES_FOLDER_RELATIVE_PATH" value="/src/main/res/layouts/common/layout/ver3/layout" />
        <option name="RES_FOLDERS_RELATIVE_PATH" value="file://$MODULE_DIR$/src/main/res/layouts/common/layout/ver3/layout;file://$MODULE_DIR$/src/main/res/layouts/common/layout/ver3;file://$MODULE_DIR$/src/main/res/layouts/common/layout/ver2/layout;file://$MODULE_DIR$/src/main/res/layouts/common/layout/ver2;file://$MODULE_DIR$/src/main/res/layouts/common/layout/ver1/layout;file://$MODULE_DIR$/src/main/res/layouts/common/layout/ver1;file://$MODULE_DIR$/src/main/res/layouts/common/layout/ver0/layout;file://$MODULE_DIR$/src/main/res/layouts/common/layout/ver0;file://$MODULE_DIR$/src/main/res/layouts/common/layout;file://$MODULE_DIR$/src/main/res/layouts/learner/layout;file://$MODULE_DIR$/src/main/res/layouts/tutor/layout;file://$MODULE_DIR$/src/main/res/layouts/obsolete/layout;file://$MODULE_DIR$/src/main/res/layouts/common;file://$MODULE_DIR$/src/main/res/layouts/learner;file://$MODULE_DIR$/src/main/res/layouts/tutor;file://$MODULE_DIR$/src/main/res/layouts/obsolete;file://$MODULE_DIR$/src/main/res/layouts;file://$MODULE_DIR$/src/main/res;file://$MODULE_DIR$/src/debug/res" />
        <option name="ASSETS_FOLDER_RELATIVE_PATH" value="/src/main/assets" />
      </configuration>
    </facet>
  </component>
  <component name="NewModuleRootManager" LANGUAGE_LEVEL="JDK_1_7" inherit-compiler-output="false">
    <output url="file://$MODULE_DIR$/build/intermediates/classes/debug" />
    <output-test url="file://$MODULE_DIR$/build/intermediates/classes/test/debug" />
    <exclude-output />
    <content url="file://$MODULE_DIR$">
      <sourceFolder url="file://$MODULE_DIR$/build/generated/source/r/debug" isTestSource="false" generated="true" />
      <sourceFolder url="file://$MODULE_DIR$/build/generated/source/aidl/debug" isTestSource="false" generated="true" />
      <sourceFolder url="file://$MODULE_DIR$/build/generated/source/buildConfig/debug" isTestSource="false" generated="true" />
      <sourceFolder url="file://$MODULE_DIR$/build/generated/source/rs/debug" isTestSource="false" generated="true" />
      <sourceFolder url="file://$MODULE_DIR$/build/generated/source/apt/debug" isTestSource="false" generated="true" />
      <sourceFolder url="file://$MODULE_DIR$/build/generated/res/google-services/debug" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/build/generated/res/rs/debug" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/build/generated/res/resValues/debug" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/build/generated/source/r/androidTest/debug" isTestSource="true" generated="true" />
      <sourceFolder url="file://$MODULE_DIR$/build/generated/source/aidl/androidTest/debug" isTestSource="true" generated="true" />
      <sourceFolder url="file://$MODULE_DIR$/build/generated/source/buildConfig/androidTest/debug" isTestSource="true" generated="true" />
      <sourceFolder url="file://$MODULE_DIR$/build/generated/source/rs/androidTest/debug" isTestSource="true" generated="true" />
      <sourceFolder url="file://$MODULE_DIR$/build/generated/source/apt/androidTest/debug" isTestSource="true" generated="true" />
      <sourceFolder url="file://$MODULE_DIR$/build/generated/res/rs/androidTest/debug" type="java-test-resource" />
      <sourceFolder url="file://$MODULE_DIR$/build/generated/res/resValues/androidTest/debug" type="java-test-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/debug/res" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/debug/resources" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/debug/assets" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/debug/aidl" isTestSource="false" />
      <sourceFolder url="file://$MODULE_DIR$/src/debug/java" isTestSource="false" />
      <sourceFolder url="file://$MODULE_DIR$/src/debug/rs" isTestSource="false" />
      <sourceFolder url="file://$MODULE_DIR$/src/debug/shaders" isTestSource="false" />
      <sourceFolder url="file://$MODULE_DIR$/src/testDebug/res" type="java-test-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/testDebug/resources" type="java-test-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/testDebug/assets" type="java-test-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/testDebug/aidl" isTestSource="true" />
      <sourceFolder url="file://$MODULE_DIR$/src/testDebug/java" isTestSource="true" />
      <sourceFolder url="file://$MODULE_DIR$/src/testDebug/rs" isTestSource="true" />
      <sourceFolder url="file://$MODULE_DIR$/src/testDebug/shaders" isTestSource="true" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/res/layouts/common/layout/ver3/layout" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/res/layouts/common/layout/ver3" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/res/layouts/common/layout/ver2/layout" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/res/layouts/common/layout/ver2" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/res/layouts/common/layout/ver1/layout" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/res/layouts/common/layout/ver1" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/res/layouts/common/layout/ver0/layout" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/res/layouts/common/layout/ver0" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/res/layouts/common/layout" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/res/layouts/learner/layout" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/res/layouts/tutor/layout" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/res/layouts/obsolete/layout" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/res/layouts/common" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/res/layouts/learner" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/res/layouts/tutor" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/res/layouts/obsolete" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/res/layouts" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/res" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/resources" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/assets" type="java-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/aidl" isTestSource="false" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/java" isTestSource="false" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/rs" isTestSource="false" />
      <sourceFolder url="file://$MODULE_DIR$/src/main/shaders" isTestSource="false" />
      <sourceFolder url="file://$MODULE_DIR$/src/androidTest/res" type="java-test-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/androidTest/resources" type="java-test-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/androidTest/assets" type="java-test-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/androidTest/aidl" isTestSource="true" />
      <sourceFolder url="file://$MODULE_DIR$/src/androidTest/java" isTestSource="true" />
      <sourceFolder url="file://$MODULE_DIR$/src/androidTest/rs" isTestSource="true" />
      <sourceFolder url="file://$MODULE_DIR$/src/androidTest/shaders" isTestSource="true" />
      <sourceFolder url="file://$MODULE_DIR$/src/test/res" type="java-test-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/test/resources" type="java-test-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/test/assets" type="java-test-resource" />
      <sourceFolder url="file://$MODULE_DIR$/src/test/aidl" isTestSource="true" />
      <sourceFolder url="file://$MODULE_DIR$/src/test/java" isTestSource="true" />
      <sourceFolder url="file://$MODULE_DIR$/src/test/rs" isTestSource="true" />
      <sourceFolder url="file://$MODULE_DIR$/src/test/shaders" isTestSource="true" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/assets" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/blame" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/builds" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/classes" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/incremental" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/incremental-classes" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/incremental-runtime-classes" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/incremental-safeguard" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/incremental-verifier" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/instant-run-resources" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/instant-run-support" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/jniLibs" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/manifests" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/multi-dex" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/pre-dexed" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/reload-dex" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/res" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/restart-dex" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/rs" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/shaders" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/split-apk" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/symbols" />
      <excludeFolder url="file://$MODULE_DIR$/build/intermediates/transforms" />
      <excludeFolder url="file://$MODULE_DIR$/build/outputs" />
      <excludeFolder url="file://$MODULE_DIR$/build/tmp" />
    </content>
    <orderEntry type="jdk" jdkName="Android API 25 Platform" jdkType="Android SDK" />
    <orderEntry type="sourceFolder" forTests="false" />
    <orderEntry type="library" exported="" name="google-http-client-android-1.22.0" level="project" />
    <orderEntry type="library" exported="" name="firebase-analytics-10.2.0" level="project" />
    <orderEntry type="library" exported="" name="firebase-core-10.2.0" level="project" />
    <orderEntry type="library" exported="" name="play-services-auth-base-10.2.0" level="project" />
    <orderEntry type="library" exported="" name="gson-2.8.0" level="project" />
    <orderEntry type="library" exported="" name="play-services-tasks-10.2.0" level="project" />
    <orderEntry type="library" exported="" name="constraint-layout-1.0.2" level="project" />
    <orderEntry type="library" exported="" name="appengine-api-1.0-sdk-1.9.50" level="project" />
    <orderEntry type="library" exported="" name="design-25.3.0" level="project" />
    <orderEntry type="library" exported="" name="android-job-1.1.8" level="project" />
    <orderEntry type="library" exported="" name="transition-25.3.0" level="project" />
    <orderEntry type="library" exported="" name="play-services-base-10.2.0" level="project" />
    <orderEntry type="library" exported="" name="multispinner-0.1.1" level="project" />
    <orderEntry type="library" exported="" name="play-services-auth-10.2.0" level="project" />
    <orderEntry type="library" exported="" name="support-core-ui-25.3.0" level="project" />
    <orderEntry type="library" exported="" name="simpleratingbar-0.1.5" level="project" />
    <orderEntry type="library" exported="" name="play-services-maps-10.2.0" level="project" />
    <orderEntry type="library" exported="" name="play-services-location-10.2.0" level="project" />
    <orderEntry type="library" exported="" name="firebase-iid-10.2.0" level="project" />
    <orderEntry type="library" exported="" name="support-core-utils-25.3.0" level="project" />
    <orderEntry type="library" exported="" name="jsr305-2.0.1" level="project" />
    <orderEntry type="library" exported="" name="support-fragment-25.3.0" level="project" />
    <orderEntry type="library" exported="" scope="TEST" name="multidex-instrumentation-1.0.1" level="project" />
    <orderEntry type="library" exported="" name="constraint-layout-solver-1.0.2" level="project" />
    <orderEntry type="library" exported="" name="androidannotations-api-3.2" level="project" />
    <orderEntry type="library" exported="" name="java-uuid-generator-3.1.4" level="project" />
    <orderEntry type="library" exported="" name="google-http-client-1.22.0" level="project" />
    <orderEntry type="library" exported="" name="firebase-messaging-10.2.0" level="project" />
    <orderEntry type="library" exported="" name="firebase-analytics-impl-10.2.0" level="project" />
    <orderEntry type="library" exported="" name="firebase-common-10.2.0" level="project" />
    <orderEntry type="library" exported="" name="eventbus-3.0.0" level="project" />
    <orderEntry type="library" exported="" name="cat-1.0.5" level="project" />
    <orderEntry type="library" exported="" name="play-services-basement-10.2.0" level="project" />
    <orderEntry type="library" exported="" name="support-compat-25.3.0" level="project" />
    <orderEntry type="library" exported="" name="support-v4-25.3.0" level="project" />
    <orderEntry type="library" exported="" name="multidex-1.0.1" level="project" />
    <orderEntry type="library" exported="" scope="TEST" name="hamcrest-core-1.3" level="project" />
    <orderEntry type="library" exported="" name="support-media-compat-25.3.0" level="project" />
    <orderEntry type="library" exported="" scope="TEST" name="junit-4.12" level="project" />
    <orderEntry type="library" exported="" name="recyclerview-v7-25.3.0" level="project" />
    <orderEntry type="library" exported="" name="appcompat-v7-25.3.0" level="project" />
    <orderEntry type="library" exported="" name="animated-vector-drawable-25.3.0" level="project" />
    <orderEntry type="library" exported="" name="support-annotations-25.3.0" level="project" />
    <orderEntry type="library" exported="" name="support-vector-drawable-25.3.0" level="project" />
    <orderEntry type="module" module-name="backend" exported="" />
    <orderEntry type="library" exported="" name="android-android-25" level="project" />
  </component>
</module>
Manish Kumar Sharma
fonte
Enquanto a resposta aceita era imediata, o tempo e a tendência do Google de mudar como o vento a tornaram obsoleta (ouso dizer @Deprecated?). Isso faz muito mais sentido.
22730 Scott Biggs #
1

O IntelliJ IDEA cria um projeto para toda a base de código com a qual você trabalha e um módulo para cada um de seus componentes individuais. Portanto, o módulo IntelliJ IDEA é mais como um projeto Eclipse, e o projeto é aproximadamente semelhante ao espaço de trabalho do Eclipse. Não existe um equivalente exato ao espaço de trabalho do Eclipse que contém todo o seu trabalho, mas você pode abrir vários projetos em vários quadros ao mesmo tempo.

Aqui está a página de perguntas e respostas do IntelliJ IDEA para usuários do Eclipse -

http://www.jetbrains.com/idea/documentation/migration_faq.html

Pramod
fonte
1

Os módulos são como apkLibs, ou seja, tem seus próprios res, manifestos, testes etc., mas o aplicativo principal geralmente usa vários apklibs / módulos para ajudar a reunir tudo em uma solução

Jonathan
fonte
-5

Referindo-me à resposta do @Oded Breiner, eu diria que:

módulo no Android Studio é como um projeto no Eclipse

projeto no Android Studio é como um conjunto de trabalho no Eclipse

Feio
fonte
1
Na verdade não. Os "conjuntos de trabalho" do IMHO no Eclipse são apenas "filtros" para o espaço de trabalho atual. Você não pode ter dois espaços de trabalho no Eclipse, nem dois projetos abertos na mesma instância do Android Studio (na verdade, quando você abre outro projeto, é necessário substituir o primeiro ou abrir o último no uma nova janela)
ocramot 30/04
1
Você pode sugerir editar, referindo a resposta original com pequenas alterações!
kokabi