Langsung ke konten utama
Setiap sesi Claude Code dimulai dengan context window yang segar. Dua mekanisme membawa pengetahuan lintas sesi:
  • File CLAUDE.md: instruksi yang Anda tulis untuk memberikan Claude konteks persisten
  • Auto memory: catatan yang Claude tulis sendiri berdasarkan koreksi dan preferensi Anda
Halaman ini mencakup cara untuk:

CLAUDE.md vs auto memory

Claude Code memiliki dua sistem memori yang saling melengkapi. Keduanya dimuat di awal setiap percakapan. Claude memperlakukan mereka sebagai konteks, bukan konfigurasi yang diberlakukan. Semakin spesifik dan ringkas instruksi Anda, semakin konsisten Claude mengikutinya.
File CLAUDE.mdAuto memory
Siapa yang menulisnyaAndaClaude
Apa yang dikandungnyaInstruksi dan aturanPembelajaran dan pola
CakupanProyek, pengguna, atau organisasiPer working tree
Dimuat ke dalamSetiap sesiSetiap sesi (200 baris pertama)
Gunakan untukStandar pengkodean, alur kerja, arsitektur proyekPerintah build, wawasan debugging, preferensi yang Claude temukan
Gunakan file CLAUDE.md ketika Anda ingin memandu perilaku Claude. Auto memory memungkinkan Claude belajar dari koreksi Anda tanpa usaha manual. Subagents juga dapat mempertahankan auto memory mereka sendiri. Lihat konfigurasi subagent untuk detail.

File CLAUDE.md

File CLAUDE.md adalah file markdown yang memberikan Claude instruksi persisten untuk proyek, alur kerja pribadi Anda, atau seluruh organisasi Anda. Anda menulis file ini dalam teks biasa; Claude membacanya di awal setiap sesi.

Pilih di mana menempatkan file CLAUDE.md

File CLAUDE.md dapat berada di beberapa lokasi, masing-masing dengan cakupan yang berbeda. Lokasi yang lebih spesifik memiliki prioritas lebih tinggi daripada yang lebih luas.
CakupanLokasiTujuanContoh kasus penggunaanDibagikan dengan
Kebijakan terkelola• macOS: /Library/Application Support/ClaudeCode/CLAUDE.md
• Linux dan WSL: /etc/claude-code/CLAUDE.md
• Windows: C:\Program Files\ClaudeCode\CLAUDE.md
Instruksi di seluruh organisasi yang dikelola oleh IT/DevOpsStandar pengkodean perusahaan, kebijakan keamanan, persyaratan kepatuhanSemua pengguna dalam organisasi
Instruksi proyek./CLAUDE.md atau ./.claude/CLAUDE.mdInstruksi bersama tim untuk proyekArsitektur proyek, standar pengkodean, alur kerja umumAnggota tim melalui kontrol sumber
Instruksi pengguna~/.claude/CLAUDE.mdPreferensi pribadi untuk semua proyekPreferensi gaya kode, pintasan alat pribadiHanya Anda (semua proyek)
File CLAUDE.md dalam hierarki direktori di atas direktori kerja dimuat sepenuhnya saat peluncuran. File CLAUDE.md di subdirektori dimuat sesuai permintaan ketika Claude membaca file di direktori tersebut. Lihat Bagaimana file CLAUDE.md dimuat untuk urutan resolusi lengkap. Untuk proyek besar, Anda dapat memecah instruksi menjadi file khusus topik menggunakan aturan proyek. Aturan memungkinkan Anda membatasi instruksi ke tipe file atau subdirektori tertentu.

Siapkan CLAUDE.md proyek

CLAUDE.md proyek dapat disimpan di ./CLAUDE.md atau ./.claude/CLAUDE.md. Buat file ini dan tambahkan instruksi yang berlaku untuk siapa pun yang bekerja pada proyek: perintah build dan test, standar pengkodean, keputusan arsitektur, konvensi penamaan, dan alur kerja umum. Instruksi ini dibagikan dengan tim Anda melalui kontrol versi, jadi fokus pada standar tingkat proyek daripada preferensi pribadi.
Jalankan /init untuk menghasilkan CLAUDE.md awal secara otomatis. Claude menganalisis basis kode Anda dan membuat file dengan perintah build, instruksi test, dan konvensi proyek yang ditemukannya. Jika CLAUDE.md sudah ada, /init menyarankan perbaikan daripada menimpanya. Perbaiki dari sana dengan instruksi yang Claude tidak akan temukan sendiri.Atur CLAUDE_CODE_NEW_INIT=true untuk mengaktifkan alur multi-fase interaktif. /init menanyakan artefak mana yang akan diatur: file CLAUDE.md, skills, dan hooks. Kemudian mengeksplorasi basis kode Anda dengan subagent, mengisi celah melalui pertanyaan lanjutan, dan menyajikan proposal yang dapat ditinjau sebelum menulis file apa pun.

