Grand Central Dispatch

The libdispatch Project, (a.k.a. Grand Central Dispatch), for concurrency on multicore hardware

  • Owner: swiftlang/swift-corelibs-libdispatch
  • Platform:
  • License:: Apache License 2.0
  • Category::
  • Topic:
  • Like:
    0
      Compare:

Github stars Tracking Chart

Grand Central Dispatch

Grand Central Dispatch (GCD or libdispatch) provides comprehensive support for concurrent code execution on multicore hardware.

libdispatch is currently available on all Darwin platforms. This project aims to make a modern version of libdispatch available on all other Swift platforms. To do this, we will implement as much of the portable subset of the API as possible, using the existing open source C implementation.

libdispatch on Darwin is a combination of logic in the xnu kernel alongside the user-space Library. The kernel has the most information available to balance workload across the entire system. As a first step, however, we believe it is useful to bring up the basic functionality of the library using user-space pthread primitives on Linux. Eventually, a Linux kernel module could be developed to support more informed thread scheduling.

Project Status

A port of libdispatch to Linux has been completed. On Linux, since Swift 3, swift-corelibs-libdispatch has been included in all Swift releases and is used by other swift-corelibs projects.

Opportunities to contribute and on-going work include:

  1. Develop a test suite for the Swift APIs of libdispatch.
  2. Enhance libdispatch as needed to support Swift language evolution and the needs of the other Core Libraries projects.

Build and Install

For detailed instructions on building and installing libdispatch, see INSTALL.md

Testing

For detailed instructions on testing libdispatch, see TESTING.md

Main metrics

Overview
Name With Ownerswiftlang/swift-corelibs-libdispatch
Primary LanguageC
Program languageShell (Language Count: 8)
Platform
License:Apache License 2.0
所有者活动
Created At2015-11-09 20:13:55
Pushed At2025-04-25 10:47:29
Last Commit At
Release Count2738
Last Release Nameswift-6.2-DEVELOPMENT-SNAPSHOT-2025-04-24-a (Posted on 2025-04-25 03:47:28)
First Release Namemacosforge/libdispatch-187.5 (Posted on )
用户参与
Stargazers Count2.5k
Watchers Count248
Fork Count469
Commits Count1.6k
Has Issues Enabled
Issues Count179
Issue Open Count66
Pull Requests Count514
Pull Requests Open Count31
Pull Requests Close Count137
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private