Maison >développement back-end >tutoriel php >Questions de développement iOS (2)
11. Impossible de déboguer l'appareil "Erreur lors du lancement du programme distant : échec de l'obtention de la tâche pour le processus 6405."
Le profil ad hoc ne prend pas en charge le débogage. Changement de profil de développement.
12. OTA ne peut pas être téléchargé, affichant le message « Impossible de télécharger l'application »
L'identifiant du bundle dans le fichier .plist est mal écrit (ou contient des caractères chinois), tels que :
<key>bundle-identifier</key> <string>com.xxx.--APN--</string>
Le com.xxx.—APN—contient du chinois ("--") et doit être remplacé par l'anglais.
Ou le certificat de signature n'est pas valide. Veuillez détecter le certificat de signature dans Orgnizer.
12. EXEC_BAD apparaît souvent dans ASIHTTPRequest
Lors de l'utilisation d'ASIHTTPRequest pour effectuer des requêtes asynchrones, des plantages de programme se produisent souvent. Surtout pendant le processus de demande (non terminé), si vous changez de vue. Puisqu'il s'agit d'une requête asynchrone, l'objet de requête peut appeler un délégué (ViewController) à tout moment et le ViewController peut avoir été libéré à ce moment-là. Parce qu'UIKit publiera à tout moment le ViewController qui n'est actuellement pas affiché. Si vous changez de ViewController, le ViewController masqué sera libéré à tout moment. Si la requête rappelle la méthode déléguée de ViewController et que ViewController est publié par UIKit, EXEC_BAD en résultera. C'est également mentionné dans la documentation officielle : les requêtes ne conservent pas leurs délégués, donc s'il y a un risque que votre délégué soit désaffecté pendant que votre requête est en cours d'exécution, il est essentiel que vous effaciez les propriétés du délégué de la requête. Dans la plupart des cas, si votre délégué est votre délégué. va être libéré, vous voudrez probablement aussi annuler la demande, puisque vous ne vous souciez plus du statut de la demande
Par conséquent, lorsque vous utilisez ASIHTTPRequest pour la programmation asynchrone, nous devons effacer nous-mêmes l'attribut délégué de la demande. Dans la méthode dealloc du délégué (ViewController), vous devez :
[request clearDelegatesAndCancel]; [request release];
Bien sûr, la requête ne peut pas être une variable temporaire, mais doit être un objet membre (ou attribut) conservé, sinon vous ne pouvez pas désallouer méthode clearDelegatesAndCancel.
13. Échec de l'assertion dans -[UIActionSheet showInView :]
Ouvrir la feuille d'action dans le fil de discussion principal :
[selfperformSelectorOnMainThread:@selector(showActionSheet) withObject:nilwaitUntilDone:NO];
Méthode showActionSheet :
-(void) showActionSheet { sheet = [[UIActionSheet alloc] initWithTitle:@"This is my ActionSheet!" delegate:self cancelButtonTitle:@"OK"destructiveButtonTitle:@"Delete Message!" otherButtonTitles:@"Option1", @"Option 2", @"Option 3", nil]; [sheet showInView:self.view]; }
14. Erreur de compilation RegexKitLite
L'erreur suivante s'affiche lors de la compilation :
"_uregex_find", referenced from: _rkl_search in RegexKitLite.o ……
在Build Settgins的Other Linke Flag中加入
-licucore
15、Archive时遇到“ResourceRules.plist:cannot read resources”错误
在build settings中找到Code Signing Resource Rules Path,填入$(SDKROOT)/ResourceRules.plist
16、使用ZombieEnable解决EXEC_BAD_EXCESS错误
这个错误是向一个release对象发送消息导致的。可以通过开启ZombieEnable参数来查找真正的问题。
Edit Scheme,选择Run …Debug,打开Arguments组,在Environment Variables中添加一个参数:
运行程序,当出现EXEC_BAD_EXCESS错误时,控制台中会输出具体出错的信息,比如:
*** -[ITSMTicketCell release]: message sent to deallocated instance0x897e920
直接指明了是由于某个对象在被释放之后,你发送了一条消息给它。
17、 关于Xcode4无法调试2代代老设备的问题
升级到Xcode4以后,你会发现许多程序无法在2代设备(有些3代设备,比如iTouch 3实际上仍然是2代的硬件)上运行了,并且Xcode4仅仅“Running…”就直接“Finished…”了,无论是Xcode控制台还是设备日志中,都没有任何提示。
注意:2代和3代的区别在于cpu架构。2代设备使用ARMv6架构cpu,3代设备使用ARMv7架构cpu。 iPhone 2G/3G,iPod 1G/2G属于ARMv6架构(2代),iPhone3GS/4, iPod 3G,iPad属于ARMv7架构(3代)。
stackoverflow上有关于这个的帖子,其中shapecatcher的答案是最准确的:
http://stackoverflow.com/questions/6378228/switching-from-xcode3-to-xcode4-cant-load-programs-onto-older-ipod-touch
1、打开Target的Build Settings,找到Architectures选项,将其从“$(ARCHS_STANDARD_32_BIT)”修改为“armv6$(ARCHS_STANDARD_32_BIT)”。注意大小写是敏感的。“$(ARCHS_STANDARD_32_BIT)”是一个变量,实际上等同于armv7。
2、Base SDK不需要改变,仍然是Lastest iOS。
3、打开Target的info,找到Required device capabilities,将下面的armv7删除。这个选项是Xcode4自己添加在工程中的默认设置,如果不去掉它,第1步-第2步的工作是无法生效的。
18、“Avalid provisioning profile for this device was not found.”
在你的开发证书中增加该设备的UDID。
19、将设备添加到 portal
连接设备,打开Orgnizer。在设备列表中选中设备,点击右边窗口左下角的“Add to Portal”按钮。或者在设备列的设备上右击,选择“AddDevice to Provisioning Portal”。
20、renew profile
打开Orgnizer,在LIBRARY中选择Provisioning Profiles。在右边窗口选择要renew的profile,点击右下角的“Refresh”按钮。输入Portal的密码,profile将被renew。
21、renew签名证书及设备激活文档
从portal移除过期的签名证书
重新制作开发证书和发布证书
删除开发和部署所用的激活文档(provisioningprofiles)
使用新的证书重新制作用于开发和部署的Provisioningprofiles
从钥匙串中删除老的证书
在XcodeOrganizer中安装新的provisioning profiles
完成
以上就是iOS 开发百问(2)的内容,更多相关内容请关注PHP中文网(www.php.cn)!