Ruby - Array

Array Ruby diurutkan, koleksi objek apa pun yang diindeks dengan integer. Setiap elemen dalam array dikaitkan dan dirujuk oleh indeks.

Pengindeksan array dimulai dari 0, seperti di C atau Java. Indeks negatif diasumsikan relatif terhadap akhir larik --- yaitu, indeks -1 menunjukkan elemen terakhir larik, -2 adalah elemen di sebelah terakhir dalam larik, dan seterusnya.

Array Ruby dapat menampung objek seperti String, Integer, Fixnum, Hash, Symbol, bahkan objek Array lainnya. Array Ruby tidak sekaku array dalam bahasa lain. Array Ruby tumbuh secara otomatis sambil menambahkan elemen ke dalamnya.

Membuat Array

Ada banyak cara untuk membuat atau menginisialisasi array. Salah satu caranya adalah dengan metode kelas baru -

names = Array.new

Anda dapat mengatur ukuran array pada saat membuat array -

names = Array.new(20)

Array nama sekarang memiliki ukuran atau panjang 20 elemen. Anda dapat mengembalikan ukuran larik dengan metode ukuran atau panjang -

#!/usr/bin/ruby

names = Array.new(20)
puts names.size  # This returns 20
puts names.length # This also returns 20

Ini akan menghasilkan hasil sebagai berikut -

20
20

Anda dapat menetapkan nilai ke setiap elemen dalam array sebagai berikut -

#!/usr/bin/ruby

names = Array.new(4, "mac")
puts "#{names}"

Ini akan menghasilkan hasil sebagai berikut -

["mac", "mac", "mac", "mac"]

Anda juga dapat menggunakan blok dengan new, mengisi setiap elemen dengan tujuan evaluasi blok -

#!/usr/bin/ruby

nums = Array.new(10) { |e| e = e * 2 }
puts "#{nums}"

Ini akan menghasilkan hasil sebagai berikut -

[0, 2, 4, 6, 8, 10, 12, 14, 16, 18]

Ada metode lain dari Array, []. Ini bekerja seperti ini -

nums = Array.[](1, 2, 3, 4,5)

Satu lagi bentuk pembuatan larik adalah sebagai berikut -

nums = Array[1, 2, 3, 4,5]

The Kernel modul yang tersedia di inti Ruby memiliki metode Array, yang hanya menerima satu argumen. Di sini, metode ini menggunakan rentang sebagai argumen untuk membuat deretan digit -

#!/usr/bin/ruby

digits = Array(0..9)
puts "#{digits}"

Ini akan menghasilkan hasil sebagai berikut -

