- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在开发一个应用程序。我也在应用程序中实现了 Crashlytics。在设备上进行测试时,它产生了我无法解决的奇怪崩溃。我在这里发布崩溃日志
Crashed: com.apple.main-thread
0 Business Card 0x104c951ec specialized closure #1 in PostVC.tableView(_:cellForRowAt:) (<compiler-generated>)
1 Business Card 0x104b22738 thunk for @escaping @callee_guaranteed (@guaranteed FIRDataSnapshot) -> () (<compiler-generated>)
2 Business Card 0x104d39c0c __71-[FIRDatabaseQuery observeSingleEventOfType:withBlock:withCancelBlock:]_block_invoke + 479 (FIRDatabaseQuery.m:479)
3 Business Card 0x104d39e74 __92-[FIRDatabaseQuery observeSingleEventOfType:andPreviousSiblingKeyWithBlock:withCancelBlock:]_block_invoke + 502 (FIRDatabaseQuery.m:502)
4 Business Card 0x104d26724 __43-[FChildEventRegistration fireEvent:queue:]_block_invoke.53 + 74 (FChildEventRegistration.m:74)
5 libdispatch.dylib 0x1a752fbb0 _dispatch_call_block_and_release + 32
6 libdispatch.dylib 0x1a753100c _dispatch_client_callout + 20
7 libdispatch.dylib 0x1a753ccd8 _dispatch_main_queue_callback_4CF + 968
8 CoreFoundation 0x1a7804e20 __CFRUNLOOP_IS_SERVICING_THE_MAIN_DISPATCH_QUEUE__ + 16
9 CoreFoundation 0x1a77ffb7c __CFRunLoopRun + 1980
10 CoreFoundation 0x1a77ff098 CFRunLoopRunSpecific + 480
11 GraphicsServices 0x1b1969534 GSEventRunModal + 108
12 UIKitCore 0x1ab91f7ac UIApplicationMain + 1940
13 Business Card 0x104afa3fc main + 18 (AppDelegate.swift:18)
14 libdyld.dylib 0x1a767ef30 start + 4
这里是 PostVc.swift 文件崩溃的代码。
//
// PostVC.swift
// Business Card
//
// Created by Elev 8 Valley on 1/10/18.
// Copyright © 2018 elev8valley. All rights reserved.
//
import Foundation
import UIKit
import Firebase
class PostVC: UIViewController{
@IBOutlet weak var userImage: UIImageView!
@IBOutlet weak var nameField: UILabel!
@IBOutlet weak var postField: UITextView!
@IBOutlet weak var notificationsTable: UITableView!
var window: UIWindow?
var postId: String?
var notifications = [MyNotification](){
didSet{
}
}
override func viewDidLoad() {
super.viewDidLoad()
self.view.backgroundColor = .white
FirebaseConnection.Connection().notificaionsListerner = self
// FirebaseConnection.Connection().getNotificationList()
UINavigationBar.appearance().tintColor = UIColor.white
//self.navigationController?.navigationBar.barTintColor = darkGrayBackgroundColor
//self.navigationController?.navigationBar.tintColor = UIColor.white
// Do any additional setup after loading the view.
}
override func viewWillAppear(_ animated: Bool) {
super.viewWillAppear(animated)
userImage.layer.masksToBounds = true
userImage.layer.cornerRadius = userImage.frame.width / 2
userImage.layer.borderColor = UIColor.white.cgColor
userImage.layer.borderWidth = 2
retrieveUserProfile()
}
func retrieveUserProfile(){
if let pid = self.postId{
var path = "Posts/\(pid)"
self.window = Popup.show(vc: self)
let ref = Database.database().reference(withPath: path)
ref.observeSingleEvent(of: .value, with: { (snapshot) in
if let w = self.window{
DispatchQueue.main.async {
Popup.hide(alertWindow: w)
}
}
if snapshot.exists(){
if let dic = snapshot.value as? NSDictionary{
DispatchQueue.main.async {
self.postField.text = dic["postContent"] as? String
//self.nameField.text = dic["postCreatorName"] as? String
if let postCreatorId = dic["postCreatorId"] as? String{
var path = "Profile"
path = "\(path)/\(postCreatorId).png"
let ref = Storage.storage().reference(withPath: path)
downloadImage(ref: ref, imageView: self.userImage)
self.downloadUserDetails(id: postCreatorId)
}
var not = [MyNotification]()
for p in self.notifications{
if let pid = p.postId, let id = self.postId{
if pid == id{
not.append(p)
}
}
}
self.notifications = not
self.notificationsTable.reloadData()
}
}
}
else{
MessageBox.showSnackbar(message: "Post deleted")
self.navigationController?.popToRootViewController(animated: true)
print("No snapshot")
}
})
}
}
private func downloadUserDetails(id: String){
let path = "users/\(id)"
Database.database().reference(withPath: path).observeSingleEvent(of: .value, with: {
(snapshot) in
if let dic = snapshot.value as? NSDictionary{
DispatchQueue.main.async {
if let name = dic["name"] as? String{
self.nameField.text = name
}
}
}
})
}
}
extension PostVC : UITableViewDelegate, UITableViewDataSource{
func tableView(_ tableView: UITableView, viewForHeaderInSection section: Int) -> UIView? {
let header = UIView()
header.backgroundColor = UIColor.clear
return header
}
func tableView(_ tableView: UITableView, heightForHeaderInSection section: Int) -> CGFloat {
return 5
}
func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
if notifications[indexPath.section].notificationType == NotificationType.Request{
return 120
}
return 100
}
func numberOfSections(in tableView: UITableView) -> Int {
return notifications.count
}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return 1
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let not = notifications[indexPath.section]
var gencell = tableView.dequeueReusableCell(withIdentifier: "notificationCell", for: indexPath)
if not.notificationType == NotificationType.Comment || not.notificationType == NotificationType.Like{
var cell = gencell as! RequestNotificationCell
if let name = not.fromName, !name.isEmpty{
cell.customView?.nameLabel.text = not.fromName
cell.customView?.descriptionLabel.text = not.message
cell.customView?.timeLabel.text = not.time?.timeAgoDisplay()
}
else{
if let id = not.from.id{
Database.database().reference(withPath: "users/\(id)").observeSingleEvent(of: .value, with: { (snapshot) in
if let dic = snapshot.value as? NSDictionary{
let user = CircleUser(dic: dic)
if let name = dic.value(forKey: "name") as? String{
self.notifications[indexPath.section].fromName = name
cell.customView?.nameLabel.text = not.fromName
cell.customView?.descriptionLabel.text = not.message
cell.customView?.timeLabel.text = not.time?.timeAgoDisplay()
}
}
})
}
}
var path = "Profile"
if let uid = not.from.id{
path = "\(path)/\(uid).png"
}
let ref = Storage.storage().reference(withPath: path)
let placeHolder = #imageLiteral(resourceName: "boy")
//let task = cell.customView?.image.sd_setImage(with: ref, placeholderImage: nil)
cell.customView?.image.sd_setImage(with: ref, placeholderImage: #imageLiteral(resourceName: "client"), completion: { (image, error, cache, ref) in
if let image = image{
}
})
cell.customView?.addBtn.isHidden = true
cell.customView?.rejectBtn.isHidden = true
return cell
}
return gencell
}
func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
let not = self.notifications[indexPath.section]
}
}
extension PostVC : NotificationListener{
func notificationsRetrieved(notifications: [MyNotification]) {
self.notifications = notifications
if notifications.count > 0{
//reload data
notificationsTable.reloadData()
}
else{
MessageBox.Show(message: "No Notifications", title: "Empty", view: self)
}
}
}
我在 stackoverflow 上的一个线程上搜索它是一个内存泄漏,但我不知道这个内存泄漏到底发生在哪里。
这是有关它如何崩溃的视频。 Crash !
最佳答案
首先要做的是找出漏水的地方。为此,您可以设置断点并使用 Debug Memory Graph 查看内存中的内容以及引用内存的内容。内存图还会针对已泄漏的实例放置指示器,以帮助您解决这个问题。
了解泄漏的原因后,您可以查看代码中创建和引用代码的点,找出泄漏的原因。
崩溃分析和崩溃日志(如您发布的那样)有助于识别崩溃的时间。但是像内存泄漏这样的事情通常出现在代码的其他地方,很少在崩溃报告中说明。
最后,根据我的经验,崩溃通常不是由内存泄漏引起的,除非某些东西已经泄漏并且其中一些内部引用被取消了。然后,如果它是由通知或其他事件触发的,它可能会因意外的 nil 而崩溃。内存泄漏通常只是消耗内存或触发奇怪的行为,因为多个对象竞争执行某事而只有一个应该运行。
关于ios - 应用程序崩溃,我无法找到原因,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58576864/
我有一段代码看起来像这样: void update_clock(uint8_t *time_array) { time_t time = *((time_t *) &time_array[0]
应用程序崩溃了 :( 请帮助我.. 在这方面失败了。我找不到错误?该应用程序可以连接到 iTunesConnect 但它会出错。 谁能根据下面的崩溃报告判断问题出在哪里? share_with_app
小二是新来的实习生,作为技术 leader,我给他安排了一个非常简单的练手任务,把前端 markdown 编辑器里上传的图片保存到服务器端,结果他真的就把图片直接保存到了服务器上,这下可把我气坏了,就
我正在创建一个函数,它将目录路径作为参数传递,或者如果它留空,则提示用户输入。 我已经设置了我的 PATH_MAX=100 和 if 语句来检查 if ((strlen(folder path) +
我已将“arial.ttf”文件(从我的/Windows/Fonts 文件夹中获取)加载到内存中,但是将其传递到 FT_New_Memory_Face 时会崩溃(在 FT_Open_Face 中的某处
我正在尝试在我的计算机上的两个控制台之间进行 rtsp 流。 在控制台 1 上,我有: ffmpeg -rtbufsize 100M -re -f dshow -s 320x240 -i video=
我正在尝试使用 scio_beast在一个项目中。我知道它还没有完成,但这并不重要。我已经设法让它工作得很好。 我现在正在尝试连接到 CloudFlare 后面的服务器,我知道我需要 SNI 才能工作
我有一个带有关联宏的下拉列表,如下所示: Sub Drop() If Range("Hidden1!A1") = "1" Then Sheets("Sheet1").Se
我对 bash 很陌生。我要做的就是运行这个nvvp -vm /usr/lib64/jvm/jre-1.8.0/bin/java无需记住最后的路径。我认为 instafix 就是这样做...... n
我在 Windows 上使用 XAMPP 已经两年左右了,它运行完美,没有崩溃没有问题。 (直到四个月前。) 大约四个月前,我们将服务器/系统升级到了更快的规范。 这是旧规范的内容 - Windows
我面临着一个非常烦人的 android 崩溃,它发生在大约 1% 的 PRODUCTION session 中,应用程序始终在后台运行。 Fatal Exception: android.app.Re
尝试使用下面的函数: public void createObjectType() { try { mCloudDB.createObjectType(ObjectTypeIn
由于我正在进行的一个项目,我在 CF11 管理员中弄乱了类路径,我设法使服务器崩溃,以至于我唯一得到的是一个漂亮的蓝屏和 500 错误.我已经检查了日志,我会把我能做的贴在帖子的底部,但我希望有人会启
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 10 个月前关闭。 Improve
我最近从 xcode 3.x 更新到 4.2,当我在 4.2 中运行应用程序时,我遇到了核心数据问题。我还更新到了 iOS 5,所以问题可能就在那里,我不太确定。 这些应用程序在 3.x 中运行良好,
我是一个相对较新的 iPhone 应用程序开发人员,所以我的知识有点粗略,所以如果这是一个微不足道的问题,请原谅我。 我有一个导航应用程序,它通过在navigationController对象上调用p
if ([MFMailComposeViewController canSendMail]) { MFMailComposeViewController *mailViewController
你能帮我吗? 我正在设置 UILocalNotification,当我尝试设置其 userInfo 字典时,它崩溃了。 fetchedObjects 包含 88 个对象。 这是代码: NSDi
为什么我的代码中突然出现 NSFastEnumeration Mutation Handler 崩溃。我很茫然为什么会突然出现这个崩溃以及如何解决它。 最佳答案 崩溃错误: **** 由于未捕获的异常
当我从表中删除行时,我的应用程序崩溃了。这是我检测到错误和堆栈跟踪的来源。谢谢! //delete row from database - (void)tableView:(UITableView *
我是一名优秀的程序员,十分优秀!