Tulis instruksi yang efektif

File CLAUDE.md dimuat ke dalam context window di awal setiap sesi, mengonsumsi token bersama percakapan Anda. Karena mereka adalah konteks daripada konfigurasi yang diberlakukan, cara Anda menulis instruksi mempengaruhi seberapa andal Claude mengikutinya. Instruksi yang spesifik, ringkas, dan terstruktur dengan baik bekerja paling baik. Ukuran: targetkan di bawah 200 baris per file CLAUDE.md. File yang lebih panjang mengonsumsi lebih banyak konteks dan mengurangi kepatuhan. Jika instruksi Anda berkembang besar, pisahkan menggunakan impor atau file .claude/rules/. Struktur: gunakan header markdown dan bullet untuk mengelompokkan instruksi terkait. Claude memindai struktur dengan cara yang sama seperti pembaca: bagian yang terorganisir lebih mudah diikuti daripada paragraf padat. Spesifisitas: tulis instruksi yang cukup konkret untuk diverifikasi. Misalnya:
  • “Gunakan indentasi 2 spasi” daripada “Format kode dengan baik”
  • “Jalankan npm test sebelum commit” daripada “Uji perubahan Anda”
  • “Handler API berada di src/api/handlers/” daripada “Jaga file tetap terorganisir”
Konsistensi: jika dua aturan saling bertentangan, Claude mungkin memilih satu secara sembarangan. Tinjau file CLAUDE.md Anda, file CLAUDE.md bersarang di subdirektori, dan file .claude/rules/ secara berkala untuk menghapus instruksi yang ketinggalan zaman atau bertentangan. Dalam monorepo, gunakan claudeMdExcludes untuk melewati file CLAUDE.md dari tim lain yang tidak relevan dengan pekerjaan Anda.

Impor file tambahan

File CLAUDE.md dapat mengimpor file tambahan menggunakan sintaks @path/to/import. File yang diimpor diperluas dan dimuat ke dalam konteks saat peluncuran bersama CLAUDE.md yang mereferensikannya. Jalur relatif dan absolut diizinkan. Jalur relatif diselesaikan relatif terhadap file yang berisi impor, bukan direktori kerja. File yang diimpor dapat secara rekursif mengimpor file lain, dengan kedalaman maksimal lima hop. Untuk menarik README, package.json, dan panduan alur kerja, referensikan mereka dengan sintaks @ di mana saja di CLAUDE.md Anda:
Lihat @README untuk gambaran umum proyek dan @package.json untuk perintah npm yang tersedia untuk proyek ini.

# Instruksi Tambahan
- alur kerja git @docs/git-instructions.md
Untuk preferensi pribadi yang tidak ingin Anda periksa, impor file dari direktori home Anda. Impor masuk ke CLAUDE.md bersama, tetapi file yang ditunjuknya tetap di mesin Anda:
# Preferensi Individu
- @~/.claude/my-project-instructions.md
Pertama kali Claude Code menemukan impor eksternal dalam proyek, itu menampilkan dialog persetujuan yang mencantumkan file. Jika Anda menolak, impor tetap dinonaktifkan dan dialog tidak muncul lagi.
Untuk pendekatan yang lebih terstruktur untuk mengorganisir instruksi, lihat .claude/rules/.

AGENTS.md

Claude Code membaca CLAUDE.md, bukan AGENTS.md. Jika repositori Anda sudah menggunakan AGENTS.md untuk agen pengkodean lain, buat CLAUDE.md yang mengimpornya sehingga kedua alat membaca instruksi yang sama tanpa menduplikasinya. Anda juga dapat menambahkan instruksi khusus Claude di bawah impor. Claude memuat file yang diimpor saat awal sesi, kemudian menambahkan sisanya:
CLAUDE.md
@AGENTS.md

