C# : List

[".0s4*0|collections;datetime-format;list",["F@eCDNO^c","JABEIGIAMEPEJAKLMA","OOOCCSTUUUUTTUUUUYFGDRDADADADGDHDADADGDHDADADGDHDADFOBBBOBCBCOBCBOCOBCCPGDRDFADADWSTTUUUUTTUUUU","s.w.rfstd.",".NET","Array","Dictionary","List","String","2D","Async","Console","DataTable","Dates","DateTime","Enum","File","For","Foreach","Format","IEnumerable","If","IndexOf","Lambda","LINQ","Optimization","Parse","Path","Process","Property","Random","Regex","Replace","Sort","Split","Static","Substring","Switch","Tuple","While","Contains."," This method scans a List. It searches for a specific element to see if that element occurs at least once in the collection.","Contains is a useful"," method that declaratively searches. To use Contains, no for-loop is required. You can type (and maintain) less code.","First example."," We add System.Collections.Generic at the top of the source file. The Contains method is an instance method on the List type. ","Note: ","This means you can only call it on a constructed List type. The List instance can have any type parameter.","Parameters: ","The argument is the searched-for element. The LINQ Contains method accepts 2 parameters (it accepts an IEqualityComparer).","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","6227126509","data-ad-format","auto","br","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","6227126509","data-ad-format","auto","Based on:"," .NET 4.6\n\n","C# program that uses List Contains method","\n\nusing System;\nusing System.Collections.Generic;\nusing System.Linq;\n\nclass Program\n{\n static void Main()\n {","\n // Create List with three elements.\n ","var list = new ","List","<string>();\n list.Add(","\"cat\"",");\n list.Add(","\"dog\"",");\n list.Add(","\"moth\"",");","\n\n // Search for this element.\n ","if (list.","Contains","(","\"dog\"","))\n {\n Console.WriteLine(","\"dog was found\"",");\n }","\n\n // Search for this element in any string case.\n // ... This is the LINQ method with the same name.\n ","if (list.","Contains","(","\"MOTH\"",", StringComparer.OrdinalIgnoreCase))\n {\n Console.WriteLine(","\"MOTH was found (insensitive)\"",");\n }","\n\n // This element is not found.\n ","Console.WriteLine(list.","Contains","(","\"fish\"","));\n }\n}\n\n","Output","\n\ndog was found\nMOTH was found (insensitive)\nFalse","Notes, above program."," With var, a string List is constructed. Three string literal references are added to the collection's internal arrays through the Add method. ","Var ","var","String Literal ","string-literal","List Add ","list-add","Notes, continued."," The second method call uses 2 parameters. StringComparer.OrdinalIgnoreCase implements the IEqualityComparer interface. This allows an insensitive string search. ","IEqualityComparer ","iequalitycomparer","Return value: ","Contains returns a bool value type. You can store its result in a bool. You can use the Contains method as an expression.","Bool ","bool","Review: ","The example in the program shows the Contains extension being used on the List type with a case-insensitive search.","Discussion."," System.Linq is included by default in new Console applications in Visual Studio. It will allow you to call a separate Contains generic method on all IEnumerable types. ","Contains ","contains-extension","Warning: ","LINQ extension methods are often slower. They operate on the IEnumerable interface.","IEnumerable ","ienumerable","Internals."," Contains performs a linear search through the elements, starting with the first element, and uses Equals to check each element value. ","Info: ","This is often much slower than a Dictionary. The LINQ method also does a linear search.","Performance."," We benchmark the performance of List Contains and a custom for-loop on a small List. Only a few elements are searched by each method. A custom for-loop was faster. ","Benchmark ","benchmark","Tip: ","Typically writing a for-loop that does a search is faster than using a built-in method.","However: ","This approach creates extra code size, and this extra size may lead to performance decreases in larger programs.","C# program that benchmarks List Contains","\n\nusing System;\nusing System.Collections.Generic;\nusing System.Diagnostics;\n\nclass Program\n{","\n /// <summary>\n /// Custom implementation.\n /// </summary>\n ","static bool ","ContainsLoop","(List<string> list, string value)\n {\n for (int i = 0; i < list.Count; i++)\n {\n if (list[i] == value)\n {\n return true;\n }\n }\n return false;\n }\n\n const int _max = 100000000;\n static void Main()\n {\n List<string> list = new List<string>();\n list.Add(\"one\");\n list.Add(\"two\");\n list.Add(\"three\");\n list.Add(\"four\");\n list.Add(\"five\");\n\n var s1 = Stopwatch.StartNew();\n for (int i = 0; i < _max; i++)\n {\n bool f = ContainsLoop(list, \"four\");\n }\n s1.Stop();\n var s2 = Stopwatch.StartNew();\n for (int i = 0; i < _max; i++)\n {\n bool f = list.Contains(\"four\");\n }\n s2.Stop();\n Console.WriteLine(((double)(s1.Elapsed.TotalMilliseconds * 1000000) /\n _max).ToString(\"0.00 ns\"));\n Console.WriteLine(((double)(s2.Elapsed.TotalMilliseconds * 1000000) /\n _max).ToString(\"0.00 ns\"));\n Console.Read();\n }\n}\n\n","Results","\n\n","19.22 ns"," For-loop, string comparisons [ContainsLoop]\n","54.60 ns"," Contains method [Contains]","A summary."," We used the Contains method on List. We saw how this method differs from the LINQ Contains method. The methods are implemented with a forward linear search. ","br","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","3679700504","data-ad-format","link","br","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","6227126509","data-ad-format","auto"],"url()","url()","url()"]

["url()","url()","url()","url()","url()","url()"]