上一篇说了应用数据的应用设置,这篇说说应用文件,应用文件主要分为三种:本地应用文件、漫游应用文件和临时应用文件。

获取根目录方法如下,都是返回一个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学习笔记之应用数据(二)的更多相关文章

  1. windowsphone8.1学习笔记之应用数据(四)

    应用数据的存储格式常用的分为json和xml两种(其实我都想略过这个地方的,json我一直用的是json.net,而wp上操作xml的方式与其他相比也没太多变化). 先说说json数据存储,关于jso ...

  2. windowsphone8.1学习笔记之应用数据(三)

    之前说了如何操作文本文件,如果是图片文件或者其他的二进制文件则需要操作文件的Stream或者Buffer数据.就需要用到DataReader和DataWriter这两个类了,这个的好好的练一下,以后的 ...

  3. windowsphone8.1学习笔记之应用数据(一)

    数据存储分为两种:云存储和应用数据(即本地存储),wp中的应用数据分为两种,一种是应用设置:一种是应用文件.wp的数据相关都是通过ApplicationData来实现,一个程序只有数据存储区. 先说应 ...

  4. Introduction to 3D Game Programming with DirectX 12 学习笔记之 --- 第二十二章:四元数(QUATERNIONS)

    原文:Introduction to 3D Game Programming with DirectX 12 学习笔记之 --- 第二十二章:四元数(QUATERNIONS) 学习目标 回顾复数,以及 ...

  5. Java菜鸟学习笔记--数组篇(三):二维数组

    定义 //1.二维数组的定义 //2.二维数组的内存空间 //3.不规则数组 package me.array; public class Array2Demo{ public static void ...

  6. JavaScript学习笔记之数组(二)

    JavaScript学习笔记之数组(二) 1.['1','2','3'].map(parseInt) 输出什么,为什么? ['1','2','3'].map(parseInt)//[1,NaN,NaN ...

  7. vue2.0学习笔记之路由(二)路由嵌套+动画

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  8. vue2.0学习笔记之路由(二)路由嵌套

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. 微信小程序开发:学习笔记[9]——本地数据缓存

    微信小程序开发:学习笔记[9]——本地数据缓存 快速开始 说明 本地数据缓存是小程序存储在当前设备上硬盘上的数据,本地数据缓存有非常多的用途,我们可以利用本地数据缓存来存储用户在小程序上产生的操作,在 ...

随机推荐

  1. 51Nod 1019 逆序数(线段树)

    题目链接:逆序数 模板题. #include <bits/stdc++.h> using namespace std; #define rep(i, a, b) for (int i(a) ...

  2. 初次使用git,记录使用步骤

      参考:https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000 https://git ...

  3. Android Studio 完美解决 “Android SDK Manager 无法更新“、 ”connection error” 的问题

    一.Android SDK Manager 无法更新 1. 打开SDK Mannger, 并选中启动单独的SDK Mannger.

  4. 报“ Got minus one from a read call”的错误

    在部署应用的时候,有时候应用可以直接启动,但偶尔应用却无法启动,报错信息是: java.sql.SQLRecoverableException: IO Error: Got minus one fro ...

  5. 单页js文件访问数据库

    最原始的编程方式,业务逻辑混杂在html中 <%@ page language="java" import="java.util.*" pageEncod ...

  6. 利用js实现table增加一行

    简单的方法: 用jquery插件,比如设置该table的id为mytable <table id="mytable"> <tr> <td> 第一 ...

  7. 刘下记录:ImageView.scaleType 属性全解析(含视频)

    0. 译序 原文:Working with the ImageView ImageView 有一个经常使用场景:ImageView 的宽度固定,高度等比例缩放.且 ImageView 在 paddin ...

  8. java基础篇2之枚举

    1.为什么要有枚举 问题:要定义星期几或者性别的变量,该怎么定义? 假设用1-7分别表示星期一到星期日,但有人可能会写成int weekday=0; 枚举就是要让某个类型的变量的取值只能为若干个固定值 ...

  9. 2017.2.20 activiti实战--第二章--搭建Activiti开发环境及简单示例(一)搭建开发环境

    学习资料:<Activiti实战> 第一章 认识Activiti 2.1 下载Activiti 官网:http://activiti.org/download.html 进入下载页后,可以 ...

  10. 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= ...