C#

[".0s4*0|collections;datetime-format;.",["FCeDI^","LEJGEEQPICIAJAEEOIIAEEKAJEEGLLLAFIOGLAIEKCLAPKJGIGIAOIOLEGBEDEEEBEMEQGLEBEMA","OOOCCSTUUUUTTUUUUYFHDADADADADOCCOBPADADGDHDADADGDHDADFOBPADADGDHDADGDGDHDADGDGDFOBOBOBCCPGRDADADADADGHDADGHDADFOBOCPRDADADADADGDHDGDADFOCPHDADADADGDRDGDRDFRDRDOBOCPGDHDRDRDGDRDFOCBCBPRDRDHDFOBCCPRDRDHDGDFOCCPHDGDGDFOBCBOBOCCPRDRDHDRDGDHDRDGDOBOCBOCBCBOBBOCCOCPRDHDRDGDFOBOBOBOBOBOBOBOBOBOCCIBOWSTTUUUUTTUUUU",".rwsl.t.t..rs.fj.sdrf.sss.r.",".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","Dictionary."," In a city many buildings are found. To find a structure we can search the entire city, street by street. But this becomes slow.","With a Dictionary,"," we can map a building to a location. We can map \"park\" to where it is found. Then to find the park, we can skip searching the whole city.","An example."," We add 4 keys with values to a Dictionary. Then we look inside it with the Visual Studio debugger. The Dictionary has pairs of keys and values. ","String, int: ","Dictionary is used with different elements. We specify its key type and its value type (string, int).","Output: ","The example program has no output: it does nothing useful. At least it does not crash.","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 Add method","\n\nusing System;\nusing System.Collections.Generic;\n\nclass Program\n{\n static void Main()\n {\n ","Dictionary","<string, int> dictionary =\n new Dictionary<string, int>();\n\n dictionary.Add(","\"cat\"",", 2);\n dictionary.Add(","\"dog\"",", 1);\n dictionary.Add(","\"llama\"",", 0);\n dictionary.Add(","\"iguana\"",", -1);\n }\n}","Debugger."," Let us peek inside the Visual Studio debugger to examine the memory. The Dictionary instance is represented by a collection of key and value pairs. ","Note: ","It is fun (and perhaps helpful) to open and close the data structure elements. Learning often involves experimentation.","Tip: ","The pairs like (dog, 1) are the string representations of KeyValuePair instances. KeyValuePair is a struct.","ContainsKey."," This sees if a given string is present in a Dictionary. We use string keys here\u2014we look at more types of Dictionaries further on. ContainsKey returns true if the key is found. ","ContainsKey ","containskey","C# program that uses ContainsKey","\n\nusing System;\nusing System.Collections.Generic;\n\nclass Program\n{\n static void Main()\n {\n Dictionary<string, int> dictionary =\n new Dictionary<string, int>();\n\n dictionary.Add(","\"apple\"",", 1);\n dictionary.Add(","\"windows\"",", 5);","\n\n // See whether Dictionary contains this string.\n ","if (dictionary.","ContainsKey","(","\"apple\"","))\n {\n int value = dictionary[","\"apple\"","];\n Console.WriteLine(value);\n }","\n\n // See whether it contains this string.\n ","if (!dictionary.","ContainsKey","(","\"acorn\"","))\n {\n Console.WriteLine(false);\n }\n }\n}\n\n","Output","\n\n1\nFalse","TryGetValue."," This is often the most efficient look up method. As the name TryGetValue implies, it tests for the key. It then returns the value if it finds the key. ","TryGetValue ","trygetvalue","C# program that uses TryGetValue","\n\nusing System;\nusing System.Collections.Generic;\n\nclass Program\n{\n static void Main()\n {\n Dictionary<string, string> values =\n new Dictionary<string, string>();\n\n values.Add(","\"cat\"",", \"feline\");\n values.Add(","\"dog\"",", \"canine\");","\n // Use TryGetValue.\n ","string test;\n if (values.","TryGetValue","(","\"cat\"",", out test))"," // Returns true.\n ","{\n Console.WriteLine(test);"," // This is the value at cat.\n ","}\n if (values.","TryGetValue","(","\"bird\"",", out test))"," // Returns false.\n ","{\n Console.WriteLine(false);"," // Not reached.\n ","}\n }\n}\n\n","Output","\n\nfeline","KeyValuePair."," When a collection that implements IDictionary (like Dictionary) is used in a foreach-loop, it returns an enumeration. A Dictionary will return KeyValuePair structs in a loop. ","KeyValuePair ","keyvaluepair","KeyNotFoundException."," This error happens when we access a nonexistent key. With Dictionary we must test keys for existence first, with ContainsKey or TryGetValue. ","KeyNotFoundException ","keynotfoundexception","Loop."," Here we loop over KeyValuePairs in a Dictionary. With collections like Dictionary, we must always know the value types. With each KeyValuePair, there is a Key member and Value member. ","Foreach ","foreach","String, int: ","The code creates a Dictionary with string keys and int values. The Dictionary stores animal counts.","Tip: ","In the foreach-loop, each KeyValuePair has two members, a string Key and an int Value.","C# program that uses foreach on Dictionary","\n\nusing System;\nusing System.Collections.Generic;\n\nclass Program\n{\n static void Main()\n {","\n // Example Dictionary again.\n ","Dictionary<string, int>"," d = new Dictionary<string, int>()\n {\n {","\"cat\"",", 2},\n {","\"dog\"",", 1},\n {","\"llama\"",", 0},\n {","\"iguana\"",", -1}\n };","\n // Loop over pairs with foreach.\n ","foreach"," (KeyValuePair<string, int> pair in d)\n {\n Console.WriteLine(","\"{0}, {1}\"",", pair.Key, pair.Value);\n }","\n // Use var keyword to enumerate dictionary.\n ","foreach"," (var pair in d)\n {\n Console.WriteLine(","\"{0}, {1}\"",", pair.Key, pair.Value);\n }\n }\n}\n\n","Output","\n\ncat, 2\ndog, 1\nllama, 0\niguana, -1\n\ncat, 2\ndog, 1\nllama, 0\niguana, -1","Var keyword."," The final loop in the above code uses var. This reduces the amount of typing required. And it may make code easier to read for humans (like us). ","Var: Dictionary ","var","Keys."," Here we use the Keys property. We then look through each key and look up the values. This method is slower but has the same results. ","KeyCollection: ","The Keys property returns a collection of type KeyCollection, not an actual List. We can convert it into a List.","C# program that gets Keys","\n\nusing System;\nusing System.Collections.Generic;\n\nclass Program\n{\n static void Main()\n {\n ","Dictionary<string, int>"," d = new Dictionary<string, int>()\n {\n {","\"cat\"",", 2},\n {","\"dog\"",", 1},\n {","\"llama\"",", 0},\n {","\"iguana\"",", -1}\n };","\n // Store keys in a List.\n ","List<string> list = new List<string>(d.","Keys",");","\n // Loop through list.\n ","foreach (string k in list)\n {\n Console.WriteLine(","\"{0}, {1}\"",", k, d[k]);\n }\n }\n}\n\n","Output","\n\ncat, 2\ndog, 1\nllama, 0\niguana, -1","Foreach, benchmark."," Here we compare loops. A foreach-loop on KeyValuePairs is faster than the looping over Keys and accessing values in the loop body. ","Tip: ","When possible, loop over the pairs in a Dictionary directly. Eliminating lookups will improve performance.","C# program that benchmarks for each on Dictionary","\n\nusing System;\nusing System.Collections.Generic;\nusing System.Diagnostics;\n\nclass Program\n{\n static void Main()\n {\n var test = new ","Dictionary","<string, int>();\n test[","\"bird\"","] = 10;\n test[","\"frog\"","] = 20;\n test[","\"cat\"","] = 60;\n int sum = 0;\n const int _max = 1000000;","\n\n // Version 1: use foreach loop directly on Dictionary.\n ","var s1 = Stopwatch.StartNew();\n for (int i = 0; i < _max; i++)\n {\n ","foreach"," (var pair in test)\n {\n sum += pair.Value;\n }\n }\n s1.Stop();","\n\n // Version 2: use foreach loop on Keys, then access values.\n ","var s2 = Stopwatch.StartNew();\n for (int i = 0; i < _max; i++)\n {\n ","foreach"," (var key in test.Keys)\n {\n sum += test[key];\n }\n }\n s2.Stop();\n Console.WriteLine(s1.Elapsed.TotalMilliseconds);\n Console.WriteLine(s2.Elapsed.TotalMilliseconds);\n }\n}\n\n","Results","\n\n","28.117 ms"," Dictionary foreach (measured January 2017)\n","83.3468 ms"," Keys foreach (measured January 2017)","Sort."," A Dictionary cannot be directly sorted. But we can take its Keys and then sort those in a separate List collection. A query expression may also be used. ","Sort Dictionary ","sort-dictionary","Types."," Dictionary is a generic class. To use it, we must specify a type. This is a good feature. It means we can use an int key just as easily as a string key. ","Int: ","In this program, we see an example of a Dictionary with int keys. The values can also be any type.","C# that uses int keys","\n\nusing System;\nusing System.Collections.Generic;\n\nclass Program\n{\n static void Main()\n {","\n // Use a Dictionary with an int key.\n ","Dictionary<int, string> dict = new ","Dictionary","<int, string>();\n dict.Add(","100",", \"Bill\");\n dict.Add(","200",", \"Steve\");","\n // We can look up the int in the Dictionary.\n ","if (dict.ContainsKey(","200","))\n {\n Console.WriteLine(true);\n }\n }\n}\n\n","Output","\n\nTrue","LINQ."," Extension methods can be used with Dictionary. We use the ToDictionary method. This is an extension method on IEnumerable. It places keys and values into a new Dictionary. ","Lambda: ","The program uses lambda expressions. With these small functions, we specify a method directly as an argument.","Lambdas ","lambda","Here: ","The example uses ToDictionary, from System.Linq, on a string array. It creates a lookup table for the strings.","ToDictionary ","todictionary","C# that uses LINQ","\n\nusing System;\nusing System.Collections.Generic;\nusing System.Linq;\n\nclass Program\n{\n static void Main()\n {\n string[] arr = new string[]\n {\n ","\"One\"",",\n ","\"Two\"","\n };\n var dict = arr.","ToDictionary","(item => item, item => true);\n foreach (var pair in dict)\n {\n Console.WriteLine(\"{0}, {1}\",\n pair.Key,\n pair.Value);\n }\n }\n}\n\n","Output","\n\nOne, True\nTwo, True","ContainsValue."," This method lacks the constant-time look up speed of ContainsKey. It instead searches the entire collection. It is linear in complexity. ","ContainsValue ","containsvalue","Note: ","This example will loop through all elements in the Dictionary until it finds a match, or there are no more elements to check.","Speed: ","MSDN states that \"this method is an O(N) operation, where N is Count.\" It does not run in constant time.","C# that uses ContainsValue","\n\nusing System;\nusing System.Collections.Generic;\n\nclass Program\n{\n static void Main()\n {\n Dictionary<string, int> d = new Dictionary<string, int>();\n d.Add(\"cat\", ","1",");\n d.Add(\"dog\", ","2",");\n if (d.","ContainsValue","(1))\n {\n Console.WriteLine(true);"," // True.\n ","}\n }\n}\n\n","Output","\n\nTrue","Indexer."," We do not need to use Add to insert into a Dictionary. We can instead use the indexer, with the \"[\" and \"]\" brackets. This syntax also gets the value at the key. ","Caution: ","If we try to get a value at a key that doesn't exist, an exception is thrown.","Note: ","With the indexer, an exception is not thrown when we assign to a key that already has a value. But with Add, an exception is thrown.","C# that uses Dictionary indexer","\n\nusing System;\nusing System.Collections.Generic;\n\nclass Program\n{\n static void Main()\n {\n ","Dictionary","<int, int> dictionary = new Dictionary<int, int>();","\n\n // We can assign with the indexer.\n ","dictionary[1] = 2;\n dictionary[2] = 1;\n dictionary[1] = 3;"," // Reassign.\n\n // Read with the indexer.\n // ... An exception occurs if no element exists.\n ","Console.WriteLine(dictionary[1]);\n Console.WriteLine(dictionary[2]);\n }\n}\n\n","Output","\n\n3\n1","Clear."," We can erase all pairs with the Clear method. Or we can assign the Dictionary variable to null. This causes little difference in memory usage\u2014the entries are garbage-collected. ","Clear ","clear","Internally: ","We find that Clear calls Array.Clear, which is not managed code. Dictionary is implemented with arrays.","Array.Clear ","array-clear","Count."," This computes the total number of keys in a Dictionary. This is simpler than accessing the Keys property, or looping over the Dictionary to count it. ","Count ","count-dictionary","Remove."," We can eliminate an entry, not just by setting its value to null or string.Empty, but by also removing the key itself. With Remove, no remnants of the key-value pair are kept. ","Note: ","Running the code in Visual Studio, no exceptions are thrown. When we remove a key that doesn't exist, nothing happens.","However: ","Remove() throws System.ArgumentNullException with a null parameter. We cannot remove null.","C# that uses Remove","\n\nusing System;\nusing System.Collections.Generic;\n\nclass Program\n{\n static void Main()\n {\n Dictionary<string, int> d = new Dictionary<string, int>();\n d.Add(","\"cat\"",", 1);\n d.Add(","\"dog\"",", 2);\n\n d.","Remove","(","\"cat\"",");"," // Removes cat.\n ","d.","Remove","(","\"nothing\"",");"," // Doesn't remove anything.\n ","}\n}","Copy."," Dictionary provides a constructor that copies all values and keys into a new Dictionary instance. This constructor improves code reuse. It makes copying simpler. ","Copy Dictionary ","copy-dictionary","Return."," A Dictionary can be returned, or passed as an argument. The Dictionary type is defined as a class. It is always passed as a reference type. ","And: ","This means only 32-64 bits will be copied on the method invocation. The same principle applies when returning values.","Return ","return","List versus Dictionary."," I suggest almost always using Dictionary for lookups. In large collections, a List will become unusable for lookups. ","But: ","A Dictionary will still work well with large amounts of data. With Dictionary a program recovers from pathological, edge cases.","List ","list","Looping: ","It is faster to loop through elements in a List. If looping through elements is the most common operation, a List is superior.","Dictionary vs. List Loops ","dictionary-list-loop","Compare types."," Sometimes, an array or List can be used instead of a Dictionary. This influences performance. Any analysis depends on the program. ","Array vs. Dictionary ","array-dictionary-test","List vs. Dictionary ","dictionary-time","Composite keys."," We can sometimes use multiple variables in a key. We can create a special function that transforms those variables into a string, serializing them. ","Note: ","We can use the string \"1,2\" to mean the ints 1 and 2. This approach is not optimally fast.","Note 2: ","This is similar to how composite names in programming languages use a period: \"Type.Member\".","Field."," Sometimes it is useful to have a Dictionary at the class level, as a field. And if we have a static class, we should initialize the Dictionary at the class level. ","Note: ","Avoid the static constructor\u2014static constructors often carry performance penalties.","C# that uses Dictionary field","\n\nusing System;\nusing System.Collections.Generic;\n\nclass Program\n{\n static void Main()\n {\n Example e = new Example();\n Console.WriteLine(e.","GetValue","());\n }\n}\n\nclass Example\n{\n ","Dictionary","<int, int> _d = new Dictionary<int, int>()\n {\n {1, 1},\n {2, 3},\n {3, 5},\n {6, 10}\n };\n public int ","GetValue","()\n {\n return _d[2];"," // Example only.\n ","}\n}\n\n","Output","\n\n3","GetEnumerator."," With this method we can loop over a Dictionary with foreach. We call GetEnumerator() and then use a while-loop on the MoveNext method. ","GetEnumerator ","dictionary-getenumerator","IEqualityComparer."," Dictionary uses an IEqualityComparer to compute the hash code for its keys. We can implement this interface with a class. This can improve performance. ","IEqualityComparer ","iequalitycomparer","Optimization."," The Dictionary is well-optimized by the .NET Framework developers. They are smart people. But there are still techniques that influence performance. ","Optimization: Dictionary ","optimization","Binary format."," In serialization we write a Dictionary to the disk. Usually strings are less efficient than a binary format. But with binary we cannot easily read the file. ","Dictionary Binary File ","dictionary-binary","Equals."," Are two dictionaries equal? Do they have the same keys and values? With a special method we can check for equivalent data. ","Dictionary Equals ","dictionary-equals","Stop words."," With a Dictionary we can remove certain words from a string. Small words like \"and\" are sometimes called \"stop words.\" We can use a Dictionary to help eliminate these. ","Stopword Dictionary ","stopword-dictionary","Combine keys."," In this example we combine the keys of two dictionaries into another collection. A HashSet is used to union the two sets of keys. ","Combine Dictionary Keys ","combine-keys","Map."," The Dictionary is a map. A real map helps us find our destination, but a digital map directs us from a key to a value. In languages we often find a map type. ","Map ","map","Case-insensitive keys."," With a special StringComparer we can have case-insensitive key lookups on a dictionary. This reduces the need to call ToLower. It reduces string creation. ","Case, Dictionary ","case-insensitive-dictionary","Research."," A Dictionary is powerful, but it is not magic. It just uses a good algorithm. This requires a hash code. We take keys and use arithmetic to transform them into numbers. ","Locations: ","We then store them in locations based on those numbers in the Dictionary. We select a \"bucket\" based on the hash.","Finally: ","When we go to look up a key, we compute a new hash code and look for it in the Dictionary. Less searching is needed.","We try to reference items in a table directly by doing arithmetic operations to transform keys into table addresses.","Algorithms in C++ Third Edition: google.com ","https://books.google.com/books?id=331YAAAAYAAJ","It is good"," that fast lookups are important. We just spent lots of time explaining how to do them. We looped over a Dictionary with KeyValuePair.","A review."," We checked key existence with ContainsKey and TryGetValue. Dictionary, like all hash tables, is fascinating. It is fast. It is useful in many places. ","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()","url()","C","url()","url()","url()","url()","url()","url()","url()","P","url()","url()","url()","url()","B","url()","url()","I","url()","N","url()","url()","H^","url()","url()","A^","url()"]