Apakah ada cara untuk mengosongkan array dan jika mungkin dengan .remove()
?
Contohnya,
A = [1,2,3,4];
Bagaimana saya bisa mengosongkannya?
javascript
arrays
akano1
sumber
sumber
Jawaban:
Cara menghapus array yang ada
A
:Metode 1
(ini adalah jawaban asli saya untuk pertanyaan itu)
Kode ini akan mengatur variabel
A
ke array kosong baru. Ini sempurna jika Anda tidak memiliki referensi ke array asli diA
tempat lain karena ini benar-benar menciptakan array baru (kosong). Anda harus berhati-hati dengan metode ini karena jika Anda telah mereferensikan array ini dari variabel atau properti lain, array asli akan tetap tidak berubah. Hanya gunakan ini jika Anda hanya mereferensikan array dengan variabel aslinyaA
.Ini juga solusi tercepat.
Contoh kode ini menunjukkan masalah yang dapat Anda temui saat menggunakan metode ini:
Metode 2 (seperti yang disarankan oleh Matthew Crumley )
Ini akan menghapus array yang ada dengan menetapkan panjangnya ke 0. Beberapa berpendapat bahwa ini mungkin tidak bekerja di semua implementasi JavaScript, tetapi ternyata ini bukan masalahnya. Ini juga berfungsi ketika menggunakan "mode ketat" di ECMAScript 5 karena properti panjang array adalah properti baca / tulis.
Metode 3 (seperti yang disarankan oleh Anthony )
Menggunakan
.splice()
akan bekerja dengan sempurna, tetapi karena.splice()
fungsi akan mengembalikan array dengan semua item yang dihapus, itu sebenarnya akan mengembalikan salinan dari array asli. Tingkatan yang dicapai menunjukkan bahwa ini tidak mempengaruhi kinerja apa pun.Metode 4 (seperti yang disarankan oleh tanguy_k )
Solusi ini tidak terlalu ringkas, dan juga solusi paling lambat, bertentangan dengan tolok ukur sebelumnya yang dirujuk dalam jawaban asli.
Performa
Dari semua metode pembersihan array yang ada , metode 2 dan 3 sangat mirip dalam kinerjanya dan jauh lebih cepat daripada metode 4. Lihat benchmark ini .
Seperti yang ditunjukkan oleh Diadistis dalam jawaban mereka di bawah ini, tolok ukur asli yang digunakan untuk menentukan kinerja empat metode yang dijelaskan di atas cacat. Benchmark asli menggunakan kembali array yang telah dihapus sehingga iterasi kedua membersihkan sebuah array yang sudah kosong.
Tolok ukur berikut memperbaiki kekurangan ini: http://jsben.ch/#/hyj65 . Ini jelas menunjukkan bahwa metode # 2 (properti panjang) dan # 3 (sambatan) adalah yang tercepat (tidak menghitung metode # 1 yang tidak mengubah array asli).
Ini telah menjadi topik hangat dan menjadi penyebab banyak kontroversi. Sebenarnya ada banyak jawaban yang benar dan karena jawaban ini telah ditandai sebagai jawaban yang diterima untuk waktu yang sangat lama, saya akan memasukkan semua metode di sini. Jika Anda memilih jawaban ini, harap jawab dengan jawaban lain yang telah saya referensikan juga.
sumber
while (A.length) { A.pop(); }
, tidak perlu untuk> 0
> 0
IMHO lebih mudah dibaca. Dan tidak ada perbedaan kinerja antara keduanya.b
memegang referensi ke array lama bahkan setelaha
ditugaskan yang baru.c
dand
terus referensi array yang sama. Oleh karena itu perbedaan dalam output diharapkan.while(A.pop())
jika item dalam array adalah falsey. Ambil contoh A = [2, 1, 0, -1, -2] akan menghasilkan A yang menyamakan [2, 1]. Bahkanwhile(A.pop() !== undefined)
tidak berfungsi karena Anda dapat memiliki array dengan undefined sebagai salah satu nilai. Mungkin mengapa kompiler tidak mengoptimalkannya.Jika Anda perlu mempertahankan array asli karena Anda memiliki referensi lain yang harus diperbarui juga, Anda dapat menghapusnya tanpa membuat array baru dengan menetapkan panjangnya ke nol:
sumber
myarray.push(whatever)
menambahkan satu panjang. Jadi pengaturan panjang memotong array, tapi itu tidak permanen.length
adalah properti khusus, tetapi tidak hanya baca, jadi tetap bekerja.Di sini, implementasi tercepat bekerja dengantetap mempertahankan array yang sama ("bisa berubah"):FYI tidak dapat disederhanakan menjadi
while (array.pop())
: tes akan gagal.FYI Map and Set define
clear()
, akan terlihat logisclear()
untuk Array juga.Versi TypeScript:
Tes terkait:
Di sini jsPerf yang diperbarui:
http://jsperf.com/array-destroy/32http://jsperf.com/array-destroy/152sumber
Array.prototype
dan melakukan sesuatu yang sedikit berbeda, maka seluruh kode Anda[].clear()
sedikit salah. Ini tidak akan menyenangkan untuk di-debug. Jadi, pesan umumnya adalah: Jangan memodifikasi global.function clear(arr) { while(arr.length) arr.pop(); }
, lalu hapus array denganclear(arr)
alih - aliharr.clear()
..splice()
dan.length=0
. Tolok ukurnya tidak benar. Lihat jawaban saya yang diperbarui.Solusi cross-browser yang lebih ramah dan lebih optimal adalah dengan menggunakan
splice
metode ini untuk mengosongkan konten array A seperti di bawah ini:A.splice(0, A.length);
sumber
splice
memodifikasi array dan mengembalikan entri yang dihapus. Baca dokumen terlebih dahulu: developer.mozilla.org/en-US/docs/JavaScript/Reference/…A.splice(0, A.length),0;
. Ini akan meninggalkan nilai kembali dari0
sepertiA.length = 0;
. Array yang dihasilkan masih dibuat dan harus menyebabkan script untuk menjalankan lebih lambat: ( jsperf ~ 56% lebih lambat). Implementasi browser akan memengaruhi ini meskipun saya tidak melihat alasan mengapasplice
lebih cepat dari pengaturanlength
.A.splice(0)
juga berfungsi.Jawaban yang tidak kurang dari 2739 yang diputuskan sekarang menyesatkan dan salah.
Pertanyaannya adalah: "Bagaimana Anda mengosongkan array yang ada?" Misalnya untuk
A = [1,2,3,4]
.Mengatakan "
A = []
adalah jawabannya" bodoh dan sama sekali tidak benar.[] == []
itu salah .Ini karena kedua array ini adalah dua objek terpisah, masing-masing, dengan dua identitas mereka sendiri, mengambil ruang mereka sendiri di dunia digital, masing-masing dengan sendirinya.
Katakanlah ibumu meminta Anda untuk mengosongkan tempat sampah.
A = [1,2,3,4]; A = [];
Mengosongkan objek array adalah yang termudah:
Dengan cara ini, kaleng di bawah "A" tidak hanya kosong, tetapi juga sebersih baru!
Selain itu, Anda tidak perlu membuang sampah dengan tangan sampai kalengnya kosong! Anda diminta untuk mengosongkan yang sudah ada, sepenuhnya, dalam satu giliran, untuk tidak mengambil sampah sampai kaleng kosong, seperti pada:
Juga, untuk meletakkan tangan kiri Anda di bagian bawah tempat sampah, memegangnya dengan tangan kanan Anda di bagian atas untuk dapat menarik isinya seperti pada:
Tidak, Anda diminta mengosongkannya:
Ini adalah satu-satunya kode yang secara benar mengosongkan isi dari array JavaScript yang diberikan.
sumber
A(n) = A.splice( 0, A.length );
jika Anda perlu membuat cadangan konten Anda sebelumnya. psArray.length
adalah properti baca-tulis \ metode jika Anda melewatkan fakta dasar itu. Artinya, Anda dapat memperluasnya ke panjang baru, Anda tidak dapat memotongnya ke panjang mana pun yang Anda inginkan, dan di antaranya Anda dapat membuang semua anggota dengan memperpendek panjangnya menjadi 0. Ini adalah pisau Swiss array.Uji kinerja:
http://jsperf.com/array-clear-methods/3
sumber
Anda dapat menambahkan ini ke file JavaScript Anda untuk memungkinkan array Anda "dihapus":
Maka Anda dapat menggunakannya seperti ini:
Atau jika Anda ingin memastikan Anda tidak menghancurkan sesuatu:
Banyak orang berpikir Anda tidak boleh memodifikasi objek asli (seperti Array), dan saya cenderung setuju. Harap berhati-hati dalam memutuskan bagaimana menangani hal ini.
sumber
clear
kunci?Ada banyak kebingungan dan informasi yang salah mengenai sementara; kinerja pop / shift baik dalam jawaban dan komentar. Solusi while / pop memiliki (seperti yang diharapkan) kinerja terburuk . Apa yang sebenarnya terjadi adalah bahwa pengaturan hanya berjalan satu kali untuk setiap sampel yang menjalankan cuplikan dalam satu lingkaran. misalnya:
Saya telah membuat tes baru yang berfungsi dengan benar:
http://jsperf.com/empty-javascript-array-redux
Peringatan: bahkan dalam versi tes ini, Anda tidak dapat benar-benar melihat perbedaan nyata karena mengkloning array memakan sebagian besar waktu pengujian. Itu masih menunjukkan bahwa itu
splice
adalah cara tercepat untuk menghapus array (tidak[]
mempertimbangkan karena sementara itu tercepat itu tidak benar-benar membersihkan array yang ada).sumber
Jika Anda tertarik dengan alokasi memori, Anda dapat membandingkan setiap pendekatan menggunakan sesuatu seperti jsfiddle ini bersama dengan tab garis waktu alat dev krom. Anda akan ingin menggunakan ikon tempat sampah di bagian bawah untuk memaksa pengumpulan sampah setelah 'membersihkan' array. Ini akan memberi Anda jawaban yang lebih pasti untuk peramban pilihan Anda. Banyak jawaban di sini sudah tua dan saya tidak akan bergantung pada mereka melainkan menguji seperti pada jawaban @ tanguy_k di atas.
(untuk pengantar ke tab tersebut Anda dapat memeriksa di sini )
Stackoverflow memaksa saya untuk menyalin jsfiddle jadi ini dia:
Dan Anda harus mencatat bahwa itu mungkin tergantung pada jenis elemen array, karena javascript mengelola string berbeda dari tipe primitif lainnya, belum lagi array objek. Jenisnya dapat memengaruhi apa yang terjadi.
sumber
Anda dapat dengan mudah membuat fungsi untuk melakukan itu untuk Anda, mengubah panjangnya atau bahkan menambahkannya ke Array asli sebagai
remove()
fungsi untuk digunakan kembali.Bayangkan Anda memiliki array ini:
Oke, jalankan saja ini:
dan hasilnya adalah:
cara mudah mengosongkan array ...
Juga menggunakan loop yang tidak perlu tetapi hanya cara lain untuk melakukan itu:
Ada juga cara rumit yang dapat Anda pikirkan, misalnya sesuatu seperti ini:
Jadi jika arr memiliki 5 item, itu akan memecah 5 item dari 0, yang berarti tidak ada yang tersisa dalam array.
Juga cara lain seperti cukup menetapkan kembali array misalnya:
Jika Anda melihat fungsi Array, ada banyak cara lain untuk melakukan ini, tetapi yang paling direkomendasikan adalah mengubah panjangnya.
Seperti yang saya katakan di awal, Anda juga dapat membuat prototipe remove () karena itu adalah jawaban untuk pertanyaan Anda. Anda cukup memilih salah satu metode di atas dan membuat prototipe untuk objek Array di JavaScript, seperti:
dan Anda bisa menyebutnya seperti ini untuk mengosongkan array apa pun di aplikasi javascript Anda:
sumber
Dan menyebutnya:
array.clear();
sumber
A.splice(0);
Saya hanya melakukan ini pada beberapa kode yang sedang saya kerjakan. Itu membersihkan array.
sumber
Jika Anda menggunakan
Kemudian Anda menetapkan referensi array baru ke a, jika referensi dalam sudah ditugaskan ke variabel lain, maka itu tidak akan mengosongkan array itu juga dan karenanya pengumpul sampah tidak akan mengumpulkan memori itu.
Misalnya
atau
Ketika kita tentukan
a.length
, kami hanya mengatur ulang batas array dan memori untuk elemen array lainnya akan dihubungkan oleh pengumpul sampah.Alih-alih kedua solusi ini lebih baik.
dan
Sesuai jawaban sebelumnya oleh kenshou.html, metode kedua lebih cepat.
sumber
a.length
, saya tidak melihat apa yang ditambahkan jawaban baru ini ke utas?a.length=0;
dilakukan? Bagaimana mesin itu bertindak untuka.length=500;
dana.length=4;
?var a = [1]; var b = a; a.length = 0; console.log(b)
cetakanArray [ ]
, jadi sepertinya tidak menciptakan array baru untuk saya.Gunakan versi modifikasi dari saran awal Jan :
sumber
Jika Anda menggunakan konstanta maka Anda tidak punya pilihan:
Anda tidak dapat menetapkan ulang:
Anda hanya dapat memotong:
sumber
Untuk Mengosongkan Lokasi memori saat ini dari sebuah array gunakan:
'myArray.length = 0'
atau'myArray.pop() UN-till its length is 0'
length
: Anda dapat mengatur properti panjang untuk memotong array kapan saja. Saat Anda memperluas array dengan mengubah properti panjangnya, jumlah elemen aktual bertambah.pop()
: Metode pop menghapus elemen terakhir dari array dan mengembalikan yang mengembalikan nilai yang dihapus.shift()
: Metode shift menghapus elemen pada indeks nol dan menggeser nilai pada indeks berturut-turut ke bawah, lalu mengembalikan nilai yang dihapus.Contoh:
new Array() | []
Buat Array dengan lokasi memori baru dengan menggunakanArray constructor
atauarray literal
.slice()
: Dengan menggunakan fungsi slice kita mendapatkan salinan elemen yang dangkal dari array asli, dengan alamat memori baru, sehingga setiap modifikasi pada cloneArr tidak akan mempengaruhi ke array | asli yang sebenarnya.sumber
length = ?
bukan hanyalength
.Saya terkejut belum ada yang menyarankan ini:
Ini menghasilkan array dalam keadaan yang sangat berbeda dari solusi lain. Dalam arti tertentu, array telah 'dikosongkan':
Anda dapat menghasilkan array yang setara dengan
[,,,,]
atauArray(4)
sumber
Gunakan di bawah ini jika Anda perlu mengosongkan Angular 2+ FormArray.
sumber