活动介绍

应用开发中的地址簿功能实现

立即解锁
发布时间: 2025-08-24 01:07:05 阅读量: 1 订阅数: 38
PDF

Objective-C编程与应用开发实战

### 应用开发中的地址簿功能实现 在应用开发过程中,涉及到地址簿功能时,会有多个关键环节需要处理,包括发送响应、命令处理、访问远程地址簿等。下面将详细介绍这些方面的实现。 #### 1. 发送响应 在处理传入数据后,发送响应是一个重要步骤。借助`dispatch_io`,发送响应变得相对简单,只需调用一次`dispatch_io_write()`方法即可。以下是发送数据的代码示例: ```objc - (void) sendData: (NSData *) data { // the queue for all blocks here dispatch_queue_t q = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0); // we want a dispatch_data_t referencing this NSData object // the logical thing is to have the dispatch cleanup block reference & release // the NSData, except we can't call -release on it under ARC. The solution is to // bridge-cast the NSData to a manually-counted CFDataRef, which we can release. CFDataRef cfData = CFBridgingRetain(data); dispatch_data_t ddata = dispatch_data_create(CFDataGetBytePtr(cfData), CFDataGetLength(cfData), q, ^{ CFRelease(cfData); }); dispatch_io_write(_io, 0, ddata, q, ^(bool done, dispatch_data_t d, int err) { if ( err != 0 ) { NSError * error = [NSError errorWithDomain: NSPOSIXErrorDomain code: err userInfo: nil]; NSLog(@"Failed to send data: %@", error); return; } else if ( done ) { NSLog(@"Sent %lu bytes of data", CFDataGetLength(cfData)); } }); } ``` 这里存在一个小问题,即需要将`NSData`对象转换为`dispatch_data`对象。由于在ARC下无法直接释放`NSData`对象,解决方法是使用免费桥接将`NSData`转换为手动管理的`CFData`对象,然后在清理块中手动释放它。 #### 2. 命令处理 `APAddressBookClient`对象解码后的命令会传递给其委托对象,通常是`APAddressBookBrowser`对象。在实现之前,需要在`APAddressBookBrowser.h`文件中添加相关协议声明: ```objc #import "APRemoteAddressBookInterface.h" #import "APAddressBookClient.h" @interface APRemoteAddressBookBrowser : NSObject <APRemoteAddressBookBrowser, APAddressBookClientDelegate, NSNetServiceBrowserDelegate, NSNetServiceDelegate> @end ``` 命令处理方法会提取命令的名称和UUID,根据这些信息向`_localAddressBook`实例发送相应的消息。以下是处理传入命令的代码示例: ```objc - (void) client: (APAddressBookClient *) client handleMessage: (NSDictionary *) command { void (^dataHandler)(NSArray *, NSError *) = ^(NSArray * values, NSError * error) { // ... }; NSString * name = command[APRemoteAddressBookCommandNameKey]; NSString * identifier = command[APRemoteAddressBookCommandPersonIDKey]; if ( [name isEqualToString: APRemoteAddressBookCommandAllPeople] ) { [_localAddressBook allPeople: dataHandler]; } else if ( [name isEqualToString: APRemoteAddressBookCommandGetMailingAddresses] ) { [_localAddressBook mailingAddressesForPersonWithIdentifier: identifier reply: dataHandler]; } else if ( [name isEqualToString: APRemoteAddressBookCommandGetEmailAddresses] ) { [_localAddressBook emailAddressesForPersonWithIdentifier: identifier reply: dataHandler]; } else if ( [name isEqualToString: APRemoteAddressBookCommandGetPhoneNumbers] ) { [_localAddressBook phoneNumbersForPersonWithIdentifier: identifier reply: dataHandler]; } else { id userInfo = @{ NSLocalizedDescriptionKey : @"Unknown command" }; NSError * error = [NSError errorWithDomain: APRemoteAddressBookErrorDomain code: 101 userInfo: userInfo]; dataHandler(nil, error); } } - (void) clientDisconnected: (APAddressBookClient *) client withError: (NSError *) error { // not doing anything with the error, which has already been logged. [_clients removeObject: client]; } ``` 数据处理程序会将结果打包为JSON数据,并发送回发送命令的客户端。以下是命令数据处理程序的代码: ```objc NSMutableDictionary * result = [NSMutableDictionary new]; NSUUID * uuid = command[APRemoteAddressBookCommandUUIDKey]; result[APRemoteAddressBookCommandNameKey] = APRemoteAddressBookCommandReply; result[APRemoteAddressBookCommandUUIDKey] = uuid; if ( values != nil ) result[APRemoteAddressBookCommandValueKey] = values; if ( error != nil ) result[APRemoteAddressBookCommandErrorKey] = [error jsonDictionaryRepresentation]; NSError * jsonError = nil; NSData * jsonData = [NSJSONSerialization dataWithJSONObject: result options: 0 error: &jsonError]; if ( jsonData == nil ) { NSLog(@"Error building JSON reply: %@. Message = %@. Reply = %@", jsonError, command, result); return; } // send the data asynchronously [client sendData: jsonData]; ``` #### 3. 访问远程地址簿 要访问网络上其他应用实例的地址簿,应用需要按以下三个步骤执行: - 向XPC服务代理对象发送`-availableServiceNames:`消息,获取可用服务列表,并在窗口中显示给用户。 - 用户选择服务后,应用向XPC代理发送`-attachToRemoteAddressBookWithName:handler:`消息以建立连接。 - 连接成功后,显示新的地址簿窗口,并通过向XPC代理发送`-allPeople:`消息异步加载人员列表。 以下是连接服务的方法实现: ```objc - (void) connectToServiceWithName: (NSString *) name replyHandler: (void (^)(id<APRemoteAddressBook>, NSError *)) replyHandler { NSLog(@"Connecting to service named '%@'", name); __block NSNetService * selected = nil; // search individual domains -- look in "local" domain first, then any others NSMutableArray * localServices = _servicesByDomain[@"local."]; NSLog(@"Searching local services: %@", localServices); for ( NSNetService * service in localServices ) { if ( [[service name] isEqualToString: name] ) { NSLog(@"Found local service: %@", service); selected = service; break; } } // if no local services were found, look in the other domains if ( selected == nil ) { [_servicesByDomain enumerateKeysAndObjectsUsingBlock: ^(id key, id obj, BOOL *stop) { if ( [key isEqualToString: @"local."] ) return; // skip local domain, we've already looked there NSLog(@"Searching services in domain '%@': %@", key, obj); for ( NSNetService * service in obj ) { if ( [[service name] isEqualToString: name] ) { NSLog(@"Found service: %@", service); selected = service; *stop = YES; break; } } }]; } // if none were found at all, send back an error if ( selected == nil ) { NSDictionary * info = @{ NSLocalizedDescriptionKey : NSLocalizedString(@"An address book service with the provided name could not be found.", @"error") }; ```
corwn 最低0.47元/天 解锁专栏
赠100次下载
继续阅读 点击查看下一篇
profit 400次 会员资源下载次数
profit 300万+ 优质博客文章
profit 1000万+ 优质下载资源
profit 1000万+ 优质文库回答
复制全文

