应用由于EXC_BREAKPOINT(SIGTRAP)而崩溃

时间:2020-03-11 13:12:18

标签: ios exception timer crash testflight

我的应用程序的一名测试人员

报告了此崩溃。我只是似乎不明白是什么原因导致了崩溃。这是崩溃日志:

Exception Type:  EXC_BREAKPOINT (SIGTRAP)
Exception Codes: 0x0000000000000001, 0x00000001027f6bf0
Termination Signal: Trace/BPT trap: 5
Termination Reason: Namespace SIGNAL, Code 0x5
Terminating Process: exc handler [1054]
Triggered by Thread:  0

Thread 0 name:
Thread 0 Crashed:
0   App Names           0x00000001027f6bf0 UpcomingViewController.networkCall1() + 4420 (UpcomingViewController.swift:240)
1   App Names           0x00000001027f88ec @objc UpcomingViewController.networkCall1() + 28 (<compiler-generated>:0)
2   CoreFoundation                  0x00000001913e2360 __CFFireTimer + 64 (CFObject.m:1573)
3   CoreFoundation                  0x0000000191366dcc -[__NSCFTimer fire] + 88 (CFObject.m:1604)
4   App Names           0x00000001027f5a9c @objc UpcomingViewController.scheduledTimerWithTimeInterval1() + 28 (<compiler-generated>:0)
5   CoreFoundation                  0x00000001913da288 __CFNOTIFICATIONCENTER_IS_CALLING_OUT_TO_AN_OBSERVER__ + 20 (CFNotificationCenter.c:787)
6   CoreFoundation                  0x00000001913da2d0 ___CFXRegistrationPost1_block_invoke + 64 (CFNotificationCenter.c:175)
7   CoreFoundation                  0x00000001913d9630 _CFXRegistrationPost1 + 368 (CFNotificationCenter.c:198)
8   CoreFoundation                  0x00000001913d92e8 ___CFXNotificationPost_block_invoke + 104 (CFNotificationCenter.c:1371)
9   CoreFoundation                  0x000000019135559c -[_CFXNotificationRegistrar find:object:observer:enumerator:] + 1416 (CFXNotificationRegistrarOld.m:168)
10  CoreFoundation                  0x00000001913d8c38 _CFXNotificationPost + 1244 (CFNotificationCenter.c:1359)
11  Foundation                      0x00000001917350c8 -[NSNotificationCenter postNotificationName:object:userInfo:] + 60 (NSNotification.m:576)
12  UIKitCore                       0x000000019551a2a4 -[UIApplication _sendWillEnterForegroundCallbacks] + 280 (UIApplication.m:10519)
13  UIKitCore                       0x0000000194cd0450 __101-[_UISceneLifecycleMultiplexer _evalTransitionToSettings:fromSettings:forceExit:withTransiti... + 1732 (_UISceneLifecycleMultiplexer.m:572)
14  UIKitCore                       0x0000000195165698 _UIScenePerformActionsWithLifecycleActionMask + 100 (_UISceneLifecycleState.m:109)
15  UIKitCore                       0x0000000194ccfcf0 __101-[_UISceneLifecycleMultiplexer _evalTransitionToSettings:fromSettings:forceExit:withTransiti... + 196 (_UISceneLifecycleMultiplexer.m:501)
16  UIKitCore                       0x0000000194ccf748 -[_UISceneLifecycleMultiplexer _performBlock:withApplicationOfDeactivationReasons:fromReasons:] + 296 (_UISceneLifecycleMultiplexer.m:450)
17  UIKitCore                       0x0000000194ccfb1c -[_UISceneLifecycleMultiplexer _evalTransitionToSettings:fromSettings:forceExit:withTransitionSto... + 736 (_UISceneLifecycleMultiplexer.m:500)
18  UIKitCore                       0x0000000194ccf3d8 -[_UISceneLifecycleMultiplexer uiScene:transitionedFromState:withTransitionContext:] + 336 (_UISceneLifecycleMultiplexer.m:406)
19  UIKitCore                       0x0000000194cd38c4 __186-[_UIWindowSceneFBSSceneTransitionContextDrivenLifecycleSettingsDiffAction _performActionsFo... + 188 (_UIWindowSceneFBSSceneTransitionContextDrivenLifecycleSettingsDiffAction.m:102)
20  UIKitCore                       0x0000000195096f08 +[BSAnimationSettings(UIKit) tryAnimatingWithSettings:actions:completion:] + 824 (BSAnimationSettings+UIKit.m:50)
21  UIKitCore                       0x000000019517ec84 _UISceneSettingsDiffActionPerformChangesWithTransitionContext + 244 (_UISceneSettingsDiffAction.m:43)
22  UIKitCore                       0x0000000194cd35fc __186-[_UIWindowSceneFBSSceneTransitionContextDrivenLifecycleSettingsDiffAction _performActionsFo... + 136 (_UIWindowSceneFBSSceneTransitionContextDrivenLifecycleSettingsDiffAction.m:87)
23  UIKitCore                       0x000000019517eb80 _UISceneSettingsDiffActionPerformActionsWithDelayForTransitionContext + 100 (_UISceneSettingsDiffAction.m:35)
24  UIKitCore                       0x0000000194cd3468 -[_UIWindowSceneFBSSceneTransitionContextDrivenLifecycleSettingsDiffAction _performActionsForUISc... + 376 (_UIWindowSceneFBSSceneTransitionContextDrivenLifecycleSettingsDiffAction.m:85)
25  UIKitCore                       0x0000000194b452c0 __64-[UIScene scene:didUpdateWithDiff:transitionContext:completion:]_block_invoke + 636 (UIScene.m:1338)
26  UIKitCore                       0x0000000194b43e28 -[UIScene _emitSceneSettingsUpdateResponseForCompletion:afterSceneUpdateWork:] + 248 (UIScene.m:1071)
27  UIKitCore                       0x0000000194b44ff8 -[UIScene scene:didUpdateWithDiff:transitionContext:completion:] + 220 (UIScene.m:1315)
28  UIKitCore                       0x00000001950b7d70 -[UIApplicationSceneClientAgent scene:handleEvent:withCompletion:] + 464 (UIApplicationSceneClientAgent.m:80)
29  FrontBoardServices              0x00000001965b2248 -[FBSSceneImpl updater:didUpdateSettings:withDiff:transitionContext:completion:] + 544 (FBSSceneImpl.m:551)
30  FrontBoardServices              0x00000001965d6d28 __88-[FBSWorkspaceScenesClient sceneID:updateWithSettingsDiff:transitionContext:completion:]_bloc... + 120 (FBSWorkspaceScenesClient.m:356)
31  FrontBoardServices              0x00000001965bbf04 -[FBSWorkspace _calloutQueue_executeCalloutFromSource:withBlock:] + 232 (FBSWorkspace.m:357)
32  FrontBoardServices              0x00000001965d6c5c __88-[FBSWorkspaceScenesClient sceneID:updateWithSettingsDiff:transitionContext:completion:]_bloc... + 184 (FBSWorkspaceScenesClient.m:355)
33  libdispatch.dylib               0x000000019114b184 _dispatch_client_callout + 16 (object.m:495)
34  libdispatch.dylib               0x00000001910f3fd8 _dispatch_block_invoke_direct$VARIANT$mp + 224 (queue.c:466)
35  FrontBoardServices              0x00000001965fb418 __FBSSERIALQUEUE_IS_CALLING_OUT_TO_A_BLOCK__ + 40 (FBSSerialQueue.m:173)
36  FrontBoardServices              0x00000001965fb0e4 -[FBSSerialQueue _queue_performNextIfPossible] + 404 (FBSSerialQueue.m:216)
37  FrontBoardServices              0x00000001965fb60c -[FBSSerialQueue _performNextFromRunLoopSource] + 28 (FBSSerialQueue.m:247)
38  CoreFoundation                  0x00000001913fca00 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 24 (CFRunLoop.c:1922)
39  CoreFoundation                  0x00000001913fc958 __CFRunLoopDoSource0 + 80 (CFRunLoop.c:1956)
40  CoreFoundation                  0x00000001913fc0f0 __CFRunLoopDoSources0 + 180 (CFRunLoop.c:1992)
41  CoreFoundation                  0x00000001913f723c __CFRunLoopRun + 1080 (CFRunLoop.c:2882)
42  CoreFoundation                  0x00000001913f6adc CFRunLoopRunSpecific + 464 (CFRunLoop.c:3192)
43  GraphicsServices                0x000000019b397328 GSEventRunModal + 104 (GSEvent.c:2246)
44  UIKitCore                       0x000000019550463c UIApplicationMain + 1936 (UIApplication.m:4773)
45  App Names           0x00000001027c0b3c main + 68 (SlideOutTransition.swift:15)
46  libdyld.dylib                   0x0000000191280360 start + 4

Thread 1 name:
Thread 1:
0   libsystem_kernel.dylib          0x0000000191254634 mach_msg_trap + 8
1   libsystem_kernel.dylib          0x0000000191253aa0 mach_msg + 72 (mach_msg.c:103)
2   CoreFoundation                  0x00000001913fc288 __CFRunLoopServiceMachPort + 216 (CFRunLoop.c:2575)
3   CoreFoundation                  0x00000001913f73a8 __CFRunLoopRun + 1444 (CFRunLoop.c:2931)
4   CoreFoundation                  0x00000001913f6adc CFRunLoopRunSpecific + 464 (CFRunLoop.c:3192)
5   Foundation                      0x0000000191736784 -[NSRunLoop(NSRunLoop) runMode:beforeDate:] + 228 (NSRunLoop.m:374)
6   Foundation                      0x0000000191736664 -[NSRunLoop(NSRunLoop) runUntilDate:] + 88 (NSRunLoop.m:421)
7   UIKitCore                       0x000000019559ce80 -[UIEventFetcher threadMain] + 152 (UIEventFetcher.m:637)
8   Foundation                      0x000000019186709c __NSThread__start__ + 848 (NSThread.m:724)
9   libsystem_pthread.dylib         0x0000000191199d8c _pthread_start + 156 (pthread.c:896)
10  libsystem_pthread.dylib         0x000000019119d76c thread_start + 8

Thread 2 name:
Thread 2:
0   libsystem_kernel.dylib          0x0000000191254634 mach_msg_trap + 8
1   libsystem_kernel.dylib          0x0000000191253aa0 mach_msg + 72 (mach_msg.c:103)
2   CoreFoundation                  0x00000001913fc288 __CFRunLoopServiceMachPort + 216 (CFRunLoop.c:2575)
3   CoreFoundation                  0x00000001913f73a8 __CFRunLoopRun + 1444 (CFRunLoop.c:2931)
4   CoreFoundation                  0x00000001913f6adc CFRunLoopRunSpecific + 464 (CFRunLoop.c:3192)
5   CFNetwork                       0x00000001946c04e8 -[__CoreSchedulingSetRunnable runForever] + 192 (CoreSchedulingSet.mm:1372)
6   Foundation                      0x000000019186709c __NSThread__start__ + 848 (NSThread.m:724)
7   libsystem_pthread.dylib         0x0000000191199d8c _pthread_start + 156 (pthread.c:896)
8   libsystem_pthread.dylib         0x000000019119d76c thread_start + 8

Thread 3 name:
Thread 3:
0   libsystem_kernel.dylib          0x0000000191254634 mach_msg_trap + 8
1   libsystem_kernel.dylib          0x0000000191253aa0 mach_msg + 72 (mach_msg.c:103)
2   CoreFoundation                  0x00000001913fc288 __CFRunLoopServiceMachPort + 216 (CFRunLoop.c:2575)
3   CoreFoundation                  0x00000001913f73a8 __CFRunLoopRun + 1444 (CFRunLoop.c:2931)
4   CoreFoundation                  0x00000001913f6adc CFRunLoopRunSpecific + 464 (CFRunLoop.c:3192)
5   AVFAudio                        0x000000019dfd9c1c GenericRunLoopThread::Entry(void*) + 156 (GenericRunLoopThread.h:91)
6   AVFAudio                        0x000000019e02ad60 CAPThread::Entry(CAPThread*) + 204 (CAPThread.cpp:286)
7   libsystem_pthread.dylib         0x0000000191199d8c _pthread_start + 156 (pthread.c:896)
8   libsystem_pthread.dylib         0x000000019119d76c thread_start + 8

Thread 4:
0   libsystem_pthread.dylib         0x000000019119d758 start_wqthread + 0

Thread 5:
0   libsystem_pthread.dylib         0x000000019119d758 start_wqthread + 0

Thread 6:
0   libsystem_pthread.dylib         0x000000019119d758 start_wqthread + 0

Thread 7 name:
Thread 7:
0   libsystem_kernel.dylib          0x00000001912779f4 kevent_id + 8
1   libdispatch.dylib               0x000000019110de18 _dispatch_kq_poll + 332 (event_kevent.c:750)
2   libdispatch.dylib               0x000000019110d920 _dispatch_kq_drain + 124 (event_kevent.c:809)
3   libdispatch.dylib               0x000000019110d844 _dispatch_event_loop_drain$VARIANT$mp + 316 (event_kevent.c:1965)
4   libdispatch.dylib               0x00000001910f8e28 _dispatch_workloop_invoke$VARIANT$mp + 1456 (queue.c:4270)
5   libdispatch.dylib               0x0000000191101314 _dispatch_workloop_worker_thread + 588 (queue.c:6445)
6   libsystem_pthread.dylib         0x000000019119ab88 _pthread_wqthread + 276 (pthread.c:2351)
7   libsystem_pthread.dylib         0x000000019119d760 start_wqthread + 8

Thread 8:
0   libsystem_pthread.dylib         0x000000019119d758 start_wqthread + 0

Thread 9:
0   libsystem_pthread.dylib         0x000000019119d758 start_wqthread + 0

Thread 10:
0   libsystem_pthread.dylib         0x000000019119d758 start_wqthread + 0

Thread 11:
0   libsystem_pthread.dylib         0x000000019119d758 start_wqthread + 0

Thread 12:
0   libsystem_pthread.dylib         0x000000019119d758 start_wqthread + 0

Thread 0 crashed with ARM Thread State (64-bit):
    x0: 0x00000002811a05d0   x1: 0x00000001c97fd320   x2: 0x0000000000000000   x3: 0x000000000000000b
    x4: 0x000000000000000b   x5: 0x0000000000000010   x6: 0x000000000000006e   x7: 0x0000000000000000
    x8: 0x6012e6b213e200eb   x9: 0x6012e6b213e200eb  x10: 0x000021a1d9f09259  x11: 0x001f000102e70ce0
   x12: 0x0000000102e70ce0  x13: 0x000041a1d9f09259  x14: 0x0000000075cda64e  x15: 0x0000000000000065
   x16: 0x00000001d9f03258  x17: 0x00000001911a1904  x18: 0x0000000000000000  x19: 0x0000000000000000
   x20: 0x000000016d640f60  x21: 0x00000001d9f09258  x22: 0x00000002811a05d0  x23: 0x9de4111954e7fd89
   x24: 0x0000000102990000  x25: 0x0000000000000001  x26: 0x000000016d640f30  x27: 0x000000016d640f20
   x28: 0x0000000102990000   fp: 0x000000016d641130   lr: 0x00000001027f6438
    sp: 0x000000016d640ea0   pc: 0x00000001027f6bf0 cpsr: 0x60000000
   esr: 0xf2000001  Address size fault

这是我认为是导致此问题的函数networCall1(),但我不知道在哪里

@objc func networkCall1() {
 var dd:Date
        var StartDate=""
        if let date=Calendar.current.date(byAdding: .month , value: +1, to: Date()){
            dd=Calendar.current.date(byAdding: .day, value:-1, to: date)!
         StartDate=dd.convertDatetoString(format: "yyyy-MM-dd'T'HH:mm:ss")
        }
        let EndDate=Date().convertDatetoString(format: "yyyy-MM-dd'T'HH:mm:ss")
        let session = URLSession.shared
          let string="api call"
          let urlC = URL(string: string)
          guard let url = urlC else {
              print("url fail")
            return
          }
          var request = URLRequest(url: url)
          request.httpMethod = "POST"
          request.setValue("application/json", forHTTPHeaderField: "Content-Type")
        request.setValue("Bearer \(UserDefaults.standard.object(forKey: "token") as! String)", forHTTPHeaderField: "Authorization")
          let json=[
              "StartDate": EndDate,
              "EndDate": StartDate,
              "SubstituteId": UserDefaults.standard.object(forKey: "userId"),
              "OrganizationId": UserDefaults.standard.object(forKey: "organizationId"),
              "DistrictId": UserDefaults.standard.object(forKey: "districtId"),
              "Status": 2,
              "Requested": false
            ] as [String : Any?]
          do {
              let jsonData = try JSONSerialization.data(withJSONObject: json, options: .prettyPrinted)
                  request.httpBody=jsonData
          }catch{
              print("JSON error: \(error.localizedDescription)")
          }
          session.dataTask(with: request) { data, response, error in
            DispatchQueue.main.async{
                self.removeActivityIndicator()
            }
              if error != nil || data == nil {
                  print(error!.localizedDescription)
                  if error!.localizedDescription=="The Internet connection appears to be offline."{
                      DispatchQueue.main.async{
                      let alertController=UIAlertController(title: "No internet connection", message: "Please recheck connectivity and try again.", preferredStyle: .alert)
                      let okAction=UIAlertAction(title: "Ok", style: .default, handler: nil)
                      alertController.addAction(okAction)
                      self.present(alertController, animated: true, completion: nil)
                  }
                  }
                  return
              }
              guard let data=data else{return}
              if let httpresponse = response as? HTTPURLResponse{
              if (httpresponse.statusCode)==200{
                  print("response:\(httpresponse.statusCode)")
                //print(data)
                do{

                    self.UserInformation=try JSONDecoder().decode([jobsData].self,from:data).sorted{ $0.startDate! > $1.startDate! }
                    let grouped = Dictionary(grouping: self.UserInformation, by: {$0.startDate})
                    self.sections = grouped.map{Section(title: $0.key!, jobsData: $0.value)}
                                          .sorted{$0.title < $1.title}
                    DispatchQueue.main.async {
                        self.collectionView.reloadData()
                    }
                }catch{
                        print("Could not decode data coming from API")
                        let dataString = String(data: data, encoding: .utf8)
                        print((dataString!.description))
                }
                  }
                 else if httpresponse.statusCode==401{
                      print(httpresponse.statusCode)
                self.uptimer!.invalidate()
                      DispatchQueue.main.async {
                          let alertController=UIAlertController(title: "Logged Out", message: "login again to continue using this app", preferredStyle: .alert)
                          let okAction=UIAlertAction(title: "Ok", style: .default,handler:{ _ -> Void in
                              let nav=UINavigationController(rootViewController: LoginViewController())
                              nav.modalPresentationStyle = .fullScreen
                              _ = self.navigationController?.present(nav, animated: true)
                          })
                          alertController.addAction(okAction)
                          self.present(alertController, animated: true, completion: nil)
                      }
                  }
              }
              else{ print("Server error")
                      return
              }
          }.resume()
    }

这是timerInvalidate和ScheduledTimerWithTimeInterval1函数

    @objc func timerInvalidate1(){
        self.uptimer!.invalidate()
    }

 @objc func scheduledTimerWithTimeInterval1(){
        if self.viewIfLoaded?.window != nil {
        uptimer = Timer.scheduledTimer(timeInterval: 3, target: self, selector:#selector(networkCall1), userInfo: nil, repeats: true)
uptime!.fire()
        }

我添加了两个NotificationCentre观察器,用于在应用程序进入背景和前景时停止和启动时间

NotificationCenter.default.addObserver(self, selector: #selector(scheduledTimerWithTimeInterval1), name: UIApplication.willEnterForegroundNotification, object: nil)
        NotificationCenter.default.addObserver(self, selector: #selector(timerInvalidate1), name: UIApplication.didEnterBackgroundNotification, object: nil)

并且我已经在ViewController主类下声明了计时器变量,如下所示:

var uptimer:Timer?

请让我知道问题出在哪里,我该如何解决

0 个答案:

没有答案