एफ # - म्यूटेबल सूची

List<'T> वर्ग वस्तुओं की एक दृढ़ता से टाइप की गई सूची का प्रतिनिधित्व करता है जिसे सूचकांक द्वारा एक्सेस किया जा सकता है।

यह सूची वर्ग का एक परस्पर समकक्ष है। यह सरणियों के समान है, क्योंकि इसे एक सूचकांक द्वारा एक्सेस किया जा सकता है, हालांकि, सरणियों के विपरीत, सूचियों का आकार बदला जा सकता है। इसलिए आपको घोषणा के दौरान एक आकार निर्दिष्ट करने की आवश्यकता नहीं है।

एक उत्परिवर्ती सूची बनाना

सूची का उपयोग कर बनाई गई हैं newकीवर्ड और सूची के निर्माता को कॉल करना। निम्न उदाहरण यह प्रदर्शित करता है -

(* Creating a List *)
open System.Collections.Generic

let booksList = new List<string>()
booksList.Add("Gone with the Wind")
booksList.Add("Atlas Shrugged")
booksList.Add("Fountainhead")
booksList.Add("Thornbirds")
booksList.Add("Rebecca")
booksList.Add("Narnia")

booksList |> Seq.iteri (fun index item -> printfn "%i: %s" index booksList.[index])

जब आप प्रोग्राम को संकलित और निष्पादित करते हैं, तो यह निम्न आउटपुट देता है -

0: Gone with the Wind
1: Atlas Shrugged
2: Fountainhead
3: Thornbirds
4: Rebecca
5: Narnia

सूची (टी) वर्ग

सूची (टी) वर्ग उन वस्तुओं की एक दृढ़ता से टाइप की गई सूची का प्रतिनिधित्व करता है जिन्हें सूचकांक द्वारा एक्सेस किया जा सकता है। यह सूचियों को खोजने, छांटने और हेरफेर करने के तरीके प्रदान करता है।

निम्न तालिकाएँ गुण, निर्माता और सूची (T) वर्ग की विधियाँ प्रदान करती हैं -

गुण

संपत्ति विवरण
क्षमता हो जाता है या आंतरिक डेटा संरचना को आकार दिए बिना उन तत्वों की कुल संख्या को निर्धारित करता है जो पकड़ सकते हैं।
गिनती सूची (T) में निहित तत्वों की संख्या प्राप्त करता है।
मद निर्दिष्ट इंडेक्स पर तत्व प्राप्त या सेट करता है।

कंस्ट्रक्टर्स

निर्माता विवरण
सूची (टी) () सूची (T) श्रेणी का एक नया उदाहरण प्रारंभ करता है जो रिक्त है और डिफ़ॉल्ट प्रारंभिक क्षमता है।
सूची (टी) (IEnumerable (टी)) सूची (T) वर्ग का एक नया उदाहरण शुरू करता है जिसमें निर्दिष्ट संग्रह से कॉपी किए गए तत्व होते हैं और कॉपी किए गए तत्वों की संख्या को समायोजित करने की पर्याप्त क्षमता होती है।
सूची (टी) (Int32) सूची (T) श्रेणी का एक नया उदाहरण प्रारंभ करता है जो खाली है और इसमें निर्दिष्ट प्रारंभिक क्षमता है।

तरीका

