GVKun编程网logo

如何在 swift 中使用 messageui 库修复此错误?(swift message priority)

4

在这篇文章中,我们将带领您了解如何在swift中使用messageui库修复此错误?的全貌,包括swiftmessagepriority的相关情况。同时,我们还将为您介绍有关iOSSwift应用程序随

在这篇文章中,我们将带领您了解如何在 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 message priority)

如何解决如何在 swift 中使用 messageui 库修复此错误?

我在 swift 中使用 messageui 库创建了一个邮件编辑器,嵌入到一个按钮中,一旦点击就会打开默认的邮件应用程序。但是,一旦打开邮件应用程序,我就会不断收到此错误。

错误:[PPT] 创建与 PPT 通信所需的 CFMessagePort 时出错。

iOS Swift 应用程序随机 EXC_BAD_ACCESS 崩溃:swift_bridgeObjectRetain swift_retain swift::RefCounts<swift::RefCountBitsT<(swift::RefCountInlinedness)1>

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 邮件发送功能

邮件发送功能是由 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 新手,无法手动将 swift 2 转换为 swift 5

我年轻的时候经常搞砸,我构建了一个应用程序,我目前正在尝试修复并改进该应用程序,但是我在将 swift 2 转换为 swift 5 时遇到了一些问题,并且该应用程序不会成功编译

问题 1: 无法将 ''(NSError) -> ()'' 类型的值转换为预期的参数类型 ''((Error) -> Void)?''

参考这两行代码:

  1. }) { (error:NSError) in
  2. print(error.localizedDescription)

问题 2: Any 类型的值没有下标

参考这些行:

  1. key = snapshot.key
  2. itemRef = snapshot.ref
  3. if let shareContent = snapshot.value!["content"] as? [[String:Any]] {
  4. content = shareContent
  5. }
  6. else{
  7. content = ""
  8. }
  9. if let shareUser = snapshot.value!["addedByUser"] as? [[String:Any]] {
  10. addedByUser = shareUser
  11. }else{
  12. content = ""

问题 3: 表达类型不明确,没有更多上下文

  1. FIRAuth.auth()?.signInWithEmail("",password: "",completion: { (user:FIRUser?,error:NSError?) in
  2. if error == nil {
  3. print(user?.email)

如果有人可以帮助其中任何一个,我将非常感激

解决方法

问题 1) 和 3):不要注释类型,在 Swift 3+ 中,错误已成为符合 Error 的类型

  1. }) { error in
  2. print(error.localizedDescription)

关于 3) 在 Firebase 文档中查找正确的类型,它不再是 (FIRUser?,NSError?)

问题 2):在 Swift 3+ 中,编译器必须知道任何下标对象的静态类型。如果 value 应该是字典,你必须有条件地向下转换它

  1. if let sharedValue = snapshot.value as? [String:Any],let shareContent = sharedValue["content"] as? [[String:Any]] {
  2. content = shareContent
  3. }

Swift 无法从 Swift.X 转换为 Swift.X.Type

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]))

注意: xOptional Int32 类型。

今天关于如何在 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等更多相关知识的信息可以在本站进行查询。

本文标签: