在这篇文章中,我们将带领您了解如何在swift中使用messageui库修复此错误?的全貌,包括swiftmessagepriority的相关情况。同时,我们还将为您介绍有关iOSSwift应用程序随
在这篇文章中,我们将带领您了解如何在 swift 中使用 messageui 库修复此错误?的全貌,包括swift message priority的相关情况。同时,我们还将为您介绍有关iOS Swift 应用程序随机 EXC_BAD_ACCESS 崩溃:swift_bridgeObjectRetain swift_retain swift::RefCounts
- 如何在 swift 中使用 messageui 库修复此错误?(swift message priority)
- iOS Swift 应用程序随机 EXC_BAD_ACCESS 崩溃:swift_bridgeObjectRetain swift_retain swift::RefCounts
- MessageUI Framework 邮件发送功能
- Swift 新手,无法手动将 swift 2 转换为 swift 5
- Swift 无法从 Swift.X 转换为 Swift.X.Type
如何在 swift 中使用 messageui 库修复此错误?(swift message priority)
如何解决如何在 swift 中使用 messageui 库修复此错误?
我在 swift 中使用 messageui 库创建了一个邮件编辑器,嵌入到一个按钮中,一旦点击就会打开默认的邮件应用程序。但是,一旦打开邮件应用程序,我就会不断收到此错误。
错误:[PPT] 创建与 PPT 通信所需的 CFMessagePort 时出错。
iOS Swift 应用程序随机 EXC_BAD_ACCESS 崩溃:swift_bridgeObjectRetain swift_retain swift::RefCounts
如何解决iOS Swift 应用程序随机 EXC_BAD_ACCESS 崩溃:swift_bridgeObjectRetain swift_retain swift::RefCounts<swift::RefCountBitsT<(swift::RefCountInlinedness)1>
我不断收到来自随机用户的随机崩溃报告。不幸的是,我无法定期重现这一点。用户说崩溃是在 discussionViewController
中随机发生的。所有崩溃报告都有类似的内容:
0 libswiftCore.dylib 0x00000001a53face4 swift::RefCounts<swift::RefCountBitsT<(swift::RefCountInlinedness)1> >::incrementSlow(swift::RefCountBitsT<(swift::RefCountInlinedness)1>,unsigned int) + 60 (atomic:1003)
1 libswiftCore.dylib 0x00000001a53c59e0 swift_retain + 124 (RefCount.h:813)
2 libswiftCore.dylib 0x00000001a5401d60 swift_bridgeObjectRetain + 56 (SwiftObject.mm:585)
3 APPNAME 0x0000000102b59734 closure #1 in discussionViewController.fetchPostData() + 7916
这是完整的崩溃日志和崩溃的线程:
Hardware Model: iphone11,6
Process: APPNAME [11770]
Path: /private/var/containers/Bundle/Application/.../APPNAME.app/APPNAME
Identifier: ----
Version: 62 (62)
AppStoretools: 12E262
AppVariant: 1:iphone11,6:13
Code Type: ARM-64 (Native)
Role: Foreground
Parent Process: launchd [1]
Coalition: ---- [1824]
Date/Time: 2021-06-17 12:07:01.4346 +1000
Launch Time: 2021-06-17 12:06:56.4993 +1000
OS Version: iPhone OS 14.6 (18F72)
Release Type: User
Baseband Version: 3.04.01
Report Version: 104
Exception Type: EXC_BAD_ACCESS (SIGSEGV)
Exception Subtype: KERN_INVALID_ADDRESS at 0x8000000000000010 -> 0x0000000000000010 (possible pointer authentication failure)
VM Region Info: 0x10 is not in any region. Bytes before following region: 4339515376
REGION TYPE START - END [ VSIZE] PRT/MAX SHRMOD REGION DETAIL
UNUSED SPACE AT START
--->
__TEXT 102a7c000-102a94000 [ 96K] r-x/r-x SM=COW ...APPNAME.app/APPNAME
Termination Signal: Segmentation fault: 11
Termination Reason: Namespace SIGNAL,Code 0xb
Terminating Process: exc handler [11770]
Triggered by Thread: 3
Thread 3 name:
Thread 3 Crashed:
0 libswiftCore.dylib 0x00000001a53face4 swift::RefCounts<swift::RefCountBitsT<(swift::RefCountInlinedness)1> >::incrementSlow(swift::RefCountBitsT<(swift::RefCountInlinedness)1>,unsigned int) + 60 (atomic:1003)
1 libswiftCore.dylib 0x00000001a53c59e0 swift_retain + 124 (RefCount.h:813)
2 libswiftCore.dylib 0x00000001a5401d60 swift_bridgeObjectRetain + 56 (SwiftObject.mm:585)
3 APPNAME 0x0000000102b59734 closure #1 in discussionViewController.fetchPostData() + 7916
4 APPNAME 0x0000000102ad09d4 thunk for @escaping @callee_guaranteed (@guaranteed Data?,@guaranteed NSURLResponse?,@guaranteed Error?) -> () + 132 (<compiler-generated>:0)
5 CFNetwork 0x00000001a1b0a3dc __40-[__NSURLSessionLocal taskForClassInfo:]_block_invoke + 540 (LocalSession.mm:687)
6 CFNetwork 0x00000001a1b1c768 __49-[__NSCFLocalSessionTask _task_onqueue_didFinish]_block_invoke + 244 (LocalSessionTask.mm:584)
7 libdispatch.dylib 0x00000001a10d1a84 _dispatch_call_block_and_release + 32 (init.c:1466)
8 libdispatch.dylib 0x00000001a10d381c _dispatch_client_callout + 20 (object.m:559)
9 libdispatch.dylib 0x00000001a10db004 _dispatch_lane_serial_drain + 620 (inline_internal.h:2557)
10 libdispatch.dylib 0x00000001a10dbc34 _dispatch_lane_invoke + 456 (queue.c:3862)
11 libdispatch.dylib 0x00000001a10e64bc _dispatch_workloop_worker_thread + 764 (queue.c:6589)
12 libsystem_pthread.dylib 0x00000001ed04a7a4 0x1ed047000 + 14244
13 libsystem_pthread.dylib 0x00000001ed05174c 0x1ed047000 + 42828
我已验证 discussionViewController.fetchPostData()
不会强制解开任何可选选项,没有 try!
并且在任何地方都使用 [weak self]
和 self?
。该函数非常大,所以我很难缩小崩溃发生的范围。
MessageUI Framework 邮件发送功能
邮件发送功能是由 MessageUI Framework 提供的,这个框架是 iPhone sdk 中最简单的框。由一个类、一个视图控制器,一个 protocol 组成。
一、创建视图控制器:
MFMailComposeViewController *mc = [[MFMailComposeViewController alloc] init]; |
mc.mailComposeDelegate = self; |
二、设置邮件主题:
[mc setSubject:@"Hello, World!"];
三、设置收件人,收件人有三种:
1、设置主收件人
[mc setToRecipients:[NSArray arrayWithObjects:@"zhuqi0@126.com", |
"@dave @iphonedevbook.com", nil]; |
2、设置 cc
[mc setCcRecipients:[NSArray arrayWithObject:@"zhuqil@163.com"]];
3、设置 bcc
[mc setBccRecipients:[NSArray arrayWithObject:@"secret@gmail.com"]];
四、设置邮件主体,有两种格式。
一种是纯文本
[mc setMessageBody:@"Watson!!!\n\nCome here, I need you!" isHTML:NO];
一个是 html 格式
[mc setMessageBody:@"<HTML><B>Hello, Joe!</B><BR/>What do you know?</HTML>" |
isHTML:YES]; |
五、添加附件
添加附件需要三个参数,一个是 NSData 类型的附件,一个是 mime type,一个附件的名称。
NSString *path = [[NSBundle mainBundle] pathForResource:@"blood_orange" ofType:@"png"];
NSData *data = [NSData dataWithContentsOfFile:path];
[mc addAttachmentData:data mimeType:@"image/png" fileName:@"blood_orange"];
六、视图呈现
[self presentModalViewController:mc animated:YES];
[mc release];
七、视图控制器的委托方法
邮件视图控制器的委托方法包含在 MFMailComposeViewControllerDelegate 中,无论用户是否发送或取消发送,不论系统是否能够发送邮件,
方法 mailComposeController:didFinishWithResult:error: gets called 都会被调用。
- (void)mailComposeController:(MFMailComposeViewController*)controller
didFinishWithResult:(MFMailComposeResult)result
error:(NSError*)error { switch (result)
{ case MFMailComposeResultCancelled:
NSLog(@"Mail send canceled..."); break; case MFMailComposeResultSaved:
NSLog(@"Mail saved..."); break; case MFMailComposeResultSent:
NSLog(@"Mail sent..."); break; case MFMailComposeResultFailed:
NSLog(@"Mail send errored: %@...", [error localizedDescription]); break; default: break;
}
[self dismissModalViewControllerAnimated:YES];
}
Swift 新手,无法手动将 swift 2 转换为 swift 5
如何解决Swift 新手,无法手动将 swift 2 转换为 swift 5
我年轻的时候经常搞砸,我构建了一个应用程序,我目前正在尝试修复并改进该应用程序,但是我在将 swift 2 转换为 swift 5 时遇到了一些问题,并且该应用程序不会成功编译
问题 1: 无法将 ''(NSError) -> ()'' 类型的值转换为预期的参数类型 ''((Error) -> Void)?''
参考这两行代码:
}) { (error:NSError) in
print(error.localizedDescription)
问题 2: Any 类型的值没有下标
参考这些行:
key = snapshot.key
itemRef = snapshot.ref
if let shareContent = snapshot.value!["content"] as? [[String:Any]] {
content = shareContent
}
else{
content = ""
}
if let shareUser = snapshot.value!["addedByUser"] as? [[String:Any]] {
addedByUser = shareUser
}else{
content = ""
问题 3: 表达类型不明确,没有更多上下文
FIRAuth.auth()?.signInWithEmail("",password: "",completion: { (user:FIRUser?,error:NSError?) in
if error == nil {
print(user?.email)
如果有人可以帮助其中任何一个,我将非常感激
解决方法
问题 1) 和 3):不要注释类型,在 Swift 3+ 中,错误已成为符合 Error
的类型
}) { error in
print(error.localizedDescription)
关于 3) 在 Firebase 文档中查找正确的类型,它不再是 (FIRUser?,NSError?)
。
问题 2):在 Swift 3+ 中,编译器必须知道任何下标对象的静态类型。如果 value
应该是字典,你必须有条件地向下转换它
if let sharedValue = snapshot.value as? [String:Any],let shareContent = sharedValue["content"] as? [[String:Any]] {
content = shareContent
}
Swift 无法从 Swift.X 转换为 Swift.X.Type
你得到的错误
编译器给了我上面的例子“无法转换''Int32.Type类型的值?''到指定类型 ''Int32''"
是因为您在 Int32.self
中将 T
作为 KeyValuePairs
作为参数传递给您的函数,因此 T?
本身的返回类型变为 Int32.Type?
.因此,当您尝试将其分配给 x
类型的 Int32
时,编译器会抛出错误,因为转换将失败。
所以为了解决这个问题,你可以更喜欢下面的代码:
数组扩展:
extension Array {
func AtIndex(index: Int) -> Any {
return self[index];
}
func AtIndexT<T>(index: KeyValuePairs<Int,T.Type>) -> T? {
if let _record = index.first {
let _key : T = self[_record.key] as! T;
return _key;
} else {
return nil;
}
}
}
用法:
let x:Int32? = Int(db.valueByKey(key:["integer_tgc":Int32.self]).AtIndexT(index: [2:Int32.self]))
注意: x
是 Optional Int32
类型。
今天关于如何在 swift 中使用 messageui 库修复此错误?和swift message priority的介绍到此结束,谢谢您的阅读,有关iOS Swift 应用程序随机 EXC_BAD_ACCESS 崩溃:swift_bridgeObjectRetain swift_retain swift::RefCounts
本文标签: