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