NSUserDefaults类概述

NSUserDefaults类为和默认的系统进行交互提供了一个系统编程接口。默认的系统允许一个应用来定制它的行为以适应用户的喜好。例如,你可以允许用户去决定你的应用程序显示什么样的计量单位或者文件多少时间自动保存。应用程序在用户默认的数据库里分配记录的参数值。这些参数被作为默认值,因为他们通常用于确定一个用用程序在启动时的默认状态或者默认状态的作用方式。
 
在运行时,你可以使用NSUserDefaults对象读取你的应用程序的从一个用户默认数据库使用的默认数据。NSUerDefaults缓存信息,以避免每次获取一个默认值都需要打开用户默认的数据库。同步方法,他会每隔一段时间自动调用,使内存中缓存的信息与用户默认数据库中的信息同步。
 
NSUserDefaults类为访问普通类型的变量提供便利的方法,这些类型有floats,doubles,integers,booleans和URLs。一个默认的对象必须是一个属性列表,是NSData,NSString,NSNumber,NSDate,NSArray或者NSDictionary的实例。如果你想存储其它类型的对象,你应当将其转换成一个NSData的实例。
 
从NSUserDefaults返回的值都是不可变的。即使你设置了一个可变的值。例如,你设置了一个可变的字符串作为“MyStringDefault”的值,你用stringForKey:获取到的字符串将是不可变的。
 
默认数据库是为用户自动创建的。NSUserDefaults目前不支持per-host的偏好(设置)。要做到这一点,你必须使用CFPreferences API.然而,NSUserDefaults正确的读取per-host的偏好,所以你可以安全地混合CFPreferences与NSUserDefaults的代码。
 
如果你的应用程序支持管理的环境,你可以使用一个NSUserDefaults对象去决定哪些对用户有利的喜好是由管理员管理的。受管理的环境中对应的计算机实验室或教室管理员或教师肯能需要以一种特定的方式配置系统。在这种情况下,教师会建立一组默认的偏好设置并且强制对用户使用。如果以这种方式管理偏好设置,应用程序应该防止用户编辑,禁用任何适当的控制。
 
NSUserDefaults类是线程安全的。
 

NSURL的持久性和文件引用的URLs

当使用NSURL实例参考文件内的过程中,重要的是要基于位置的跟踪与文件系统的身份跟踪之间的区别。当坚持一个NSURL,你应该考虑采取这种行为。如果你的应用程序跟踪位于其身份的资源,那么当用户移动文件的时候你可以发觉到,那么你应该明确的解NSURL的书签数据或者对文件引用的URL进行编码。
 
如果你想通过文件的引用跟踪文件,但是当解析时你需要显式控制,你需要关心的把书签数据写到NSUserDefaults中,而不是依靠[NSUserDefaults setURL:forKey:],当你知道你的应用程序将能够处理潜在的I/O所需的用户界面交互时允许你调用[NSURL URLByResolvingBookmarkData:options:relativeToURL:bookmarkDataIsStale:error:]

沙盒注意事项

一个沙盒应用不能访问和修改其他应用的偏好设置。例如,如果你使用addSuiteNamed:方法添加另一个应用程序,但是你不会获得该应用程序的偏好设置。
 
尝试去访问或者修改另一个应用的偏好设置不会导致错误,但是当你你做的时候,世纪上OS X读取和写入位于应用程序容器内的文件,而不是其他应用程序的偏好设置文件。
 

方法详解

获取公有的NSUserDefaults实例

 
  1. + (NSUserDefaults *)standardUserDefaults;
  2. 单例模式,获取NSUserDefaults的一个实例,默认Key值如下:
  3. AppleLanguages,
  4. AppleKeyboardsExpanded,
  5. AppleITunesStoreItemKinds,
  6. AppleLocale,
  7. AppleKeyboards,
  8. NSLanguages,
  9. NSInterfaceStyle
 
  1. + (void)resetStandardUserDefaults;

初始化一个NSUserDefaults的对象


 
  1. - (id)init;
  2. - (id)initWithUser:(NSString *)username;
  3. init是初始化一个公有的defaults对象
  4. initWithUser是初始化一个针对username的对象

注册一个defaults


 
  1. - (void)registerDefaults:(NSDictionary *)registrationDictionary;
  2. 注册的内容(registrationDictionary里的)不写入磁盘