तरीकों विवरण
जोड़ना सूची (T) के अंत में एक वस्तु जोड़ता है।
AddRange सूची (टी) के अंत में निर्दिष्ट संग्रह के तत्वों को जोड़ता है।
AsReadOnly वर्तमान संग्रह के लिए केवल पढ़ने के लिए IList (T) रैपर देता है।
BinarySearch (टी) डिफ़ॉल्ट तुलना करने वाले तत्व का उपयोग करके संपूर्ण सॉर्ट की गई सूची (T) को खोजता है और तत्व के शून्य-आधारित सूचकांक को लौटाता है।
बाइनरीसर्च (T, IComparer (T)) निर्दिष्ट तुलनित्र का उपयोग करने वाले तत्व के लिए संपूर्ण क्रमबद्ध सूची (T) को खोजता है और तत्व के शून्य-आधारित सूचकांक को लौटाता है।
बाइनरीसर्च (Int32, Int32, T, IComparer (T)) निर्दिष्ट तुलनित्र का उपयोग करते हुए तत्व के लिए क्रमबद्ध सूची (T) में कई तत्वों को खोजता है और तत्व के शून्य-आधारित सूचकांक को लौटाता है।
स्पष्ट सूची (T) से सभी तत्वों को निकालता है।
शामिल यह निर्धारित करता है कि कोई तत्व सूची (T) में है या नहीं।
ConvertAll (TOutput) वर्तमान सूची (T) में तत्वों को दूसरे प्रकार में परिवर्तित करता है, और एक सूची देता है जिसमें परिवर्तित तत्व होते हैं।
CopyTo (टी []) लक्ष्य सूची की शुरुआत में एक संगत एक-आयामी सरणी में संपूर्ण सूची (T) की प्रतिलिपि बनाता है।
CopyTo (T [], Int32) संपूर्ण सूची (T) को एक संगत आयामी आयाम में कॉपी करता है, जो लक्ष्य सरणी के निर्दिष्ट सूचकांक पर शुरू होता है।
CopyTo (Int32, T [], Int32, Int32) टारगेट के निर्दिष्ट इंडेक्स पर शुरू करते हुए लिस्ट (T) से तत्वों की एक श्रृंखला को एक संगत डायमेंशनल सरणी में कॉपी करता है।
बराबरी (वस्तु) निर्धारित करता है कि निर्दिष्ट वस्तु वर्तमान वस्तु के बराबर है या नहीं। (ऑब्जेक्ट से निहित)
मौजूद निर्धारित करता है कि सूची (T) में ऐसे तत्व हैं जो निर्दिष्ट विधेय द्वारा परिभाषित शर्तों से मेल खाते हैं।
अंतिम रूप किसी ऑब्जेक्ट को कचरा संग्रह (ऑब्जेक्ट से इनहेरिट) द्वारा पुनर्प्राप्त करने से पहले संसाधनों को मुक्त करने और अन्य सफाई कार्यों को करने की अनुमति देता है।
खोज एक तत्व की खोज करता है जो निर्दिष्ट विधेय द्वारा परिभाषित शर्तों से मेल खाता है, और संपूर्ण सूची (T) के भीतर पहली घटना देता है।
सब ढूँढ़ो निर्दिष्ट प्रेडिक्ट द्वारा परिभाषित शर्तों से मेल खाने वाले सभी तत्वों को पुनः प्राप्त करता है।
FindIndex (विधेय (टी)) एक तत्व की खोज करता है जो निर्दिष्ट विधेय द्वारा परिभाषित शर्तों से मेल खाता है, और पूरी सूची (टी) के भीतर पहली घटना के शून्य-आधारित सूचकांक को वापस करता है।
FindIndex (Int32, Predicate (T)) एक तत्व के लिए खोज जो निर्दिष्ट विधेय द्वारा परिभाषित शर्तों से मेल खाती है, और सूची (टी) में तत्वों की सीमा के भीतर पहली घटना के शून्य-आधारित सूचकांक को वापस करती है जो निर्दिष्ट सूचकांक से अंतिम तत्व तक फैली हुई है।
FindIndex (Int32, Int32, Predicate (T)) एक तत्व के लिए खोज जो निर्दिष्ट विधेय द्वारा परिभाषित शर्तों से मेल खाती है, और सूची (टी) में तत्वों की सीमा के भीतर पहली घटना के शून्य-आधारित सूचकांक को वापस करती है जो निर्दिष्ट सूचकांक पर शुरू होती है और इसमें तत्वों की निर्दिष्ट संख्या होती है।
FindLast एक तत्व की खोज करता है जो निर्दिष्ट विधेय द्वारा परिभाषित शर्तों से मेल खाता है, और संपूर्ण सूची (T) के भीतर अंतिम घटना देता है।
FindLastIndex (विधेय (टी)) एक तत्व की खोज करता है जो निर्दिष्ट विधेय द्वारा परिभाषित शर्तों से मेल खाता है, और संपूर्ण सूची (टी) के भीतर अंतिम घटना के शून्य-आधारित सूचकांक को लौटाता है।
FindLastIndex (Int32, Predicate (T)) एक तत्व के लिए खोज जो निर्दिष्ट विधेय द्वारा परिभाषित शर्तों से मेल खाती है, और सूची (T) में तत्वों की सीमा के भीतर अंतिम घटना के शून्य-आधारित सूचकांक को वापस करती है जो पहले तत्व से निर्दिष्ट सूचकांक तक फैली हुई है।
FindLastIndex (Int32, Int32, Predicate (T)) एक तत्व के लिए खोज जो निर्दिष्ट विधेय द्वारा परिभाषित शर्तों से मेल खाती है, और सूची (टी) में तत्वों की सीमा के भीतर अंतिम घटना का शून्य-आधारित सूचकांक लौटाता है जिसमें तत्वों की निर्दिष्ट संख्या होती है और निर्दिष्ट सूचकांक पर समाप्त होती है।
प्रत्येक के लिए सूची (टी) के प्रत्येक तत्व पर निर्दिष्ट कार्रवाई करता है।
GetEnumerator एक एन्यूमरेटर लौटाता है जो सूची (टी) के माध्यम से पुनरावृत्त करता है।
GetHashCode डिफ़ॉल्ट हैश फ़ंक्शन के रूप में कार्य करता है। (ऑब्जेक्ट से निहित)
GetRange स्रोत सूची (T) में तत्वों की एक श्रेणी की उथली प्रतिलिपि बनाता है।
GetType वर्तमान उदाहरण के प्रकार प्राप्त होते हैं। (ऑब्जेक्ट से निहित)
IndexOf (टी) निर्दिष्ट ऑब्जेक्ट के लिए खोज करता है और संपूर्ण सूची (T) के भीतर पहली घटना के शून्य-आधारित सूचकांक देता है।
IndexOf (T, Int32) निर्दिष्ट ऑब्जेक्ट के लिए खोज करता है और सूची (T) में तत्वों की सीमा के भीतर पहली घटना के शून्य-आधारित सूचकांक को वापस करता है जो निर्दिष्ट सूचकांक से अंतिम तत्व तक फैली हुई है।
IndexOf (T, Int32, Int32) निर्दिष्ट ऑब्जेक्ट के लिए खोज करता है और सूची (T) में तत्वों की सीमा के भीतर पहली घटना के शून्य-आधारित सूचकांक को लौटाता है जो निर्दिष्ट सूचकांक पर शुरू होता है और इसमें तत्वों की निर्दिष्ट संख्या होती है।
डालने निर्दिष्ट तर्ज पर सूची (T) में एक तत्व सम्मिलित करता है।
InsertRange एक सूची के तत्वों को निर्दिष्ट सूचकांक में सूची (टी) में सम्मिलित करता है।
LastIndexOf (टी) निर्दिष्ट ऑब्जेक्ट के लिए खोज करता है और संपूर्ण सूची (T) के भीतर अंतिम घटना का शून्य-आधारित सूचकांक देता है।
LastIndexOf (T, Int32) निर्दिष्ट ऑब्जेक्ट के लिए खोज करता है और सूची (T) में तत्वों की सीमा के भीतर अंतिम घटना का शून्य-आधारित सूचकांक लौटाता है जो पहले तत्व से निर्दिष्ट सूचकांक तक विस्तारित होता है।
LastIndexOf (T, Int32, Int32) निर्दिष्ट ऑब्जेक्ट के लिए खोज करता है और सूची (T) में तत्वों की सीमा के भीतर अंतिम घटना के शून्य-आधारित सूचकांक को वापस करता है जिसमें तत्वों की निर्दिष्ट संख्या शामिल होती है और निर्दिष्ट सूचकांक पर समाप्त होती है।
MemberwiseClone वर्तमान वस्तु की एक उथली प्रति तैयार करती है। (ऑब्जेक्ट से निहित)
हटाना किसी विशिष्ट ऑब्जेक्ट की पहली घटना को सूची (T) से निकालता है।
सभी हटाएं निर्दिष्ट predicate द्वारा परिभाषित शर्तों से मेल खाने वाले सभी तत्वों को निकालता है।
RemoveAt सूची (टी) के निर्दिष्ट सूचकांक पर तत्व को निकालता है।
RemoveRange सूची (T) से कई तत्वों को निकालता है।
उलटना() संपूर्ण सूची (T) में तत्वों के क्रम को उलट देता है।
रिवर्स (Int32, Int32) निर्दिष्ट सीमा में तत्वों के क्रम को उलट देता है।
क्रमबद्ध करें () डिफ़ॉल्ट सूची का उपयोग करके संपूर्ण सूची (T) में तत्वों को जोड़ता है।
क्रमबद्ध करें (तुलना (टी)) निर्दिष्ट सिस्टम का उपयोग करके संपूर्ण सूची (T) में तत्वों को सॉर्ट करता है। तुलना (टी)।
क्रमबद्ध करें (IComparer (टी)) निर्दिष्ट सूची का उपयोग करके संपूर्ण सूची (T) में तत्वों को जोड़ता है।
क्रमबद्ध करें (Int32, Int32, IComparer (T)) तत्वों की एक श्रृंखला में तत्वों की सूची निर्दिष्ट टी का उपयोग करके (टी) को भेजता है।
toArray सूची (T) के तत्वों को एक नए सरणी में कॉपी करता है।
तार एक स्ट्रिंग रिटर्न जो मौजूदा वस्तु का प्रतिनिधित्व करता है। (ऑब्जेक्ट से निहित)
TrimExcess सूची (T) में तत्वों की वास्तविक संख्या की क्षमता निर्धारित करता है, यदि वह संख्या एक सीमा मूल्य से कम है।
TrueForAll निर्धारित करता है कि सूची (T) में प्रत्येक तत्व निर्दिष्ट विधेय द्वारा परिभाषित शर्तों से मेल खाता है या नहीं।

