curl_multi_init - Man Page

create a multi handle

Synopsis

#include <curl/curl.h>

CURLM *curl_multi_init();

Description

This function returns a pointer to a CURLM handle to be used as input to all the other multi-functions, sometimes referred to as a multi handle in some places in the documentation. This init call MUST have a corresponding call to curl_multi_cleanup(3) when the operation is complete.

Protocols

This functionality affects all supported protocols

Example

int main(void)
{
  /* init a multi stack */
  CURLM *multi = curl_multi_init();
  CURL *curl = curl_easy_init();
  CURL *curl2 = curl_easy_init();

  /* add individual transfers */
  curl_multi_add_handle(multi, curl);
  curl_multi_add_handle(multi, curl2);
}

Availability

Added in curl 7.9.6

Return Value

If this function returns NULL, something went wrong and you cannot use the other curl functions.

See Also

curl_easy_init(3), curl_global_init(3), curl_multi_add_handle(3), curl_multi_cleanup(3), curl_multi_get_handles(3)

Referenced By

curl_easy_init(3), curl_multi_add_handle(3), curl_multi_cleanup(3), curl_multi_fdset(3), curl_multi_get_handles(3), curl_multi_info_read(3), curl_multi_perform(3), curl_multi_remove_handle(3), curl_multi_setopt(3), curl_multi_socket(3), curl_multi_socket_action(3), curl_multi_socket_all(3), libcurl-multi(3), libcurl-tutorial(3).

2024-08-21 libcurl