获取Defaults的值


 
  1. - (NSArray *)arrayForKey:(NSString *)defaultName;

 
  1. - (BOOL)boolForKey:(NSString *)defaultName;
  2. 返回一个和defaultName关联的bool值,如果不存在defaultName的话返回NO

 
  1. - (NSData *)dataForKey:(NSString *)defaultName
  2. 返回defaultName所对应的NSData数据,如果defaultName不存在或者返回的数据不是NSData类型的都会返回nil
  3. 返回的数据是不可变类型的

 
  1. - (NSDictionary *)dictionaryForKey:(NSString *)defaultName
  2. 同dataForKey

 
  1. - (float)floatForKey:(NSString *)defaultName
  2. 同dataForKey
  3. 如果defaultName不存在返回0

 
  1. - (NSInteger)integerForKey:(NSString *)defaultName
  2. 同floatForKey
  3. 如果defaultName不存在返回0

 
  1. - (id)objectForKey:(NSString *)defaultName
  2. 同dataForKey

 
  1. - (NSArray *)stringArrayForKey:(NSString *)defaultName
  2. 同dataForKey
  3. 如果defaultName不存在,或者defaultName所对应的不是一个数组,或者数组包含的不是NSString对象都会返回nil

 
  1. - (NSString *)stringForKey:(NSString *)defaultName
  2. 同dataForKey

 
  1. - (double)doubleForKey:(NSString *)defaultName
 
  1. - (NSURL *)URLForKey:(NSString *)defaultName
  2. 同dataForKey
  3. 当调用[NSUserDefaults URLForKey:]时,有以下3种情况:
  4. 1.如果值是NSData,NSData可以作为[NSKeyedUnarchiver unarchiveObjectWithData:]的参数。如果NSData可以作为NSURL存档就返回一个NSURL,否则返回nil
  5. 2.如果值是一个文件引用的URL,那么这个文件引用的URL将会被创建,但是它的书签数据不会被解决直到以后使用NSURL实例
  6. 3.如果值是一个一~开头的字符串,这个字符串将会用[NSString stringByExpandingTildeInPath]扩展,文件将会以NSURL创建

设置Defaults值


 
  1. – setBool:forKey:
  2. – setFloat:forKey:
  3. – setInteger:forKey:
  4. – setDouble:forKey:
  5. – setObject:forKey:
  6. 对象参数只能是属性列表对象:NSData,NSString,NSNumber,NSDate,NSArray,NSDictionary
  7. – setURL:forKey:

移除Defaults值


 
  1. - (void)removeObjectForKey:(NSString *)defaultName

维护持久域


 
  1. - (BOOL)synchronize
  2. 把持久域中的任何改变写到磁盘并且更新磁盘上的任何没有修改的持久域
  3. 如果返回YES表明成功保存到磁盘,相反返回NO
  4. 这个方法是以一定周期间隔自动调用的,如果你不想等待自动调用就可以调用这个方法来同步。(例如,如果你的应用要退出时,或者你想更新磁盘上的defaults即使你没有做任何改变)

 
  1. - (NSDictionary *)persistentDomainForName:(NSString *)domainName
  2. 返回一个特定持久域的键值对

 
  1. - (NSArray *)persistentDomainNames
  2. 返回当前的持久域的名称

 
  1. - (void)removePersistentDomainForName:(NSString *)domainName
  2. 移除对应domainName的持久域

 
  1. - (void)setPersistentDomain:(NSDictionary *)domain forName:(NSString *)domainName
  2. 设置持久域
  3. domainName
  4. This value should be equal to your application's bundle identifier.

访问管理的环境值


 
  1. - (BOOL)objectIsForcedForKey:(NSString *)key
  2. - (BOOL)objectIsForcedForKey:(NSString *)key inDomain:(NSString *)domain

管理搜索列表


 
  1. - (NSDictionary *)dictionaryRepresentation
  2. 返回搜索列表中对应域的所有的键值对

维护不稳定的域


 
  1. – removeVolatileDomainForName:
  2. – setVolatileDomain:forName:
  3. – volatileDomainForName:
  4. – volatileDomainNames

维护套件


 
  1. - (void)addSuiteNamed:(NSString *)suiteName
  2. 一个套件可以在不同的应用之间使用

 
  1. - (void)removeSuiteNamed:(NSString *)suiteName
  2. 移除套件

