Technology & Design

How To Handle Asynchronous Multiple Task To Synchronous Way Using GCD in Swift 4.0

In Multitasking environment developers like you, We always give best to the application so, End user interaction will be smooth. But making application user interactive it’s not an easy task in a multithreaded environment, because the user can do different tasks at a time. So today I will discuss how to make multiple asynchronous tasks to synchronously way in swift using GCD(Grand Central Dispatch).

GCD is a core level powerful tool to handle multithreading in the application. For more details, you can check apple documentation regarding gcd. So let’s start with one Example, I have a situation where we need to request two different asynchronous API(Web Service) at a time and handle the response.

We will do this exercise in Xcode PlayGround, So open Xcode Go to File -> New -> Playground, Select Blank playground and then Next and give the name as HTTPRequest, it will save it as HTTPRequest.playground in your specified directory.

First, we will create HTTPRequest handler class, the main purpose of this class is it will request to the web server and get a response from the web server, here we just handling only GET request for this example purpose, you can try with POST, DELETE and PUT as well.

class HTTPRequest: NSObject {

   // GET Service

   func onHandlelGETService(_ urlString: String,_ completion: @escaping (Data?, URLResponse?, Error?) -> ()) {

       let url = URL(string: urlString)

       let session = URLSession.shared

       session.dataTask(with: url!) { (data, response, error) in

           if let errorResponse = error {

               completion(nil, nil, errorResponse)

           }

           else {

               if let httpResponse = response as? HTTPURLResponse {

                   if httpResponse.statusCode != 200 {

                       let errorResponse = NSError(domain: "com.error", code: httpResponse.statusCode, userInfo: [NSLocalizedDescriptionKey :"Http status code has unexpected value"])

                       completion(nil, nil, errorResponse)

                   }

                   else {

                       completion(data, response, nil)

                   }

               }

           }

       }.resume()

   }

}

Above, the code is straightforward, we have created HTTPRequest class and create function onHandleGETService which takes the argument of string URL and it will request get http request using URLSession Data task and give a callback to method caller.

let httpResonce = HTTPRequest()

// First we create DispatchGroup() instance

let serialGroup = DispatchGroup()

// The ‘enter’ method add the task in the dispatch  group

serialGroup.enter()

httpResonce.callGETService("http://www.google.com") { (data, response, error) in

   if error != nil {

       print("First Request got completed with error.....")

   }

   else {

       print("First Request got completed.....")

 

   }

   // The ‘leave’ method remove task from dispatch group

   serialGroup.leave()

}

serialGroup.enter()

httpResonce.callGETService("http://www.yahoo.com") { (data, response, error) in

   if error != nil {

       print("Second Request got completed with error.....")

   }

   else {

       print("Second Request got completed.....")

   }

   serialGroup.leave()

}

// The ‘notify’ method will execute when all task is finished.

serialGroup.notify(queue: DispatchQueue.main) {

   print("All Groups request completed.....")

}

In the above code, we have used DispatchGroup() to fulfill our requirements. So let’s dig into that, first, we have to create an instance of the DispatchGroup and here it’s magic happen.

Before the call of each GET request, we have to use ‘enter’, it will tell GCD that task is added in the queue.

After each callback block, we have use ‘leave’, it will tell GCD that task is completed and you can remove that task from the queue.

Here we need to make sure we have to call function ‘enter()’ and ‘leave()’ for each task, otherwise group never gone be finished.

Next, ‘notify()’ method will execute when all the task got finished, which we have called in ‘main’ queue.

To know more about our achievements in detail, please click here or contact us

Related Posts

Nothing found.

Let’s talk!
We’d love to hear what you are working on. Drop us a note here andwe’ll get back to you within 24 hours

Published by
Janki Thaker

Recent Posts

  • Data & Analytics

Solving the ‘Data Silo’: An Approach with Databricks Lakehouse

Getting rid of data silos involves more than just…

2 days ago
  • Data & Analytics

From Data Chaos to Data Clarity: The True Value of Data Analytics

Businesses can break through the chaos of data using…

1 week ago
  • Data & Analytics

Why is Data Analytics the Invisible Foundation for your Business Insights?

There is a huge quantity of “invisible work” in…

2 weeks ago
  • Data & Analytics

Data Strategy: Short-Term Wins vs Long-Term Vision

Explore why this combination of short-term wins and long-term…

2 weeks ago
  • AI/ML

4 Layers of AI & Automation Challenges

AI and automation hold transformative potential for businesses, enabling…

2 weeks ago