Recurso usado para operações que são executadas em segundo plano. Não oferece interface gráfica para interação com o usuário. Geralmente são indicadas para operações longas. Um exemplo clássico de uso: uma música sendo reproduzida mesmo quando você está usando outro aplicativo.
A figura 1 mostra o ciclo de vida do service

-
Referência da figura 1: GOOGLE DEVELOPERS. Visão geral dos serviços. Disponível em: https://developer.android.com/guide/components/services. Acesso: 28 ago. 2025.
Exemplo 01 (music service):
-
No arquivo AndroidManifest.xml acrescente as tags: <uses-permission android:name="android.permission.FOREGROUND_SERVICE"/> <uses-permission android:name="android.permission.FOREGROUND_SERVICE_MEDIA_PLAYBACK"/> <uses-permission android:name="android.permission.POST_NOTIFICATIONS"/>
<service android:name=".MusicService" android:exported="false" android:enabled="true" android:foregroundServiceType="mediaPlayback"/> -
NotificationHelper.java
import android.app.Notification; import android.app.NotificationChannel; import android.app.NotificationManager; import android.content.Context; import androidx.core.app.NotificationCompat; public class NotificationHelper { private static final String CHANNEL_ID = "music_channel"; public static Notification createNotification(Context context) { NotificationManager manager = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE); if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.O) { NotificationChannel channel = new NotificationChannel( CHANNEL_ID, "Music Service", NotificationManager.IMPORTANCE_LOW ); manager.createNotificationChannel(channel); } return new NotificationCompat.Builder(context, CHANNEL_ID) .setContentTitle("Reproduzindo música") .setContentText("A música está tocando em segundo plano") .setSmallIcon(android.R.drawable.ic_media_play) .setOngoing(true) .build(); } } -
MusicService.java
import android.app.Notification; import android.app.Service; import android.content.Intent; import android.media.MediaPlayer; import android.os.Build; import android.os.IBinder; import android.util.Log; import androidx.annotation.Nullable; public class MusicService extends Service { private MediaPlayer mediaPlayer; private final String TAG = MusicService.class.getName(); @Override public void onCreate() { super.onCreate(); mediaPlayer = MediaPlayer.create(this, R.raw.musica); mediaPlayer.setLooping(true); } @Override public int onStartCommand(Intent intent, int flags, int startId) { Notification notification = NotificationHelper.createNotification(this); startForeground(1, notification); if (!mediaPlayer.isPlaying()) { mediaPlayer.start(); } return START_STICKY; } @Override public void onDestroy() { super.onDestroy(); Log.d(TAG, "onDestroy chamado - parando música"); if (mediaPlayer != null) { if (mediaPlayer.isPlaying()) { mediaPlayer.stop(); } mediaPlayer.reset(); mediaPlayer.release(); mediaPlayer = null; Log.d(TAG, "MediaPlayer liberado"); } if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.UPSIDE_DOWN_CAKE) { stopForeground(STOP_FOREGROUND_REMOVE); } else { stopForeground(true); } } @Nullable @Override public IBinder onBind(Intent intent) { return null; } } -
activity_main.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:gravity="center" android:layout_width="match_parent" android:layout_height="match_parent" android:padding="24dp"> <Button android:id="@+id/btnStart" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Iniciar Música"/> <Button android:id="@+id/btnStop" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Parar Música" android:layout_marginTop="16dp"/> </LinearLayout> -
MainActivity.java
package com.example.musicaservice;
import android.content.Intent; import android.os.Bundle; import android.view.View; import android.widget.Button; import androidx.appcompat.app.AppCompatActivity; public class MainActivity extends AppCompatActivity { private Button btnStart, btnStop; private Intent intent; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); btnStart = findViewById(R.id.btnStart); btnStop = findViewById(R.id.btnStop); btnStart.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { intent = new Intent(MainActivity.this, MusicService.class); startService(intent); } }); btnStop.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { intent = new Intent(MainActivity.this, MusicService.class); stopService(intent); } }); } }
Por que não aparece a notificação??? E a música continua executando mesmo assim!!!
Tente fazer essas alterações na MainActivity.java
import android.Manifest;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.os.Build;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;
import androidx.core.content.ContextCompat;
public class MainActivity extends AppCompatActivity {
private static final int REQUEST_CODE_NOTIFICATIONS = 1001;
private Button btnStart, btnStop;
private Intent intent;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
btnStart = findViewById(R.id.btnStart);
btnStop = findViewById(R.id.btnStop);
btnStart.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (temPermissaoNotificacao()) {
iniciarServicoMusica();
} else {
solicitarPermissaoNotificacao();
}
}
});
btnStop.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (intent != null) {
stopService(intent);
Toast.makeText(MainActivity.this, "Serviço parado", Toast.LENGTH_SHORT).show();
}
}
});
}
private boolean temPermissaoNotificacao() {
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.TIRAMISU) {
return true;
}
return ContextCompat.checkSelfPermission(this, Manifest.permission.POST_NOTIFICATIONS)
== PackageManager.PERMISSION_GRANTED;
}
private void solicitarPermissaoNotificacao() {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU) {
if (ActivityCompat.shouldShowRequestPermissionRationale(this, Manifest.permission.POST_NOTIFICATIONS)) {
Toast.makeText(this, "Precisamos da permissão para mostrar a notificação da música", Toast.LENGTH_LONG).show();
}
ActivityCompat.requestPermissions(this,
new String[]{Manifest.permission.POST_NOTIFICATIONS},
REQUEST_CODE_NOTIFICATIONS);
}
}
private void iniciarServicoMusica() {
intent = new Intent(MainActivity.this, MusicService.class);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
startForegroundService(intent);
} else {
startService(intent);
}
Toast.makeText(this, "Música iniciada!", Toast.LENGTH_SHORT).show();
}
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions,
@NonNull int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
if (requestCode == REQUEST_CODE_NOTIFICATIONS) {
if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
Toast.makeText(this, "Permissão concedida! Iniciando música...", Toast.LENGTH_SHORT).show();
iniciarServicoMusica(); // Agora inicia o serviço
} else {
Toast.makeText(this, "Permissão negada. A notificação não aparecerá, mas a música pode tocar sem ela.", Toast.LENGTH_LONG).show();
}
}
}
}