## Claude Code

Gunakan plan mode untuk perubahan di bawah `src/billing/`.

Bagaimana file CLAUDE.md dimuat

Claude Code membaca file CLAUDE.md dengan berjalan naik pohon direktori dari direktori kerja saat ini, memeriksa setiap direktori di sepanjang jalan. Ini berarti jika Anda menjalankan Claude Code di foo/bar/, itu memuat instruksi dari foo/bar/CLAUDE.md dan foo/CLAUDE.md. Claude juga menemukan file CLAUDE.md di subdirektori di bawah direktori kerja saat ini. Alih-alih memuatnya saat peluncuran, mereka disertakan ketika Claude membaca file di subdirektori tersebut. Jika Anda bekerja di monorepo besar di mana file CLAUDE.md tim lain diambil, gunakan claudeMdExcludes untuk melewatinya. Komentar HTML tingkat blok (<!-- maintainer notes -->) dalam file CLAUDE.md dihapus sebelum konten disuntikkan ke dalam konteks Claude. Gunakan mereka untuk meninggalkan catatan bagi pengelola manusia tanpa menghabiskan token konteks pada mereka. Komentar di dalam blok kode dipertahankan. Ketika Anda membuka file CLAUDE.md secara langsung dengan alat Read, komentar tetap terlihat.

Muat dari direktori tambahan

Flag --add-dir memberikan Claude akses ke direktori tambahan di luar direktori kerja utama Anda. Secara default, file CLAUDE.md dari direktori ini tidak dimuat. Untuk juga memuat file CLAUDE.md dari direktori tambahan, termasuk CLAUDE.md, .claude/CLAUDE.md, dan .claude/rules/*.md, atur variabel lingkungan CLAUDE_CODE_ADDITIONAL_DIRECTORIES_CLAUDE_MD:
CLAUDE_CODE_ADDITIONAL_DIRECTORIES_CLAUDE_MD=1 claude --add-dir ../shared-config

Organisir aturan dengan .claude/rules/

Untuk proyek yang lebih besar, Anda dapat mengorganisir instruksi menjadi beberapa file menggunakan direktori .claude/rules/. Ini membuat instruksi modular dan lebih mudah bagi tim untuk dipertahankan. Aturan juga dapat dibatasi ke jalur file tertentu, sehingga mereka hanya dimuat ke dalam konteks ketika Claude bekerja dengan file yang cocok, mengurangi kebisingan dan menghemat ruang konteks.
Aturan dimuat ke dalam konteks setiap sesi atau ketika file yang cocok dibuka. Untuk instruksi khusus tugas yang tidak perlu berada dalam konteks sepanjang waktu, gunakan skills sebagai gantinya, yang hanya dimuat ketika Anda menginvokasinya atau ketika Claude menentukan mereka relevan dengan prompt Anda.

Siapkan aturan

Tempatkan file markdown di direktori .claude/rules/ proyek Anda. Setiap file harus mencakup satu topik, dengan nama file deskriptif seperti testing.md atau api-design.md. Semua file .md ditemukan secara rekursif, jadi Anda dapat mengorganisir aturan ke dalam subdirektori seperti frontend/ atau backend/:
your-project/
├── .claude/
│   ├── CLAUDE.md           # Instruksi proyek utama
│   └── rules/
│       ├── code-style.md   # Pedoman gaya kode
│       ├── testing.md      # Konvensi pengujian
│       └── security.md     # Persyaratan keamanan
Aturan tanpa frontmatter paths dimuat saat peluncuran dengan prioritas yang sama seperti .claude/CLAUDE.md.

Aturan khusus jalur

Aturan dapat dibatasi ke file tertentu menggunakan frontmatter YAML dengan bidang paths. Aturan bersyarat ini hanya berlaku ketika Claude bekerja dengan file yang cocok dengan pola yang ditentukan.
---
paths:
  - "src/api/**/*.ts"
---

# Aturan Pengembangan API

