- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的应用程序中有以下基本 NSManagedObject:
@objc(LaravelEntity)
class LaravelEntity: NSManagedObject {
static func create(moc: NSManagedObjectContext) -> LaravelEntity? {
let entityName = NSStringFromClass(self)
let ent = NSEntityDescription.insertNewObject(forEntityName: entityName, into: moc) as? LaravelEntity
// We set local changes to true, so it will definitely be pushed to the server
ent?.local_changes = true
return ent
}
static func lastUpdatedRequest() -> NSFetchRequest<LaravelEntity> {
let request : NSFetchRequest<LaravelEntity> = self.self.fetchRequest()
let sort = NSSortDescriptor(key: #keyPath(LaravelEntity.updated_at), ascending: false)
request.sortDescriptors = [sort]
request.fetchLimit = 1
return request
}
}
我也有一些它的子类。它们也在 DataModel 中定义为子类:
@objc(Answer)
class Answer: LaravelEntity {
}
我尝试获取给定类的最后更新的实体,如下所示:
func lastUpdated(klass: LaravelEntity.Type, ctx : NSManagedObjectContext? = nil) -> LaravelEntity? {
do {
let request = klass.lastUpdatedRequest()
let result = try ctx?.fetch(request) ?? self.persistentContainer.newBackgroundContext().fetch(request)
return result.first
} catch {
print("Error while fetching last updated: \(error)!")
}
return nil
}
这在大多数情况下都非常有效。然而,当尝试执行像查询 id 这样简单的操作时,应用程序偶尔会崩溃:lastUpdated?.id == 1
。我不知道为什么这会崩溃,因为所有选项都被安全处理(据我所知)。此外,当查看调试器中的对象时,它们显示得很好(例如,po lastUpdated?.id == 1
在调试器中返回 true)。
我创建了以下示例测试用例来重现该问题,有些一致:
func testLastUpdated() {
for i in 0...1000 {
let cases = [Location.self, Position.self, Answer.self, Question.self]
for kase in cases {
let old = kase.create(moc: sm.persistentContainer.viewContext)
let new = kase.create(moc: sm.persistentContainer.viewContext)
XCTAssert(old != nil, "Couldn't create old \(kase) object!")
XCTAssert(new != nil, "Couldn't create new \(kase) object!")
old?.updated_at = Date(timeIntervalSinceNow: TimeInterval(-60*60*24 + i * 60))
old?.id = Int32(i*2)
new?.updated_at = Date(timeIntervalSinceNow: TimeInterval(i*60))
new?.id = Int32(i*2+1)
try! sm.persistentContainer.viewContext.save()
let last_updated = sm.lastUpdated(klass: kase)
XCTAssert(last_updated?.id == new?.id, "Last updated \(kase) doesn't have the correct id \(last_updated?.id ?? -1) vs \(new?.id ?? -1)!") //It crashes on this line.
}
}
}
但是,即使重复 1000 次,它也只有大约 1/3 的时间在我运行测试时崩溃。此外,它只会在 50 秒左右的迭代中崩溃。
以下是运行上述测试时的调用堆栈:
#0 0x00000001857f8430 in objc_msgSend ()
#1 0x0000000188e1f274 in -[NSPersistentStoreCoordinator _canRouteToStore:forContext:] ()
#2 0x0000000188e21f38 in __110-[NSPersistentStoreCoordinator(_NSInternalMethods) newValueForRelationship:forObjectWithID:withContext:error:]_block_invoke ()
#3 0x0000000188e29af0 in gutsOfBlockToNSPersistentStoreCoordinatorPerform ()
#4 0x0000000185f19048 in _dispatch_client_callout ()
#5 0x0000000185f5b760 in _dispatch_sync_invoke_and_complete_recurse ()
#6 0x0000000185f5b26c in _dispatch_sync_wait ()
#7 0x0000000188e17f74 in _perform ()
#8 0x0000000188e17d2c in -[NSPersistentStoreCoordinator _routeLightweightBlock:toStore:] ()
#9 0x0000000188d4bc94 in -[NSPersistentStoreCoordinator(_NSInternalMethods) newValueForRelationship:forObjectWithID:withContext:error:] ()
#10 0x0000000188d34d7c in _PFFaultHandlerFulfillFault ()
#11 0x0000000188d32a80 in _PFFaultHandlerLookupRow ()
#12 0x0000000188d32334 in _PF_FulfillDeferredFault ()
#13 0x0000000188dd7644 in _pvfk_header ()
#14 0x0000000188dd7450 in _sharedIMPL_pvfk_core_i ()
#15 0x00000001092484a4 in implicit closure #5 in SyncManagerTests.testLastUpdated() at CDTests.swift:74
#16 0x00000001092589d4 in partial apply for implicit closure #5 in SyncManagerTests.testLastUpdated() ()
#17 0x00000001092a5bdc in partial apply for closure #1 in XCTAssertTrue(_:_:file:line:) ()
#18 0x00000001092a5448 in partial apply for closure #1 in _XCTRunThrowableBlock(_:) ()
#19 0x0000000109290224 in thunk for @callee_owned () -> () ()
#20 0x00000001092a6048 in _XCTRunThrowableBlockBridge ()
#21 0x00000001092943bc in specialized _XCTRunThrowableBlock(_:) ()
#22 0x0000000109296118 in specialized XCTAssertTrue(_:_:file:line:) ()
#23 0x000000010929045c in XCTAssert(_:_:file:line:) ()
#24 0x0000000109248010 in SyncManagerTests.testLastUpdated() at CDTests.swift:74
#25 0x0000000109248aa8 in @objc SyncManagerTests.testLastUpdated() ()
#26 0x000000018659d670 in __invoking___ ()
#27 0x000000018647c6cc in -[NSInvocation invoke] ()
#28 0x0000000107996654 in __24-[XCTestCase invokeTest]_block_invoke.275 ()
#29 0x00000001079e4208 in -[XCTMemoryChecker _assertInvalidObjectsDeallocatedAfterScope:] ()
#30 0x0000000107996404 in __24-[XCTestCase invokeTest]_block_invoke ()
#31 0x00000001079dc9d8 in -[XCUITestContext performInScope:] ()
#32 0x000000010799614c in -[XCTestCase invokeTest] ()
#33 0x0000000107997224 in __26-[XCTestCase performTest:]_block_invoke.382 ()
#34 0x00000001079e1a78 in +[XCTContext runInContextForTestCase:block:] ()
#35 0x0000000107996c20 in -[XCTestCase performTest:] ()
#36 0x0000000107992e14 in __27-[XCTestSuite performTest:]_block_invoke ()
#37 0x000000010799283c in -[XCTestSuite _performProtectedSectionForTest:testSection:] ()
#38 0x0000000107992a4c in -[XCTestSuite performTest:] ()
#39 0x0000000107992e14 in __27-[XCTestSuite performTest:]_block_invoke ()
#40 0x000000010799283c in -[XCTestSuite _performProtectedSectionForTest:testSection:] ()
#41 0x0000000107992a4c in -[XCTestSuite performTest:] ()
#42 0x0000000107992e14 in __27-[XCTestSuite performTest:]_block_invoke ()
#43 0x000000010799283c in -[XCTestSuite _performProtectedSectionForTest:testSection:] ()
#44 0x0000000107992a4c in -[XCTestSuite performTest:] ()
#45 0x00000001079eb484 in __44-[XCTTestRunSession runTestsAndReturnError:]_block_invoke ()
#46 0x00000001079a5994 in -[XCTestObservationCenter _observeTestExecutionForBlock:] ()
#47 0x00000001079eb300 in -[XCTTestRunSession runTestsAndReturnError:] ()
#48 0x00000001079823d4 in -[XCTestDriver runTestsAndReturnError:] ()
#49 0x00000001079e0c20 in _XCTestMain ()
#50 0x000000018653e0fc in __CFRUNLOOP_IS_CALLING_OUT_TO_A_BLOCK__ ()
#51 0x000000018653d9cc in __CFRunLoopDoBlocks ()
#52 0x000000018653b6dc in __CFRunLoopRun ()
#53 0x000000018645bfb8 in CFRunLoopRunSpecific ()
#54 0x00000001882f3f84 in GSEventRunModal ()
#55 0x000000018fa302e8 in UIApplicationMain ()
#56 0x000000010137f528 in main at AppDelegate.swift:13
#57 0x0000000185f7e56c in start ()
我不知道什么会导致这样的崩溃,因为所有选项都被正确处理。
编辑 1: 所以崩溃肯定发生在以下行 last_updated?.id == new?.id
(这对我来说仍然没有任何意义)。即使我注释掉所有更改对象的代码并只创建一个对象,它仍然会在 lastUpdated?.id != nil
上(随机)崩溃。
最佳答案
核心数据不是线程安全的。每个上下文都有且只有一个可以读取或写入的线程。如果您违反此规定,则该行为是未定义的。这意味着它可能会崩溃,也可能不会。当您执行不相关的操作时,它可能会等待 10 分钟,然后崩溃。
在您的代码中,您将在 func lastUpdated
内创建一个 newBackgroundContext
(因为您传递的是 nil 上下文)。使用此上下文进行提取是非法的。您只能将此上下文与performBlock
或performBlockAndWait
一起使用。
此外,您在 lastUpdatedRequest
中还有一个额外的 self.
关于ios - EXC_BAD_ACCESS 当安全地展开 NSManagedObject 上的可选内容时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49168641/
我自学了 Obj-C,并且一直在自学 Cocoa,但是将 Core Data 添加到我的程序中却让我非常头疼,因为我需要大量的自定义逻辑。以下是几个让我抓狂的问题。 如果我希望一个托管对象拥有另一个托
我正在创建一个新的 NSManagedObject 并尝试与另一个 NSManagedObject 建立关系,但收到此错误: Illegal attempt to establish a relati
我有一个 NSManagedObject 派生类 OrderMO,它具有 NSDate 类型的属性 OrderDate。我希望 OrderDate 的默认值是尚无关联订单的第一个月的第一个星期一。 为
我正在尝试使用我在该网站上找到的一个与使用 TableView 中的滑动功能从核心数据中删除相关的功能,但我无法弄清楚此错误消息需要我做什么?有人可以帮忙解决这个错误吗? import UIKit i
我正在创建一个名为“translation”的新 NSManagedObject。在翻译中,我需要创建两个额外的 NSManagedObjects 称为“phrase”。有时,其中一个短语分配会引发错
到目前为止,我已经在这个问题上花费了 6 个多小时,确实需要帮助。我编译的 RKCatalog 示例很好。但是当我尝试将示例包含到我的独立项目中时,我遇到了各种问题: 当我从我的主项目运行这个例子时,
我已经将一个 NSManagedObject 对象复制到一个临时的 NSManagedObject 对象中。这样,如果用户输入没有变化,我就可以使用那个临时的 NSManagedObject 对象。否
我正在使用 CoreData 开发 Objective-C,但出现以下错误... *** Terminating app due to uncaught exception 'NSInvalidArg
我正在为我的 iPhone 应用程序使用核心数据模型。我一直在寻找一种在 ManagedObjectContext 之外实例化或使用实体的方法。 (我知道这是不应该做的,我也更多地寻找一种不这样做的方
我正在与 CoreData 作斗争。我想获取以下对象: @interface Email : NSManagedObject { } @property (nonatomic, copy) NSStr
是否可以使用 NSFetchedResultsController 设置一个 UITableView,因为它是 dataSource,其中 Contact Group 决定了部分, Contact G
我正在尝试将对象添加到“一对一”关系中: //1. I create the temporary object for the ServerUpdates entity NSManagedObject
我有一个作者实体。 Author 实体在其 Class 定义中具有一组 Book 实体作为 1:many 关系。 Author 目前不在 managedObjectContext 中。 当我说 [se
这个问题已经存在: Must have a valid NSEntityDescription Objective c? 4年前关闭。 我在核心数据 x code8.3 中遇到错误,数据库已添加 DB
我想观察特定 NSManagedObject 的变化并相应地更新 UI。 我不想保留对NSManagedObject 的引用,因为它可能随时被删除(即通过远程推送通知的结果)。 目前我正在设置 NSF
我正在使用核心数据在 vc1 中保存一个类别,并想将列表属性添加到 vc2 中的列表中。我的数据模型是许多列表属性的一个类别。 我在 vc1 中添加这样的类别: func createNewCateg
我已将 RestKit 链接到一个 xcode 4 项目中,如 GitHub 安装页面所述,但在尝试构建时遇到此错误。有谁知道发生了什么事?我也在 RestKit IRC channel 上提问,正在
首先让我确保我有 X-Code 4.3.2 版本和 iOS 5.1 SDK。我在我的项目中使用以下方法进行核心数据操作。两种方法都会发出相同的警告。即“从结果类型为“NSManagedObject ”
我为我的 Story 模型创建了 NSManagedObject 的子类。我创建了几个新故事,如下所示: Story *newStory = [NSEntityDescription insertNe
我正在努力使我的 NSMangedObjectClass 配置文件可导出/可导出。 我试试this way 如果我在 NSArrays 中写入关系,则导出工作正常,因为 NSSet 没有 writeT
我是一名优秀的程序员,十分优秀!