CocoaAsyncSocket provides easy-to-use and powerful asynchronous socket libraries for Mac and iOS. The classes are described below.
Install using CocoaPods by adding this line to your Podfile:
use_frameworks! # Add this if you are targeting iOS 8+ or using Swift
pod 'CocoaAsyncSocket'
CocoaAsyncSocket is Carthage compatible. To include it add the following line to your Cartfile
github "robbiehanson/CocoaAsyncSocket" "master"
The project is currently configured to build for iOS, tvOS and Mac. After building with carthage the resultant frameworks will be stored in:
Carthage/Build/iOS/CocoaAsyncSocket.framework
Carthage/Build/tvOS/CocoaAsyncSocket.framework
Carthage/Build/Mac/CocoaAsyncSocket.framework
Select the correct framework(s) and drag it into your project.
You can also include it into your project by adding the source files directly, but you should probably be using a dependency manager to keep up to date.
Using Objective-C:
@import CocoaAsyncSocket; // When using iOS 8+ frameworks
// OR
#import "CocoaAsyncSocket.h" // When not using frameworks, targeting iOS 7 or below
Using Swift:
import CocoaAsyncSocket
GCDAsyncSocket and AsyncSocket are TCP/IP socket networking libraries. Here are the key features available in both:
Native objective-c, fully self-contained in one class.
No need to muck around with sockets or streams. This class handles everything for you.
Full delegate support
Errors, connections, read completions, write completions, progress, and disconnections all result in a call to your delegate method.
Queued non-blocking reads and writes, with optional timeouts.
You tell it what to read or write, and it handles everything for you. Queueing, buffering, and searching for termination sequences within the stream - all handled for you automatically.
Automatic socket acceptance.
Spin up a server socket, tell it to accept connections, and it will call you with new instances of itself for each connection.
Support for TCP streams over IPv4 and IPv6.
Automatically connect to IPv4 or IPv6 hosts. Automatically accept incoming connections over both IPv4 and IPv6 with a single instance of this class. No more worrying about multiple sockets.
Support for TLS / SSL
Secure your socket with ease using just a single method call. Available for both client and server sockets.
GCDAsyncSocket is built atop Grand Central Dispatch:
Fully GCD based and Thread-Safe
It runs entirely within its own GCD dispatch_queue, and is completely thread-safe. Further, the delegate methods are all invoked asynchronously onto a dispatch_queue of your choosing. This means parallel operation of your socket code, and your delegate/processing code.
The Latest Technology & Performance Optimizations
Internally the library takes advantage of technologies such as kqueue's to limit system calls and optimize buffer allocations. In other words, peak performance.
AsyncSocket wraps CFSocket and CFStream:
GCDAsyncUdpSocket and AsyncUdpSocket are UDP/IP socket networking libraries. Here are the key features available in both:
Native objective-c, fully self-contained in one class.
No need to muck around with low-level sockets. This class handles everything for you.
Full delegate support.
Errors, send completions, receive completions, and disconnections all result in a call to your delegate method.
Queued non-blocking send and receive operations, with optional timeouts.
You tell it what to send or receive, and it handles everything for you. Queueing, buffering, waiting and checking errno - all handled for you automatically.
Support for IPv4 and IPv6.
Automatically send/recv using IPv4 and/or IPv6. No more worrying about multiple sockets.
GCDAsyncUdpSocket is built atop Grand Central Dispatch:
AsyncUdpSocket wraps CFSocket:
Can't find the answer to your question in any of the wiki articles? Try the mailing list.
Love the project? Wanna buy me a coffee? (or a beer :D)
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。