Elixir - ลิสต์และทูเปิล

(เชื่อมโยง) รายการ

รายการที่เชื่อมโยงคือรายการองค์ประกอบที่แตกต่างกันซึ่งจัดเก็บไว้ที่ตำแหน่งต่างๆในหน่วยความจำและจะถูกติดตามโดยใช้การอ้างอิง รายการที่เชื่อมโยงเป็นโครงสร้างข้อมูลที่ใช้โดยเฉพาะในการเขียนโปรแกรมเชิงฟังก์ชัน

Elixir ใช้วงเล็บเหลี่ยมเพื่อระบุรายการค่า ค่าสามารถเป็นประเภทใดก็ได้ -

[1, 2, true, 3]

เมื่อ Elixir เห็นรายการหมายเลข ASCII ที่พิมพ์ได้ Elixir จะพิมพ์เป็นรายการถ่าน (ตามตัวอักษรรายการ) เมื่อใดก็ตามที่คุณเห็นค่าใน IEx และไม่แน่ใจว่าคืออะไรคุณสามารถใช้ไฟล์i เพื่อดึงข้อมูลเกี่ยวกับมัน

IO.puts([104, 101, 108, 108, 111])

อักขระด้านบนในรายการสามารถพิมพ์ได้ทั้งหมด เมื่อรันโปรแกรมข้างต้นจะให้ผลลัพธ์ดังนี้ -

hello

คุณยังสามารถกำหนดรายการในทางกลับกันโดยใช้เครื่องหมายคำพูดเดี่ยว -

IO.puts(is_list('Hello'))

เมื่อรันโปรแกรมข้างต้นจะให้ผลลัพธ์ดังนี้ -

true

โปรดจำไว้ว่าการแทนค่าแบบยกเดียวและแบบยกคู่จะไม่เทียบเท่ากันใน Elixir เนื่องจากแสดงด้วยประเภทต่างๆ

ความยาวของรายการ

ในการค้นหาความยาวของรายการเราใช้ฟังก์ชัน length ดังในโปรแกรมต่อไปนี้ -

IO.puts(length([1, 2, :true, "str"]))

โปรแกรมข้างต้นสร้างผลลัพธ์ต่อไปนี้ -

4

การต่อและการลบ

สองรายการสามารถต่อกันและลบโดยใช้ ++ และ --ผู้ประกอบการ พิจารณาตัวอย่างต่อไปนี้เพื่อทำความเข้าใจฟังก์ชัน

IO.puts([1, 2, 3] ++ [4, 5, 6])
IO.puts([1, true, 2, false, 3, true] -- [true, false])

สิ่งนี้จะทำให้คุณมีสตริงที่ต่อกันในกรณีแรกและสตริงที่ลบออกในตัวที่สอง โปรแกรมข้างต้นสร้างผลลัพธ์ต่อไปนี้ -

[1, 2, 3, 4, 5, 6]
[1, 2, 3, true]

หัวและท้ายรายการ

ส่วนหัวเป็นองค์ประกอบแรกของรายการและส่วนท้ายคือส่วนที่เหลือของรายการ สามารถเรียกดูได้ด้วยฟังก์ชันhd และ tl. ให้เรากำหนดรายการให้กับตัวแปรและดึงหัวและหาง

list = [1, 2, 3]
IO.puts(hd(list))
IO.puts(tl(list))

สิ่งนี้จะทำให้เรามีส่วนหัวและส่วนท้ายของรายการเป็นผลลัพธ์ โปรแกรมข้างต้นสร้างผลลัพธ์ต่อไปนี้ -

1
[2, 3]

Note - การได้รับส่วนหัวหรือส่วนท้ายของรายการว่างเป็นข้อผิดพลาด

ฟังก์ชั่นรายการอื่น ๆ

ไลบรารีมาตรฐาน Elixir มีฟังก์ชันมากมายสำหรับจัดการกับรายการ เราจะดูบางส่วนของที่นี่ คุณสามารถตรวจสอบส่วนที่เหลือนี่รายการ

ส. ชื่อฟังก์ชันและคำอธิบาย
1

delete(list, item)

ลบรายการที่กำหนดออกจากรายการ ส่งคืนรายการที่ไม่มีรายการ หากรายการเกิดขึ้นมากกว่าหนึ่งครั้งในรายการเพียงเหตุการณ์แรกจะถูกลบออก

2

delete_at(list, index)

สร้างรายการใหม่โดยการลบค่าที่ดัชนีที่ระบุ ดัชนีเชิงลบหมายถึงการหักล้างจากส่วนท้ายของรายการ หากดัชนีอยู่นอกขอบเขตรายการเดิมจะถูกส่งกลับ

3

first(list)