[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

Metode Bawaan Array

Kita perlu memiliki instance objek Array untuk memanggil metode Array. Seperti yang telah kita lihat, berikut adalah cara membuat instance dari objek Array -

Array.[](...) [or] Array[...] [or] [...]

Ini akan mengembalikan array baru yang diisi dengan objek yang diberikan. Sekarang, dengan menggunakan objek yang dibuat, kita dapat memanggil metode instance apa pun yang tersedia. Misalnya -

#!/usr/bin/ruby

digits = Array(0..9)
num = digits.at(6)
puts "#{num}"

Ini akan menghasilkan hasil sebagai berikut -

6
Sr.No. Metode & Deskripsi
1

array & other_array

Mengembalikan larik baru yang berisi elemen yang sama untuk dua larik, tanpa duplikat.

2

array * int [or] array * str

Mengembalikan larik baru yang dibangun dengan menggabungkan salinan int diri. Dengan argumen String, setara dengan self.join (str).

3

array + other_array

Mengembalikan larik baru yang dibangun dengan menggabungkan dua larik bersama-sama untuk menghasilkan larik ketiga.

4

array - other_array

Mengembalikan larik baru yang merupakan salinan dari larik asli, menghapus item apa pun yang juga muncul di larik_lain.

5

array <=> other_array

Membandingkan str dengan other_str, mengembalikan -1 (kurang dari), 0 (sama dengan), atau 1 (lebih besar dari). Perbandingannya peka huruf besar / kecil.

6

array | other_array

Mengembalikan larik baru dengan menggabungkan larik dengan other_array, menghapus duplikat.

7

array << obj

Mendorong objek yang diberikan ke akhir larik. Ekspresi ini mengembalikan larik itu sendiri, jadi beberapa tambahan dapat dirangkai bersama.

8

array <=> other_array

Mengembalikan integer (-1, 0, atau +1) jika larik ini lebih kecil dari, sama dengan, atau lebih besar dari larik_lain.

9

array == other_array

Dua array sama jika mereka berisi jumlah elemen yang sama dan jika setiap elemen sama dengan (menurut Object. ==) elemen terkait dalam array lainnya.

10

array[index] [or] array[start, length] [or]

array[range] [or] array.slice(index) [or]

array.slice(start, length) [or] array.slice(range)

Mengembalikan elemen pada indeks , atau mengembalikan subarray yang dimulai dari awal dan berlanjut untuk elemen panjang , atau mengembalikan subarray yang ditentukan oleh rentang . Indeks negatif dihitung mundur dari akhir larik (-1 adalah elemen terakhir). Mengembalikan nihil jika indeks (atau indeks awal) di luar rentang.

11

array[index] = obj [or]

array[start, length] = obj or an_array or nil [or]

array[range] = obj or an_array or nil

Menyetel elemen pada indeks , atau mengganti sub larik yang dimulai dari awal dan berlanjut untuk elemen panjang , atau mengganti sub larik yang ditentukan oleh rentang . Jika indeks lebih besar dari kapasitas larik saat ini, larik tumbuh secara otomatis. Indeks negatif akan dihitung mundur dari akhir larik. Menyisipkan elemen jika panjangnya nol. Jika nil digunakan dalam bentuk kedua dan ketiga, menghapus elemen dari self .

12

array.abbrev(pattern = nil)

Menghitung kumpulan singkatan yang tidak ambigu untuk string di dirinya sendiri . Jika melewati pola atau string, hanya string yang cocok dengan pola atau dimulai dengan string yang dipertimbangkan.

13

array.assoc(obj)

Pencarian melalui sebuah array yang elemennya juga merupakan array yang membandingkan obj dengan elemen pertama dari setiap array berisi menggunakan obj. ==. Mengembalikan larik berisi pertama yang cocok atau nol jika tidak ada kecocokan yang ditemukan.

14

array.at(index)

Mengembalikan elemen pada indeks. Indeks negatif dihitung dari akhir diri. Mengembalikan nihil jika indeks di luar rentang.

15

array.clear

Menghapus semua elemen dari array.

16

array.collect { |item| block } [or]

array.map { |item| block }

Memanggil blok sekali untuk setiap elemen diri . Membuat array baru yang berisi nilai yang dikembalikan oleh blok.

17

array.collect! { |item| block } [or]

array.map! { |item| block }

Memanggil blok satu kali untuk setiap elemen diri , mengganti elemen dengan nilai yang dikembalikan oleh blok .

18

array.compact

Mengembalikan salinan diri dengan semua elemen nihil dihapus.

19

array.compact!

Menghapus elemen nil dari array. Mengembalikan nihil jika tidak ada perubahan yang dilakukan.

20

array.concat(other_array)

Menambahkan elemen dalam other_array ke self .

21

array.delete(obj) [or]

array.delete(obj) { block }

Menghapus item dari diri yang sama dengan obj . Jika item tidak ditemukan, mengembalikan nihil . Jika blok kode opsional diberikan, kembalikan hasil blok jika item tidak ditemukan.

22

array.delete_at(index)

Menghapus elemen pada indeks yang ditentukan , mengembalikan elemen tersebut, atau nihil jika indeks di luar rentang.

23

array.delete_if { |item| block }

Menghapus setiap elemen self yang dinilai bloknya sebagai true.

24

array.each { |item| block }

Panggilan memblokir satu kali untuk setiap elemen di dirinya sendiri , meneruskan elemen itu sebagai parameter.

25

array.each_index { |index| block }

Sama seperti Array # masing-masing, tetapi meneruskan indeks elemen, bukan elemen itu sendiri.

26

array.empty?

Mengembalikan nilai benar jika larik mandiri tidak berisi elemen.

27

array.eql?(other)

Mengembalikan nilai true jika array dan lainnya adalah objek yang sama, atau keduanya adalah array dengan konten yang sama.

28

array.fetch(index) [or]

array.fetch(index, default) [or]

array.fetch(index) { |index| block }

Mencoba mengembalikan elemen pada indeks posisi . Jika indeks berada di luar larik, formulir pertama menampilkan pengecualian IndexError , formulir kedua mengembalikan default , dan formulir ketiga mengembalikan nilai blok pemanggilan , meneruskan indeks . Nilai negatif hitungan indeks dari akhir larik.

29

array.fill(obj) [or]

array.fill(obj, start [, length]) [or]

array.fill(obj, range) [or]

array.fill { |index| block } [or]

array.fill(start [, length] ) { |index| block } [or]

array.fill(range) { |index| block }

Tiga bentuk pertama mengatur elemen diri yang dipilih menjadi obj . Awal dari nol sama dengan nol. Panjang nol setara dengan panjang diri . Tiga formulir terakhir mengisi larik dengan nilai blok. The blok dilewatkan dengan indeks mutlak setiap elemen untuk diisi.

30

array.first [or]

array.first(n)

Mengembalikan elemen pertama, atau n elemen pertama , dari larik. Jika larik kosong, formulir pertama mengembalikan nihil , dan formulir kedua mengembalikan larik kosong.

31

array.flatten

Mengembalikan larik baru yang merupakan perataan satu dimensi dari larik ini (secara rekursif).

32

array.flatten!

Meratakan array pada tempatnya. Mengembalikan nihil jika tidak ada modifikasi yang dilakukan. (array tidak berisi subarray.)

33

array.frozen?

Mengembalikan nilai benar jika larik dibekukan (atau dibekukan sementara saat diurutkan).

34

array.hash

Menghitung kode hash untuk array. Dua larik dengan konten yang sama akan memiliki kode hash yang sama.

35

array.include?(obj)

Mengembalikan nilai benar jika obj ada dalam diri , salah jika sebaliknya.

36

array.index(obj)

Mengembalikan indeks objek pertama dalam diri yaitu == menjadi obj. Mengembalikan nihil jika tidak ditemukan kecocokan.

37

array.indexes(i1, i2, ... iN) [or]

array.indices(i1, i2, ... iN)

Metode ini tidak digunakan lagi di versi Ruby terbaru, jadi gunakan Array # values_at.

38

array.indices(i1, i2, ... iN) [or]

array.indexes(i1, i2, ... iN)

Metode ini tidak digunakan lagi di versi Ruby terbaru, jadi gunakan Array # values_at.

39

array.insert(index, obj...)

Menyisipkan nilai yang diberikan sebelum elemen dengan indeks yang diberikan (yang mungkin negatif).

40

array.inspect

Membuat versi larik yang dapat dicetak.

41

array.join(sep = $,)

Mengembalikan string yang dibuat dengan mengonversi setiap elemen larik menjadi string, dipisahkan dengan sep .

42

array.last [or] array.last(n)

Mengembalikan elemen diri terakhir . Jika array kosong , bentuk pertama mengembalikan nihil .

43

array.length

Mengembalikan jumlah elemen dalam diri . Mungkin nol.

44

array.map { |item| block } [or]

array.collect { |item| block }

Memanggil blok sekali untuk setiap elemen diri . Membuat array baru yang berisi nilai-nilai yang dikembalikan oleh blok.

45

array.map! { |item| block } [or]

array.collect! { |item| block }

Memanggil blok sekali untuk setiap elemen larik , mengganti elemen dengan nilai yang dikembalikan oleh blok.

46

array.nitems

Mengembalikan jumlah elemen bukan nol dalam diri . Mungkin nol.

47

array.pack(aTemplateString)

Mengemas konten array ke dalam urutan biner sesuai dengan arahan di TemplateString. Perintah A, a, dan Z dapat diikuti dengan hitungan, yang memberikan lebar bidang yang dihasilkan. Arahan yang tersisa juga mungkin menghitung, menunjukkan jumlah elemen larik yang akan dikonversi. Jika hitungannya adalah asterisk (*), semua elemen array yang tersisa akan dikonversi. Salah satu arahan masih dapat diikuti dengan garis bawah (_) untuk menggunakan ukuran asli platform yang mendasari untuk tipe yang ditentukan; jika tidak, mereka menggunakan ukuran platform independen. Spasi diabaikan dalam string template.

48

array.pop

Menghapus elemen terakhir dari larik dan mengembalikannya, atau nihil jika larik kosong.

49

array.push(obj, ...)

Mendorong (menambahkan) obj yang diberikan ke akhir larik ini. Ekspresi ini mengembalikan larik itu sendiri, jadi beberapa tambahan dapat dirangkai bersama.

50

array.rassoc(key)

Pencarian melalui larik yang elemennya juga merupakan larik. Membandingkan kunci dengan elemen kedua dari setiap larik berisi menggunakan ==. Mengembalikan larik tertampung pertama yang cocok.

51

array.reject { |item| block }

Mengembalikan sebuah array baru yang berisi item array yang yang blok tidak benar .

52

array.reject! { |item| block }

Menghapus elemen dari larik yang dievaluasi bloknya sebagai true , tetapi mengembalikan nihil jika tidak ada perubahan yang dibuat. Setara dengan Array # delete_if.

53

array.replace(other_array)

Mengganti konten array dengan konten other_array , memotong atau memperluas jika perlu.

54

array.reverse

Mengembalikan larik baru yang berisi elemen larik dalam urutan terbalik.

55

array.reverse!

Membalikkan larik di tempat.

56

array.reverse_each {|item| block }

Sama seperti Array # masing-masing, tetapi melintasi array dalam urutan terbalik.

57

array.rindex(obj)

Mengembalikan indeks objek terakhir dalam larik == ke obj. Mengembalikan nihil jika tidak ditemukan kecocokan.

58

array.select {|item| block }

Memanggil blok yang meneruskan elemen berurutan dari larik, mengembalikan larik yang berisi elemen-elemen tersebut yang blok mengembalikan nilai sebenarnya .

59

array.shift

Mengembalikan elemen pertama dari diri dan menghapusnya (menggeser semua elemen lainnya ke bawah satu per satu). Mengembalikan nihil jika array kosong.

60

array.size

Mengembalikan panjang larik (jumlah elemen). Alias ​​untuk panjangnya.

61

array.slice(index) [or] array.slice(start, length) [or]

array.slice(range) [or] array[index] [or]

array[start, length] [or] array[range]

Mengembalikan elemen pada indeks , atau mengembalikan subarray yang dimulai dari awal dan berlanjut untuk elemen panjang , atau mengembalikan subarray yang ditentukan oleh rentang . Indeks negatif dihitung mundur dari akhir larik (-1 adalah elemen terakhir). Mengembalikan nihil jika indeks (atau indeks awal) di luar rentang.

62

array.slice!(index) [or] array.slice!(start, length) [or]

array.slice!(range)

Menghapus elemen yang diberikan oleh indeks (opsional dengan panjang) atau rentang . Mengembalikan objek yang dihapus, subarray, atau nil jika indeks di luar jangkauan.

63

array.sort [or] array.sort { | a,b | block }

Mengembalikan larik baru yang dibuat dengan mengurutkan sendiri.

64

array.sort! [or] array.sort! { | a,b | block }

Mengurutkan diri sendiri.

65

array.to_a

Mengembalikan diri . Jika dipanggil pada subclass Array , ubah receiver menjadi objek Array.

66

array.to_ary

Mengembalikan diri.

67

array.to_s

Mengembalikan self.join.

68

array.transpose

Mengasumsikan bahwa diri adalah larik larik dan mengubah urutan baris dan kolom.

69

array.uniq

Mengembalikan larik baru dengan menghapus nilai duplikat dalam larik .

70

array.uniq!

Menghapus elemen duplikat dari diri sendiri . Mengembalikan nihil jika tidak ada perubahan yang dibuat (yaitu, tidak ada duplikat yang ditemukan).

71

array.unshift(obj, ...)

Tambahkan objek ke depan array, elemen lain di atas satu.

72

array.values_at(selector,...)

Mengembalikan larik yang berisi elemen yang sesuai dengan selektor yang ditentukan (satu atau lebih). Selektor dapat berupa indeks atau rentang integer.

73

array.zip(arg, ...) [or]

array.zip(arg, ...){ | arr | block }

Mengonversi argumen apa pun menjadi larik, lalu menggabungkan elemen larik dengan elemen yang sesuai dari setiap argumen.

Array pack Directive

Sr.No. Petunjuk & Deskripsi
1

@

Pindah ke posisi absolut.

2

A

String ASCII (spasi empuk, hitungan lebar).

3

a

String ASCII (kosong nol, hitungan lebar).

4

B

string (urutan bit menurun).

5

b

String bit (urutan bit naik).

6

C

Karakter tak bertanda tangan.

7

c

Arang.

8

D, d

Float presisi ganda, format asli.

9

E

Float presisi ganda, urutan byte little-endian.

10

e

Float presisi tunggal, urutan byte little-endian.

11

F, f

Float presisi tunggal, format asli.

12

G

Float presisi ganda, urutan byte jaringan (big-endian).

13

g

Float presisi tunggal, urutan byte jaringan (big-endian).

14

H

String hex (gigitan tinggi dulu).

15

h

String heksa (gigit rendah dulu).

16

I

Integer tak bertanda tangan.

17

i

Bilangan bulat.

18

L

Tak bertanda tangan panjang.

19

l

Panjang.

20

M

Dikutip dapat dicetak, pengkodean MIME (lihat RFC 2045).

21

m

String berenkode Base64.

22

N

Urutan byte jaringan (big-endian) panjang.

23

n

Urutan byte jaringan (big-endian) pendek.

24

P

Pointer ke struktur (string dengan panjang tetap).

25

p

Pointer ke string yang diakhiri null.

26

Q, q

Angka 64-bit.

27

S

Pendek tak bertanda tangan.

28

s

Pendek.

29

U

UTF-8.

30

u

String berenkode UU.

31

V

Urutan byte yang panjang, little-endian.

32

v

Urutan byte pendek, little-endian.

33

w

Integer terkompresi BER \ fnm.

34

X

Cadangkan satu byte.

35

x

Byte nol.

36

Z

Sama seperti a, kecuali null ditambahkan dengan *.

Contoh

Coba contoh berikut untuk mengemas berbagai data.

a = [ "a", "b", "c" ]
n = [ 65, 66, 67 ]
puts a.pack("A3A3A3")   #=> "a  b  c  "
puts a.pack("a3a3a3")   #=> "a\000\000b\000\000c\000\000"
puts n.pack("ccc")      #=> "ABC"

Ini akan menghasilkan hasil sebagai berikut -

a  b  c
abc
ABC