iOS开发值NSUserDefaults类概述的更多相关文章

  1. IOS开发之支付功能概述

    前言:本随笔将对IOS开发的支付功能进行一个概述. 内容大纲: 一.常见的支付方案简介 二.第三方支付SDK 三.苹果官方支付方案 四.Web支付方案 正文: 一.常见的支付方案简介 在微信支付中 微 ...

  2. iOS开发学习-NSUserDefaults的介绍和用法

    NSUserDefaults类提供了一个与默认系统进行交互的编程接口.NSUserDefaults对象是用来保存,恢复应用程序相关的偏好设置,配置数据等等.默认系统允许应用程序自定义它的行为去迎合用户 ...

  3. ios开发:Core Data概述

    Core Data 概述 2005年的四月份,Apple 发布了 OS X 10.4,在这个版本中 Core Data 框架发布了.Core Data本身既不是数据库也不是数据库访问框架.相反,Cor ...

  4. iOS开发:多线程技术概述

    一.概述 线程(thread):用于指代独立执行的代码段. 进程(process):用于指代一个正在运行的可执行程序,它可以包含多个线程. 任务(task):用于指代抽象的概念,表示需要执行工作. 多 ...

  5. IOS开发--常用工具类收集整理(Objective-C)(持续更新)

    前言:整理和收集了IOS项目开发常用的工具类,最后也给出了源码下载链接. 这些可复用的工具,一定会给你实际项目开发工作锦上添花,会给你带来大大的工作效率. 重复造轮子的事情,除却自我多练习编码之外,就 ...

  6. iOS开发之资讯类App常用分类控件的封装与实现(CollectionView+Swift3.0+)

    今天博客中,我们就来实现一下一些常用资讯类App中常用的分类选择的控件的封装.本篇博客中没有使用到什么新的技术点,如果非得说用到了什么新的技术点的话,那么勉强的说,用到了一些iOS9以后UIColle ...

  7. iOS 开发学习-类的创建与实现,与java语言的对比

    Person.h #import <Foundation/Foundation.h> @interface Person : NSObject { //在{}中定义属性(全局变量/实例变量 ...

  8. ios开发缓存处理类NSCash类的了解与使用

    一:NSCash的基本了解 #import "ViewController.h" @interface ViewController ()<NSCacheDelegate&g ...

  9. iOS开发——时间格式类

    目前只实现了三个类方法, 第一个获取当前时间,以字符创的形式返回,例如"201606161532" 第二个以当前时间与给定时间的时间差(秒) 第三个以当前时间与给定时间的时间差(分 ...

随机推荐

  1. 关于muse-ui 图片不显示的办法。

    直接使用框架提供的例子不能显示图片.需要npm安装 才可以直接使用. npm install --save material-design-icons

  2. JS跳转页面的几种方法

    JS的几种跳转方式: 1. window.open(”url“) 2.用自定义函数 <script> function openWin(tag,obj) { obj.target=&quo ...

  3. linux xfs文件系统无法用readdir获取dirent文件类型d_type则用stat获取暨stat函数讲解

    stat函数讲解 表头文件:    #include <sys/stat.h>             #include <unistd.h>定义函数:    int stat ...

  4. [S5PV210 Linux字符驱动之PWM蜂鸣器驱动

    在SMDK210.C中添加如下beeper_device 结构体 static struct platform_device beeper_device = { .name = "pwm_b ...

  5. shader 变体variants

    https://blogs.unity3d.com/cn/2018/05/14/stripping-scriptable-shader-variants/ variants涉及的是build时间和da ...

  6. vmware虚拟机 C硬盘空间 无损扩容 新测

    摘自: http://hi.baidu.com/y276827893/item/78a351f427726549932af214 其实上面一步的话, 虚拟机设置 里选择磁盘,实用工具里也有这个功能的. ...

  7. LeetCode56:Jump Game

    Given an array of non-negative integers, you are initially positioned at the first index of the arra ...

  8. jsp el 自定义方法 tld 说明

    使用 el 的过程中,需要使用到后端代码处理逻辑,这个时候我们就需要自定义 方法. 如我们后端代码定义如下: package com.rhythmk.common; public class FncH ...

  9. [Tools] Add a Dynamic Tweet Button to a Webpage

    To let people easily share the patio11bot, we'll add a "Tweet" button to the page. You can ...

  10. html中锚点的应用【本页面跳转】

    设置锚点 <a name="top"></a> 同页跳转 <a href="#top">返回顶部</a> 不同页 ...