data:image/s3,"s3://crabby-images/d6467/d64674125c99d5b83906f635be01400d15f7630f" alt="iOS 12 Programming for Beginners"
Creating a dictionary
The traditional way of creating a dictionary is to first declare it as a dictionary and then, inside angle brackets, declare a type for the key and value. Let's create our first dictionary inside Playgrounds:
data:image/s3,"s3://crabby-images/e11e1/e11e1dd7a453a771b7c743ead0dcd1f13343970c" alt=""
The immutable dictionary we created earlier has a string data type for both its key and value. We have multiple ways to create a dictionary. Let's look at another by adding the following to Playgrounds:
let dictSecondExample = [String: Int]()
Your code should now look like this:
data:image/s3,"s3://crabby-images/8c242/8c242bd8cb7e025a9a9ecf1855671c228a86a83c" alt=""
In this latest example, we created another immutable dictionary, with its key having a string data type and its value having an int data type.
If we wanted to use our pizza diagram, the key would have a string data type and the value would have a double data type. Let's create this dictionary in Playgrounds, but, this time, we will make it a mutable dictionary and give it an initial value:
var dictThirdExample = Dictionary<String, Double>(dictionaryLiteral: ("veggie", 14.99), ("meat", 16.99))
Your code should now look like this:
data:image/s3,"s3://crabby-images/bbef3/bbef32935b527add55d0f6a32850a87762ab2e8d" alt=""
The preceding example is just one way of creating a dictionary for our pizza diagram example. Let's look at a much more common method using type inference:
var dictPizzas = ["veggie": 14.99]
Once you add this to your code, your code should look something like this:
data:image/s3,"s3://crabby-images/8fc66/8fc66d395bf27077f7d73675bb3220e201af9c6a" alt=""
The preceding is a much simpler way of creating a dictionary with an initial value. When initializing a dictionary, it can have any number of items. In our case, we are starting off with just one.
Now, let's look at how we can add more pizzas to our dictionary.