- Semua endpoint API harus menyertakan validasi input
- Gunakan format respons kesalahan standar
- Sertakan komentar dokumentasi OpenAPI
Aturan tanpa bidang paths dimuat tanpa syarat dan berlaku untuk semua file. Aturan bersyarat jalur dipicu ketika Claude membaca file yang cocok dengan pola, bukan pada setiap penggunaan alat. Gunakan pola glob di bidang paths untuk mencocokkan file berdasarkan ekstensi, direktori, atau kombinasi apa pun:
PolaCocok dengan
**/*.tsSemua file TypeScript di direktori apa pun
src/**/*Semua file di bawah direktori src/
*.mdFile Markdown di root proyek
src/components/*.tsxKomponen React di direktori tertentu
Anda dapat menentukan beberapa pola dan menggunakan ekspansi brace untuk mencocokkan beberapa ekstensi dalam satu pola:
---
paths:
  - "src/**/*.{ts,tsx}"
  - "lib/**/*.ts"
  - "tests/**/*.test.ts"
---
Direktori .claude/rules/ mendukung symlinks, jadi Anda dapat mempertahankan set aturan bersama dan menautkannya ke beberapa proyek. Symlinks diselesaikan dan dimuat secara normal, dan symlinks melingkar terdeteksi dan ditangani dengan anggun. Contoh ini menautkan direktori bersama dan file individual:
ln -s ~/shared-claude-rules .claude/rules/shared
ln -s ~/company-standards/security.md .claude/rules/security.md

Aturan tingkat pengguna

Aturan pribadi di ~/.claude/rules/ berlaku untuk setiap proyek di mesin Anda. Gunakan untuk preferensi yang bukan khusus proyek:
~/.claude/rules/
├── preferences.md    # Preferensi pengkodean pribadi Anda
└── workflows.md      # Alur kerja pilihan Anda
Aturan tingkat pengguna dimuat sebelum aturan proyek, memberikan aturan proyek prioritas lebih tinggi.

Kelola CLAUDE.md untuk tim besar

Untuk organisasi yang menerapkan Claude Code di seluruh tim, Anda dapat memusatkan instruksi dan mengontrol file CLAUDE.md mana yang dimuat.

Terapkan CLAUDE.md di seluruh organisasi

Organisasi dapat menerapkan CLAUDE.md yang dikelola secara terpusat yang berlaku untuk semua pengguna di mesin. File ini tidak dapat dikecualikan oleh pengaturan individual.
1

Buat file di lokasi kebijakan terkelola

  • macOS: /Library/Application Support/ClaudeCode/CLAUDE.md
  • Linux dan WSL: /etc/claude-code/CLAUDE.md
  • Windows: C:\Program Files\ClaudeCode\CLAUDE.md
2

Terapkan dengan sistem manajemen konfigurasi Anda

Gunakan MDM, Group Policy, Ansible, atau alat serupa untuk mendistribusikan file di seluruh mesin pengembang. Lihat pengaturan terkelola untuk opsi konfigurasi di seluruh organisasi lainnya.
CLAUDE.md yang dikelola dan pengaturan terkelola melayani tujuan yang berbeda. Gunakan pengaturan untuk penegakan teknis dan CLAUDE.md untuk panduan perilaku:
KekhawatiranKonfigurasi dalam
Blokir alat, perintah, atau jalur file tertentuPengaturan terkelola: permissions.deny
Paksakan isolasi sandboxPengaturan terkelola: sandbox.enabled
Variabel lingkungan dan perutean penyedia APIPengaturan terkelola: env
Metode autentikasi dan kunci organisasiPengaturan terkelola: forceLoginMethod, forceLoginOrgUUID
Panduan gaya kode dan kualitasCLAUDE.md terkelola
Pengingat penanganan data dan kepatuhanCLAUDE.md terkelola
Instruksi perilaku untuk ClaudeCLAUDE.md terkelola
Aturan pengaturan diberlakukan oleh klien terlepas dari apa yang Claude putuskan untuk dilakukan. Instruksi CLAUDE.md membentuk perilaku Claude tetapi bukan lapisan penegakan keras.

Kecualikan file CLAUDE.md tertentu

