ios - 使用 suiteName 检测 NSUserDefaults 中的更改

标签 ios swift nsuserdefaults watchkit watchos-2

在我的项目中,我使用应用程序组将数据传输到 Apple Watch! 这看起来像这样

let sharedDefaults = NSUserDefaults(suiteName: "group.com.myappname.defaults")
sharedDefaults?.setObject(MyData, forKey: "DataKey")
sharedDefaults?.synchronize()

在 WKInterfaceController 中,我使用以下代码获取数据:

let sharedDefaults = NSUserDefaults(suiteName: "group.com.myappname.defaults")
let MyData = sharedDefaults?.objectForKey("DataKey") as! [[AnyObject]]

一切正常!

现在我尝试检测 sharedDefaults?.objectForKey("DataKey") 中的数据是否发生了变化。我尝试使用 addObserver 方法:

override func willActivate() {
NSUserDefaults(suiteName: "group.com.myappname.defaults")!.addObserver(self, forKeyPath: "DataKey", options: NSKeyValueObservingOptions.New, context: nil)
}

override func observeValueForKeyPath(keyPath: String?, ofObject object: AnyObject?, change: [String : AnyObject]?, context: UnsafeMutablePointer<Void>){
      print("Data Changed")
}

但是“override func observeValueForKeyPath”仅在 WKInterfaceController 将激活时调用并且在我更改 NSUserDefaults(suiteName: "group.com.myappname.defaults") 中的数据时不调用

我也尝试使用 NSNotificationCenter:

override func willActivate() {
let sharedDefaults = NSUserDefaults(suiteName: "group.com.myappname.defaults")
NSNotificationCenter.defaultCenter().addObserver(self, selector: #selector(userDefaultsDidChangeNotificationMethod(_:)), name: NSUserDefaultsDidChangeNotification, object: nil)
}

func userDefaultsDidChangeNotificationMethod(notification: NSNotification){
 print("Data Changed")
}

没用(

我做错了什么?如何检测数据是否发生变化?

最佳答案

我知道这是一个不好的方法,但我没有找到任何其他方法...... 我的方式是无限循环:

var NeedCheking = Bool()


override func willActivate() {
        super.willActivate()
        NeedChecking = true
        CheckDefaults()
}

override func didDeactivate() {
    NeedChecking = false
    super.didDeactivate()
}

func CheckDefaults(){

        let priority = DISPATCH_QUEUE_PRIORITY_DEFAULT
        dispatch_async(dispatch_get_global_queue(priority, 0)) {

        repeat {

            let sharedDefaults = NSUserDefaults(suiteName: "group.com.myappname.defaults")
            let NewData = sharedDefaults?.objectForKey("DataKey") as! [[AnyObject]]
            if NewData != self.MyData {

                dispatch_async(dispatch_get_main_queue()) {
                    self.MyData = NewData
                    //Here do update actions!
               }
            }
            sleep(2)
        }while self.NeedChecking
    }
    }

如果有人知道其他方法,请发布您的解决方案作为此问题的答案!

关于ios - 使用 suiteName 检测 NSUserDefaults 中的更改,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38598016/

相关文章:

swift - 我可以从一个地方全局管理选项卡栏(而不是 Controller )吗?

iphone - 如何使用 Xcode 4 和 OCUnit 运行应用程序测试?

ios - TWICE相关实体的CoreData计数记录

ios - 禁用/启用 UIButton

ios - 使用 NSMutableURLRequest/URLRequest 请求 http

ios - 从 NSUserDefaults 检索到的整数始终为 0

ios - SDWebImage UITableView 单元格图像不持久化

ios - Swift 3.0 中的 UICollectionViewController 错误 : must be initialized with a non-nil layout parameter

swift - 如何避免这种 Force Cast

iphone - iOS 能够在模拟器上读取 plist 文件,但不能在设备上读取