相关推荐

陆鲁

资深技术专家
超过10年工作经验的资深技术专家,曾在多家知名大型互联网公司担任重要职位。任职期间,参与并主导了多个重要的移动应用项目。
最低0.47元/天 解锁专栏
赠100次下载
百万级 高质量VIP文章无限畅学
千万级 优质资源任意下载
千万级 优质文库回答免费看
立即解锁

专栏目录

最新推荐

老冀文章编辑工具v1.8团队协作模式:多人编辑与项目管理的高效策略

![老冀文章编辑工具v1.8团队协作模式:多人编辑与项目管理的高效策略](https://assets-global.website-files.com/5f7178312623813d346b8936/645b5d19e34ec4f7d4303b3a_e6829d98.png) # 摘要 本文系统介绍老冀文章编辑工具v1.8的核心功能与应用实践,重点分析了多人编辑功能的理论基础、操作实践以及效率优化策略。同时,深入探讨了项目管理功能在实际工作中的核心理论、实施操作和最佳实践方法。此外,本文提出了一系列提升团队协作的高级策略,并通过实战案例展示了工具如何优化日常工作流程和解决特殊场景问题。最

【STM32CubeIDE代码补全完全教程】:成为STM32开发专家的终极学习路径

![【STM32CubeIDE代码补全完全教程】:成为STM32开发专家的终极学习路径](https://reversepcb.com/wp-content/uploads/2023/05/STM32CubeMX-Configuration-Perspective.png.webp) # 摘要 随着嵌入式系统开发的普及,STM32CubeIDE作为一种集成开发环境,其代码补全功能在提升开发效率和代码质量方面扮演着重要角色。本文首先介绍了STM32CubeIDE的基本概念及安装流程,随后深入探讨了代码补全的理论基础、实践应用和性能优化。特别地,本文分析了代码补全如何与STM32开发实践相结合,

【DB文件查看器扩展应用】:解锁更多使用场景与高级功能

![DB文件查看器](https://learnesy.com/wp-content/uploads/2021/07/sql3.png) # 摘要 本文详细介绍了DB文件查看器的功能与操作,涵盖了数据库基础理论、DB文件结构解析、高级查询技巧、扩展功能开发、在不同环境下的应用案例,以及该工具未来的发展方向和社区贡献。文章首先概述了DB文件查看器的基本操作,然后深入探讨了数据库基础知识和DB文件的内部结构。接着,文中阐述了如何利用DB文件查看器进行高级查询,并生成数据分析报告。此外,文章还探讨了DB文件查看器的插件系统设计、用户界面定制化以及脚本编写技巧。最后,通过应用案例展示了DB文件查看器

固件更新风险评估与减轻策略:系统停机的最小化

![固件更新风险评估与减轻策略:系统停机的最小化](https://montemagno.com/content/images/2021/09/Screen-Shot-2021-09-06-at-7.59.46-AM.png) # 摘要 固件更新作为维护设备安全性与性能的重要手段,在技术快速发展的今天显得尤为重要,但同时伴随着风险和挑战。本文深入探讨了固件更新过程中的风险评估、控制点识别、系统停机成本及影响,并通过实践案例分析了成功与失败的固件更新经验。针对固件更新风险,文章提出了一系列减轻策略,包括风险预防措施、自动化更新流程、持续集成策略以及用户教育和技术支持的重要性。最后,本文展望了固

【STID135开发板网络通信宝典】:TCP_IP和HTTP实现解析

![【STID135开发板网络通信宝典】:TCP_IP和HTTP实现解析](https://media.licdn.com/dms/image/D5612AQGCPPLDxGeP8w/article-cover_image-shrink_600_2000/0/1704891486381?e=2147483647&v=beta&t=jhrhYwsocc5cnsxfnciT-en0QIpny2VWATleV9wJNa8) # 摘要 本文旨在全面介绍STID135开发板及其在网络通信领域的应用。首先概述STID135开发板的特性与网络通信基础,接着深入分析TCP/IP协议族的模型结构、TCP与UD

【GIS地图制图精要】:打造专业级别的内蒙古水系分布图

![【GIS地图制图精要】:打造专业级别的内蒙古水系分布图](https://www.nicoladeinnocentis.it/sito/wp-content/uploads/2017/10/georeference.png) # 摘要 本文全面探讨了地理信息系统(GIS)在地图制图中的应用,涵盖了从数据获取到制图实践操作的整个流程。文章首先介绍了GIS的基础知识以及地图制图的基本概念。随后,针对内蒙古水系数据的获取、预处理、清洗和质量控制进行了详细讨论,并比较了当前流行的GIS软件及其制图功能。在分析和制图方面,文章深入探讨了水文地理学的应用、专题制图技术和动态变化分析方法。实践操作章节

Brocade MIBs网络带宽管理:基于MIBs的监控与控制策略详解

![Brocade MIBs网络带宽管理:基于MIBs的监控与控制策略详解](https://substackcdn.com/image/fetch/w_1200,h_600,c_fill,f_jpg,q_auto:good,fl_progressive:steep,g_auto/https%3A%2F%2Fsiteproxy.ruqli.workers.dev%3A443%2Fhttps%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F400e92f8-7e84-4ba6-9443-74368c1eaeb6_3735x3573.jpeg) # 摘要 本文综述了Brocade MIBs在网络带宽管理中的应用,

持续集成与部署(CI_CD)实施:S12(X)项目管理秘诀

![持续集成与部署(CI_CD)实施:S12(X)项目管理秘诀](https://www.edureka.co/blog/content/ver.1531719070/uploads/2018/07/CI-CD-Pipeline-Hands-on-CI-CD-Pipeline-edureka-5.png) # 摘要 随着软件开发速度的加快,持续集成与持续部署(CI/CD)已成为企业确保快速交付高质量软件的关键实践。本文深入探讨了CI/CD的核心概念、工具选择与技术实践,并结合S12(X)项目的案例分析了CI/CD的实施细节。文中详细阐述了CI/CD工具的分类与特点,流水线设计原则以及环境配置

BCM5396日志分析与故障诊断:掌握日志管理,快速定位问题

# 摘要 本文围绕BCM5396日志分析与故障诊断的核心议题展开,首先概述了日志分析与故障诊断的基本概念,随后深入探讨了日志数据的类型、结构、收集、存储、安全性和合规性管理。紧接着,文中介绍了多种日志分析工具及其实践应用,包括模式匹配、日志聚合、排序和可视化技术,并通过实际案例分析展示了日志分析在故障诊断和性能优化中的重要性。文章进一步详细阐述了故障诊断的流程、工具和策略,并对故障案例进行了深入分析,提出了解决方案及预防措施。最后,本文探讨了日志管理的最佳实践以及故障预防和持续改进方法,旨在为网络管理和故障排除提供指导和参考。 # 关键字 BCM5396;日志分析;故障诊断;数据管理;安全合

【飞行模拟器的自动化测试】:实现F-16模拟配平的自动化校准,效率倍增!

![【飞行模拟器的自动化测试】:实现F-16模拟配平的自动化校准,效率倍增!](https://d3i71xaburhd42.cloudfront.net/d30c440a618b1e4e9e24152ae112553108a7a48d/24-Figure4.1-1.png) # 摘要 本文对飞行模拟器自动化测试进行了全面概述,探讨了自动化测试的理论基础、F-16模拟配平自动化校准的实现、自动化校准测试的深度应用与优化,以及未来展望。自动化测试不仅提高了测试效率和准确性,还降低了人力成本。针对F-16模拟配平,文章详细介绍了自动化校准脚本的设计、开发、测试与部署,并分析了校准测试数据,提出了