उदाहरण

(* Creating a List *)
open System.Collections.Generic

let booksList = new List<string>()
booksList.Add("Gone with the Wind")
booksList.Add("Atlas Shrugged")
booksList.Add("Fountainhead")
booksList.Add("Thornbirds")
booksList.Add("Rebecca")
booksList.Add("Narnia")

printfn"Total %d books" booksList.Count
booksList |> Seq.iteri (fun index item -> printfn "%i: %s" index booksList.[index])
booksList.Insert(2, "Roots")

printfn("after inserting at index 2")
printfn"Total %d books" booksList.Count

booksList |> Seq.iteri (fun index item -> printfn "%i: %s" index booksList.[index])
booksList.RemoveAt(3)

printfn("after removing from index 3")
printfn"Total %d books" booksList.Count

booksList |> Seq.iteri (fun index item -> printfn "%i: %s" index booksList.[index])

जब आप प्रोग्राम को संकलित और निष्पादित करते हैं, तो यह निम्न आउटपुट देता है -

Total 6 books
0: Gone with the Wind
1: Atlas Shrugged
2: Fountainhead
3: Thornbirds
4: Rebecca
5: Narnia
after inserting at index 2
Total 7 books
0: Gone with the Wind
1: Atlas Shrugged
2: Roots
3: Fountainhead
4: Thornbirds
5: Rebecca
6: Narnia
after removing from index 3
Total 6 books
0: Gone with the Wind
1: Atlas Shrugged
2: Roots
3: Thornbirds
4: Rebecca
5: Narnia