Dalam monorepo besar, file CLAUDE.md leluhur mungkin berisi instruksi yang tidak relevan dengan pekerjaan Anda. Pengaturan claudeMdExcludes memungkinkan Anda melewati file tertentu berdasarkan jalur atau pola glob. Contoh ini mengecualikan CLAUDE.md tingkat atas dan direktori aturan dari folder induk. Tambahkan ke .claude/settings.local.json agar pengecualian tetap lokal ke mesin Anda:
{
  "claudeMdExcludes": [
    "**/monorepo/CLAUDE.md",
    "/home/user/monorepo/other-team/.claude/rules/**"
  ]
}
Pola dicocokkan dengan jalur file absolut menggunakan sintaks glob. Anda dapat mengonfigurasi claudeMdExcludes di lapisan pengaturan apa pun: pengguna, proyek, lokal, atau kebijakan terkelola. Array digabungkan di seluruh lapisan. File CLAUDE.md kebijakan terkelola tidak dapat dikecualikan. Ini memastikan instruksi di seluruh organisasi selalu berlaku terlepas dari pengaturan individual.

Auto memory

Auto memory memungkinkan Claude mengumpulkan pengetahuan lintas sesi tanpa Anda menulis apa pun. Claude menyimpan catatan untuk dirinya sendiri saat bekerja: perintah build, wawasan debugging, catatan arsitektur, preferensi gaya kode, dan kebiasaan alur kerja. Claude tidak menyimpan sesuatu setiap sesi. Itu memutuskan apa yang layak diingat berdasarkan apakah informasi akan berguna dalam percakapan masa depan.
Auto memory memerlukan Claude Code v2.1.59 atau lebih baru. Periksa versi Anda dengan claude --version.

Aktifkan atau nonaktifkan auto memory

Auto memory aktif secara default. Untuk mengalihkannya, buka /memory dalam sesi dan gunakan toggle auto memory, atau atur autoMemoryEnabled dalam pengaturan proyek Anda:
{
  "autoMemoryEnabled": false
}
Untuk menonaktifkan auto memory melalui variabel lingkungan, atur CLAUDE_CODE_DISABLE_AUTO_MEMORY=1.

Lokasi penyimpanan

Setiap proyek mendapatkan direktori memori sendiri di ~/.claude/projects/<project>/memory/. Jalur <project> berasal dari repositori git, jadi semua worktrees dan subdirektori dalam repo yang sama berbagi satu direktori auto memory. Di luar repo git, root proyek digunakan sebagai gantinya. Untuk menyimpan auto memory di lokasi berbeda, atur autoMemoryDirectory dalam pengaturan pengguna atau lokal Anda:
{
  "autoMemoryDirectory": "~/my-custom-memory-dir"
}
Pengaturan ini diterima dari pengaturan kebijakan, lokal, dan pengguna. Itu tidak diterima dari pengaturan proyek (.claude/settings.json) untuk mencegah proyek bersama mengarahkan ulang penulisan auto memory ke lokasi sensitif. Direktori berisi titik masuk MEMORY.md dan file topik opsional:
~/.claude/projects/<project>/memory/
├── MEMORY.md          # Indeks ringkas, dimuat ke dalam setiap sesi
├── debugging.md       # Catatan terperinci tentang pola debugging
├── api-conventions.md # Keputusan desain API
└── ...                # File topik lain yang Claude buat
MEMORY.md bertindak sebagai indeks direktori memori. Claude membaca dan menulis file di direktori ini sepanjang sesi Anda, menggunakan MEMORY.md untuk melacak apa yang disimpan di mana. Auto memory adalah mesin-lokal. Semua worktrees dan subdirektori dalam repositori git yang sama berbagi satu direktori auto memory. File tidak dibagikan di seluruh mesin atau lingkungan cloud.

Bagaimana cara kerjanya

200 baris pertama MEMORY.md dimuat di awal setiap percakapan. Konten di luar baris 200 tidak dimuat saat awal sesi. Claude membuat MEMORY.md ringkas dengan memindahkan catatan terperinci ke file topik terpisah. Batas 200 baris ini hanya berlaku untuk MEMORY.md. File CLAUDE.md dimuat sepenuhnya terlepas dari panjangnya, meskipun file yang lebih pendek menghasilkan kepatuhan yang lebih baik. File topik seperti debugging.md atau patterns.md tidak dimuat saat startup. Claude membacanya sesuai permintaan menggunakan alat file standarnya ketika membutuhkan informasi. Claude membaca dan menulis file memori selama sesi Anda. Ketika Anda melihat “Writing memory” atau “Recalled memory” di antarmuka Claude Code, Claude secara aktif memperbarui atau membaca dari ~/.claude/projects/<project>/memory/.