ส่งคืนองค์ประกอบแรกในรายการหรือศูนย์หากรายการว่างเปล่า

4

flatten(list)

แบนรายการที่ซ้อนกันที่กำหนด

5

insert_at(list, index, value)

ส่งคืนรายการที่มีค่าแทรกที่ดัชนีที่ระบุ โปรดทราบว่าดัชนีถูกต่อยอดตามความยาวของรายการ ดัชนีเชิงลบหมายถึงการหักล้างจากส่วนท้ายของรายการ

6

last(list)

ส่งคืนองค์ประกอบสุดท้ายในรายการหรือศูนย์หากรายการว่างเปล่า

ทูเปิล

Tuples เป็นโครงสร้างข้อมูลที่เก็บโครงสร้างอื่น ๆ ไว้ภายใน ต่างจากรายการที่เก็บองค์ประกอบไว้ในบล็อกหน่วยความจำที่ต่อเนื่องกัน ซึ่งหมายความว่าการเข้าถึงองค์ประกอบทูเพิลต่อดัชนีหรือการได้ขนาดทูเพิลเป็นการดำเนินการที่รวดเร็ว ดัชนีเริ่มต้นจากศูนย์

Elixir ใช้วงเล็บปีกกาเพื่อกำหนดสิ่งที่เพิ่มขึ้น เช่นเดียวกับรายการ tuples สามารถเก็บค่าใดก็ได้ -

{:ok, "hello"}

ความยาวของทูเพิล

ในการรับความยาวของทูเปิลให้ใช้ tuple_size ฟังก์ชันดังในโปรแกรมต่อไปนี้ -

IO.puts(tuple_size({:ok, "hello"}))

โปรแกรมข้างต้นสร้างผลลัพธ์ต่อไปนี้ -

2

การต่อท้ายค่า

ในการผนวกค่าเข้ากับทูเปิลให้ใช้ฟังก์ชัน Tuple.append -

tuple = {:ok, "Hello"}
Tuple.append(tuple, :world)

สิ่งนี้จะสร้างและส่งคืนทูเพิลใหม่: {: ok, "Hello",: world}

การแทรกค่า

ในการแทรกค่าในตำแหน่งที่กำหนดเราสามารถใช้ Tuple.insert_at ฟังก์ชันหรือ put_elemฟังก์ชัน พิจารณาตัวอย่างต่อไปนี้เพื่อทำความเข้าใจสิ่งเดียวกัน -

tuple = {:bar, :baz}
new_tuple_1 = Tuple.insert_at(tuple, 0, :foo)
new_tuple_2 = put_elem(tuple, 1, :foobar)

สังเกตว่า put_elem และ insert_atส่งคืนสิ่งที่เพิ่มขึ้นใหม่ ทูเปิลเดิมที่เก็บไว้ในตัวแปรทูเปิลไม่ได้รับการแก้ไขเนื่องจากชนิดข้อมูล Elixir ไม่เปลี่ยนรูป ด้วยการไม่เปลี่ยนรูปรหัส Elixir จึงให้เหตุผลได้ง่ายขึ้นโดยที่คุณไม่ต้องกังวลว่าโค้ดใดจะเปลี่ยนโครงสร้างข้อมูลของคุณหรือไม่

Tuples กับ Lists

ความแตกต่างระหว่างลิสต์และทูเปิลคืออะไร?

รายการจะถูกเก็บไว้ในหน่วยความจำเป็นรายการที่เชื่อมโยงซึ่งหมายความว่าแต่ละองค์ประกอบในรายการจะเก็บค่าและชี้ไปที่องค์ประกอบต่อไปนี้จนกว่าจะถึงจุดสิ้นสุดของรายการ เราเรียกแต่ละคู่ของมูลค่าและตัวชี้เซลล์ข้อเสีย ซึ่งหมายความว่าการเข้าถึงความยาวของรายการเป็นการดำเนินการเชิงเส้นเราจำเป็นต้องสำรวจรายการทั้งหมดเพื่อหาขนาดของรายการ การอัปเดตรายการทำได้รวดเร็วตราบเท่าที่เรากำลังเตรียมองค์ประกอบไว้ล่วงหน้า

ในทางกลับกัน Tuples จะถูกจัดเก็บไว้ในหน่วยความจำอย่างต่อเนื่อง ซึ่งหมายความว่าการรับขนาดทูเพิลหรือการเข้าถึงองค์ประกอบโดยดัชนีนั้นรวดเร็ว อย่างไรก็ตามการอัปเดตหรือเพิ่มองค์ประกอบให้กับทูเพิลมีราคาแพงเนื่องจากต้องคัดลอกทูเพิลทั้งหมดในหน่วยความจำ