- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我在 iOS 和 WatchOS 上制作了一个计数应用程序,我希望应用程序能够同步。当我指望 WatchOS 时,iOS 标签上的数字必须与 WatchOS 上的数字相同,当我指望 iOS 时,WatchOS 标签上的数字必须与一个 iOS 上的数字相同。这两个中的一个正在工作,当我依靠 iOS 时,WatchOS 上的标签正在改变,这意味着它正在工作,但是当我依靠 WatchOS 时,iOS 的标签没有改变。
代码如下:
ViewController.swift
import UIKit
import WatchConnectivity
class ViewController: UIViewController, WCSessionDelegate {
var watchSession : WCSession?
var counter: Int {
return NSUserDefaults().integerForKey("counter")
}
@IBAction func resetButton(sender: AnyObject) {
NSUserDefaults().removeObjectForKey("counter")
countedLabel.text = "\(counter)"
if let message : String = countedLabel.text {
do {
try watchSession?.updateApplicationContext(
["message" : message]
)
} catch let error as NSError {
NSLog("Updating the context failed: " + error.localizedDescription)
}
}
}
@IBOutlet var countedLabel: UILabel!
@IBAction func countUpButton(sender: AnyObject) {
NSUserDefaults().setInteger(counter+1, forKey: "counter")
countedLabel.text = "\(counter)"
if let message : String = countedLabel.text {
do {
try watchSession?.updateApplicationContext(
["message" : message]
)
} catch let error as NSError {
NSLog("Updating the context failed: " + error.localizedDescription)
}
}
}
func session(session: WCSession, didReceiveApplicationContext applicationContext: [String : AnyObject]){
let message : String = applicationContext["message"] as! String
NSUserDefaults().setInteger(Int(message)!, forKey: "counted")
countedLabel.text = ("\(message)")
}
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view, typically from a nib.
if(WCSession.isSupported()){
watchSession = WCSession.defaultSession()
watchSession!.delegate = self
watchSession!.activateSession()
}
}
InterfaceController.swift
import WatchKit
import Foundation
import WatchConnectivity
class InterfaceController: WKInterfaceController, WCSessionDelegate {
var watchSession : WCSession?
var counted: Int {
return NSUserDefaults().integerForKey("counted")
}
@IBAction func resetButton() {
NSUserDefaults().removeObjectForKey("counted")
countedLabel.setText("\(counted)")
if let message : String = "\(counted)" {
do {
try watchSession?.updateApplicationContext(
["message" : message]
)
} catch let error as NSError {
NSLog("Updating the context failed: " + error.localizedDescription)
}
}
}
@IBOutlet var countedLabel: WKInterfaceLabel!
@IBAction func countUpButton() {
NSUserDefaults().setInteger(counted+1, forKey: "counted")
countedLabel.setText("\(counted)")
if let message : String = "\(counted)" {
do {
try watchSession?.updateApplicationContext(
["message" : message]
)
} catch let error as NSError {
NSLog("Updating the context failed: " + error.localizedDescription)
}
}
}
func session(session: WCSession, didReceiveApplicationContext applicationContext: [String : AnyObject]){
let message : String = applicationContext["message"] as! String
NSUserDefaults().setInteger(Int(message)!, forKey: "counted")
countedLabel.setText(message)
}
override func awakeWithContext(context: AnyObject?) {
super.awakeWithContext(context)
// Configure interface objects here.
}
override func willActivate() {
// This method is called when watch view controller is about to be visible to user
super.willActivate()
if(WCSession.isSupported()){
watchSession = WCSession.defaultSession()
// Add self as a delegate of the session so we can handle messages
watchSession!.delegate = self
watchSession!.activateSession()
}
}
问题出在InterfaceController.swift
这部分代码。
if let message : String = "\(counted)" {
do {
try watchSession?.updateApplicationContext(
["message" : message]
)
} catch let error as NSError {
NSLog("Updating the context failed: " + error.localizedDescription)
}
}
虽然在 ViewController.swift
(iOS) 中工作并且那部分代码是:
if let message : String = countedLabel.text {
do {
try watchSession?.updateApplicationContext(
["message" : message]
)
} catch let error as NSError {
NSLog("Updating the context failed: " + error.localizedDescription)
}
}
那么,我可以在 InterfaceController.swift (WatchOS) 上使用什么来代替这个 if let message : String = "\(counted)"{
正如我在ViewController.swift (iOS) 这个if let message : String = countedLabel.text
?
有关更多信息,您可以查看此项目:Counting App (<- 项目的 URL)
最佳答案
我发现了问题,我无法对答案发表评论,因为评论太长了,所以我做了一个新的答案。问题出在 ViewController.swift
而不是使用
func session(session: WCSession, didReceiveApplicationContext applicationContext: [String : AnyObject]){
let message : String = applicationContext["message"] as! String
NSUserDefaults().setInteger(Int(message)!, forKey: "counted")
countedLabel.text = ("\(message)") }
它应该使用
func session(session: WCSession, didReceiveApplicationContext applicationContext: [String : AnyObject]){
dispatch_async(dispatch_get_main_queue()) { [unowned self] in
let message : String = applicationContext["message"] as! String
NSUserDefaults().setInteger(Int(message)!, forKey: "counter")
self.countedLabel.text = ("\(message)")
}
}
关于 swift 2 : How to keep iOS and watchOS2 apps synchronized with WatchConnectivity?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34485075/
在 java 中不使用“同步”关键字的情况下,是否有其他方法可以同步类或方法? 谢谢, 马利卡琼·科卡塔努尔 最佳答案 您可能想查看并发包中引入的对 JDK 5 的更改。 http://java.su
第 1 部分: 假设下面这段代码 void method1(){ synchronized (lockObject){ method2(); System.ou
我有一个 REST 服务器和一个在移动设备上运行的客户端应用程序。客户端有一些数据并希望从服务器获取数据更新。如何以 RESTful 方式在单个事务中执行此操作? 假设客户有以下元素: widge
我有一个多线程 Java 应用程序。在一种方法中,需要同步一个 ArrayList。由于 arrayList 不是线程安全的,所以我必须使用同步。问题是 ArrayList 类型的对象不是对象的成员变
我正在阅读 Android 示例中的 BluetoothChatService.java 文件,有一件事特别让我感到困惑。 方法在多个位置访问静态成员,并且定义为同步。 在另一部分中,正在访问同一个静
我知道为了实现线程安全和同步,我们使用同步块(synchronized block)或方法。 但我无法理解声明- “Java 中的同步块(synchronized block)在某些对象上同步 ” 任
在 Scala 中使用 JDBC 的示例中,有以下代码: this.synchronized { if (!driverLoaded) loadDriver() } 为什么this.synchro
abstract class A { protected abstract int isRunning(); public void concreteMethod() { synchr
有谁可以分享一下他们的经验吗?“我们什么时候在同步方法和同步块(synchronized block)之间进行调用”有任何性能问题吗? 最佳答案 When do we make a call to u
这是我之前问题的后续问题,Is this variable being safely accessed by using synchronization? 对于下面的程序, Class SubClas
我目前正在为 N 体问题实现多线程版本的 Barnes-Hut 算法。虽然该算法有效,但它不是很优化,我正在尝试减少我的程序的运行时间。 我已经确保有多个线程可以准确地找到我正在使用的空间的边界,并意
我有这门课: public class MyClass { public MyClass(){} public void actionA(){ synchronized
又是一个关于ArrayList和synchronize的问题。 我只想知道这段代码到底做了什么: ArrayList list = ....; synchronized (list) { if
我可以在另一个同步块(synchronized block)中包含同步块(synchronized block)以同步另一个对象吗? 例子: synchronized(myObjetc1){
public class ObjectCounter { private static long numOfInstances = 0; public ObjectCounter(){
我在某处读到,对于 various reasons 应该避免 synchronized(this) .然而,我遇到的一些值得尊敬的代码在构造函数中使用了以下内容: public SomeClass(C
Java 为同步代码的关键部分提供了一种非常方便的习惯用法: synchronized(someObject) { // do something really important all b
我有一个 WeakReference 的 Collections.synchronizedList,_components; 我写了类似下面的内容,希望编译者会提示: public boolean a
使用下面两个版本的Singleton Classes有什么区别 首先我使用的是synchronized(Singleton.class) 在第二个我使用同步(Obj)//第一种类型 公共(public
我正在查看 DatagramSocket 的源代码,我发现了这个: public void disconnect() { synchronized (this) { if (i
我是一名优秀的程序员,十分优秀!