Audit dan edit memori Anda

File auto memory adalah markdown biasa yang dapat Anda edit atau hapus kapan saja. Jalankan /memory untuk menelusuri dan membuka file memori dari dalam sesi.

Lihat dan edit dengan /memory

Perintah /memory mencantumkan semua file CLAUDE.md dan rules yang dimuat dalam sesi saat ini, memungkinkan Anda mengalihkan auto memory aktif atau mati, dan menyediakan tautan untuk membuka folder auto memory. Pilih file apa pun untuk membukanya di editor Anda. Ketika Anda meminta Claude untuk mengingat sesuatu, seperti “selalu gunakan pnpm, bukan npm” atau “ingat bahwa tes API memerlukan instans Redis lokal,” Claude menyimpannya ke auto memory. Untuk menambahkan instruksi ke CLAUDE.md sebagai gantinya, minta Claude secara langsung, seperti “tambahkan ini ke CLAUDE.md,” atau edit file sendiri melalui /memory.

Troubleshoot masalah memori

Ini adalah masalah paling umum dengan CLAUDE.md dan auto memory, bersama dengan langkah-langkah untuk men-debug mereka.

Claude tidak mengikuti CLAUDE.md saya

Konten CLAUDE.md disampaikan sebagai pesan pengguna setelah prompt sistem, bukan sebagai bagian dari prompt sistem itu sendiri. Claude membacanya dan mencoba mengikutinya, tetapi tidak ada jaminan kepatuhan ketat, terutama untuk instruksi yang samar atau bertentangan. Untuk men-debug:
  • Jalankan /memory untuk memverifikasi file CLAUDE.md Anda dimuat. Jika file tidak terdaftar, Claude tidak dapat melihatnya.
  • Periksa bahwa CLAUDE.md yang relevan berada di lokasi yang dimuat untuk sesi Anda (lihat Pilih di mana menempatkan file CLAUDE.md).
  • Buat instruksi lebih spesifik. “Gunakan indentasi 2 spasi” bekerja lebih baik daripada “format kode dengan baik.”
  • Cari instruksi yang bertentangan di seluruh file CLAUDE.md. Jika dua file memberikan panduan berbeda untuk perilaku yang sama, Claude mungkin memilih satu secara sembarangan.
Untuk instruksi yang Anda inginkan di tingkat prompt sistem, gunakan --append-system-prompt. Ini harus dilewatkan setiap invokasi, jadi lebih cocok untuk skrip dan otomasi daripada penggunaan interaktif.
Gunakan hook InstructionsLoaded untuk mencatat dengan tepat file instruksi mana yang dimuat, kapan mereka dimuat, dan mengapa. Ini berguna untuk men-debug aturan khusus jalur atau file yang dimuat malas di subdirektori.

Saya tidak tahu apa yang disimpan auto memory

Jalankan /memory dan pilih folder auto memory untuk menelusuri apa yang telah disimpan Claude. Semuanya adalah markdown biasa yang dapat Anda baca, edit, atau hapus.

CLAUDE.md saya terlalu besar

File di atas 200 baris mengonsumsi lebih banyak konteks dan dapat mengurangi kepatuhan. Pindahkan konten terperinci ke file terpisah yang direferensikan dengan impor @path (lihat Impor file tambahan), atau pisahkan instruksi Anda di seluruh file .claude/rules/.

Instruksi tampak hilang setelah /compact

CLAUDE.md sepenuhnya bertahan dari pemadatan. Setelah /compact, Claude membaca ulang CLAUDE.md Anda dari disk dan menyuntikkannya kembali segar ke dalam sesi. Jika instruksi hilang setelah pemadatan, itu diberikan hanya dalam percakapan, bukan ditulis ke CLAUDE.md. Tambahkan ke CLAUDE.md untuk membuatnya bertahan lintas sesi. Lihat Tulis instruksi yang efektif untuk panduan tentang ukuran, struktur, dan spesifisitas.

Sumber daya terkait

  • Skills: paket alur kerja yang dapat diulang yang dimuat sesuai permintaan
  • Settings: konfigurasi perilaku Claude Code dengan file pengaturan
  • Kelola sesi: kelola konteks, lanjutkan percakapan, dan jalankan sesi paralel
  • Memori subagent: biarkan subagents mempertahankan auto memory mereka sendiri