我做了一个单人类来从任何其他类中访问用户的电子邮件,以便于将数据上传到云端。我能够在第一个视图中打印电子邮件,但当我尝试在其他视图中访问它或回到这个视图时,它显示为空。
class SingletonAccount: NSObject {
static var shared: SingletonAccount = SingletonAccount()
var userEmail: String = "ABCD"
}
我还设置了单子只在appDelegate中初始化,这样它就可以在所有其他类中共享。
class AppDelegate: UIResponder, UIApplicationDelegate {
var window: UIWindow?
var userAccount: SingletonAccount?
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
// Override point for customization after application launch.
userAccount = SingletonAccount.shared
return true
}
下面是启动时出现的第一个视图控制器。
weak var userAccount: SingletonAccount?
override func viewWillAppear(_ animated: Bool) {
super.viewWillAppear(animated)
self.navigationController?.navigationBar.isHidden = true
print(userAccount!.userEmail)
}
override func viewWillDisappear(_ animated: Bool) {
super.viewWillDisappear(animated)
}
override func viewDidLoad() {
super.viewDidLoad()
let tap = UITapGestureRecognizer(target: self, action: #selector(LoginViewController.tapRegister))
let appDelegate = UIApplication.shared.delegate as! AppDelegate
userAccount = appDelegate.userAccount
self.registerLbl.addGestureRecognizer(tap)
// Do any additional setup after loading the view.
}
单人的好处是可以从任何地方访问同一个实例。
声明一个属性 AppDelegate
是没有意义的。只需获得带有
let email = SingletonAccount.shared.userEmail
并宣布 shared
为常数。说明 Singleton 意味着一个常数。
static let shared = SingletonAccount()
而且该类不一定要继承于 NSObject
这甚至不需要单人是一个类。
你在你的视图控制器中声明了一个新的userAccount实例。
let appDelegate = UIApplication.shared.delegate as! AppDelegate
let aVariable = appDelegate.userAccount
我会一直使用SingletonAccount.shared。或者在SingletonAccount类之外全局定义你的单人。
let gSingletonAccount: SingletonAccount = SingletonAccount()
class SingletonAccount: NSObject {
var userEmail: String = "ABCD"
}