windowsphone8.1学习笔记之应用数据(二)
上一篇说了应用数据的应用设置,这篇说说应用文件,应用文件主要分为三种:本地应用文件、漫游应用文件和临时应用文件。
获取根目录方法如下,都是返回一个StorageFolder对象(稍后介绍这个)。
//获取本地应用文件 ApplicationData.Current.LocalFolder; //获取漫游应用文件 ApplicationData.Current.RoamingFolder //获取临时应用文件 ApplicationData.Current.TemporaryFolder;
这里细说下漫游应用文件的特点:
1.数据大小有限制:每个应用的可漫游的大小由ApplicationData.RoamingStorageQuota属性决定,如果漫游数据超过其最大值则会挂起其中所有数据复制到云,直到大小不超过最大值。所以用户首选项、链接和小型数据文件使用漫游数据是最好的做法。
2.数据改变时机的不确定性:漫游数据会同步到用户的所有设备中,所以要考虑到应用数据变化对当前应用的影响,可以通过注册ApplicationData.DataChanged事件来进行监控。
3.数据版本的统一性:如果用户在某个设备安装更新版本的应用,应用数据将会本复制到云,而不会将应用数据更新到安装了该应用的其他设备。
4.漫游数据有时间限制:这个时间是30天,如果用户在30天内都不使用该应用,那么30天后应用数据将会从云中删除,换句话说,如果用户在漫游数据有限期内使用应用,那么数据是”永久“的。
5.漫游数据的同步时间依赖网络和设备:这个好理解吧,不多说!
漫游数据还可以通过特殊的设置键来设置漫游数据的同步优先级,这个key为HighPriority,支持复合数据。
ApplicationDataContainer applicationdata = ApplicationData.Current.LocalSettings; application.Values["HighPriority"]=xxxxxx;
来个简单的例子
//获取本地文件夹根目录 StorageFolder localfolder = ApplicationData.Current.LocalFolder; //创建名为MyFolder的文件夹,如果存在则打开它 var folder = await lcoalfolder.CreateFolderAsync("MyFolder",CreationCollisionOption.OpenIfExists); //创建名为Test.txt的文件,存在则替换掉 var file = await folder.CreateFileAsync("Test.txt",CreationCollisionOption.ReplaceExisting); //文本信息的读写可通过StreamReader/StreamWriter和FileIO静态类中的方法来实现的 //StreamReader/StreamWriter默认编码为UTF-8 //流和二进制则是通过DataReader和DataWriter,下篇博客讲 //通过FileIO类实现读写 string fileContent = await FileIO.ReadTextAsync(file); await FileIO.WriterTextAsync(file,"hello world"); //还可以通过如下方式实现读写 var readerstream = await fild.OpenStreamForReadAsync(); var writerstream = await fild.OpenStreamForWriteAsync(); byte[] bytes = Encoding.UTF8.GetBytes("Hello!".ToCharArray()); writerstream.Write(bytes,,bytes.length); //通过StreamReader和StreamWriter实现读写 using(StreamReader reader = new StreamReader(readerstream)) { string fileContent = reader.ReadToEnd(); } using(StreamWriter writer = new StreamWriter(writerstream)) { writer.WriteLine("Test"); } //删除文件 await file.DeleteAsync(); //复制文件 StorageFile fileCopy = await file.CopyAsync("目标文件夹","名称",NameCollisionOption.ReplaceExisting); //重命名 StorageFile file = await file.RenameAsync("newname"); //移动文件 await file.MoveAsync(newFolder,newFileName);
其实这个有点C#基础,对文件操作熟悉点的都没什么问题,就不多说了!自己点一下,各种方法和属性都出来了,都有中文翻译,很明了!
windowsphone8.1学习笔记之应用数据(二)的更多相关文章
- windowsphone8.1学习笔记之应用数据(四)
应用数据的存储格式常用的分为json和xml两种(其实我都想略过这个地方的,json我一直用的是json.net,而wp上操作xml的方式与其他相比也没太多变化). 先说说json数据存储,关于jso ...
- windowsphone8.1学习笔记之应用数据(三)
之前说了如何操作文本文件,如果是图片文件或者其他的二进制文件则需要操作文件的Stream或者Buffer数据.就需要用到DataReader和DataWriter这两个类了,这个的好好的练一下,以后的 ...
- windowsphone8.1学习笔记之应用数据(一)
数据存储分为两种:云存储和应用数据(即本地存储),wp中的应用数据分为两种,一种是应用设置:一种是应用文件.wp的数据相关都是通过ApplicationData来实现,一个程序只有数据存储区. 先说应 ...
- Introduction to 3D Game Programming with DirectX 12 学习笔记之 --- 第二十二章:四元数(QUATERNIONS)
原文:Introduction to 3D Game Programming with DirectX 12 学习笔记之 --- 第二十二章:四元数(QUATERNIONS) 学习目标 回顾复数,以及 ...
- Java菜鸟学习笔记--数组篇(三):二维数组
定义 //1.二维数组的定义 //2.二维数组的内存空间 //3.不规则数组 package me.array; public class Array2Demo{ public static void ...
- JavaScript学习笔记之数组(二)
JavaScript学习笔记之数组(二) 1.['1','2','3'].map(parseInt) 输出什么,为什么? ['1','2','3'].map(parseInt)//[1,NaN,NaN ...
- vue2.0学习笔记之路由(二)路由嵌套+动画
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- vue2.0学习笔记之路由(二)路由嵌套
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 微信小程序开发:学习笔记[9]——本地数据缓存
微信小程序开发:学习笔记[9]——本地数据缓存 快速开始 说明 本地数据缓存是小程序存储在当前设备上硬盘上的数据,本地数据缓存有非常多的用途,我们可以利用本地数据缓存来存储用户在小程序上产生的操作,在 ...
随机推荐
- 51Nod 1019 逆序数(线段树)
题目链接:逆序数 模板题. #include <bits/stdc++.h> using namespace std; #define rep(i, a, b) for (int i(a) ...
- 初次使用git,记录使用步骤
参考:https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000 https://git ...
- Android Studio 完美解决 “Android SDK Manager 无法更新“、 ”connection error” 的问题
一.Android SDK Manager 无法更新 1. 打开SDK Mannger, 并选中启动单独的SDK Mannger.
- 报“ Got minus one from a read call”的错误
在部署应用的时候,有时候应用可以直接启动,但偶尔应用却无法启动,报错信息是: java.sql.SQLRecoverableException: IO Error: Got minus one fro ...
- 单页js文件访问数据库
最原始的编程方式,业务逻辑混杂在html中 <%@ page language="java" import="java.util.*" pageEncod ...
- 利用js实现table增加一行
简单的方法: 用jquery插件,比如设置该table的id为mytable <table id="mytable"> <tr> <td> 第一 ...
- 刘下记录:ImageView.scaleType 属性全解析(含视频)
0. 译序 原文:Working with the ImageView ImageView 有一个经常使用场景:ImageView 的宽度固定,高度等比例缩放.且 ImageView 在 paddin ...
- java基础篇2之枚举
1.为什么要有枚举 问题:要定义星期几或者性别的变量,该怎么定义? 假设用1-7分别表示星期一到星期日,但有人可能会写成int weekday=0; 枚举就是要让某个类型的变量的取值只能为若干个固定值 ...
- 2017.2.20 activiti实战--第二章--搭建Activiti开发环境及简单示例(一)搭建开发环境
学习资料:<Activiti实战> 第一章 认识Activiti 2.1 下载Activiti 官网:http://activiti.org/download.html 进入下载页后,可以 ...
- AngularJS中,<span class="bluetext" ng-bind="ctrl.user.name|uppercase"></span>和{{ctrl.user.name|uppercase}}是等价的,但不等于<span class="bluetext" ng-bind="ctrl.user.name|uppercase"/>
代码下载:https://files.cnblogs.com/files/xiandedanteng/angularjsAttenSpan.rar AngularJS中,<span class= ...