Android学习第六天————android中数据存储的五种方式

数据的存取
1、通过键值对的形式来存读数据
SharedPreferences存储共享变量的文件路径位于“/data/data/应用程序包/shared_prefs”目录下
获取SharedPreferences的两种方式:
1 调用Context对象的getSharedPreferences()方法
2 调用Activity对象的getPreferences()方法
两种方式的区别:
调用Context对象的getSharedPreferences()方法获得的SharedPreferences对象可以被同一应用程序下的其他组件共享.
调用Activity对象的getPreferences()方法获得的SharedPreferences对象只能在该Activity中使用.
 
SharedPreferences的四种操作模式:
Context.MODE_PRIVATE
Context.MODE_APPEND
Context.MODE_WORLD_READABLE
Context.MODE_WORLD_WRITEABLE
 
Context.MODE_PRIVATE:为默认操作模式,代表该文件是私有数据,只能被应用本身访问,在该模式下,写入的内容会覆盖原文件的内容
Context.MODE_APPEND:模式会检查文件是否存在,存在就往文件追加内容,否则就创建新文件.
Context.MODE_WORLD_READABLE和Context.MODE_WORLD_WRITEABLE用来控制其他应用是否有权限读写该文件.
MODE_WORLD_READABLE:表示当前文件可以被其他应用读取.
MODE_WORLD_WRITEABLE:表示当前文件可以被其他应用写入.
将数据保存至SharedPreferences:
	SharedPreferences preferences=getSharedPreferences("user",Context.MODE_PRIVATE);
		Editor editor=preferences.edit();
		String name="xixi";
		String age="22";
		editor.putString("name", name);
		editor.putString("age", age);
		editor.commit();
 	SharedPreferences sharedPreferences =getPreferences(Activity.MODE_PRIVATE);//有默认的文件名
		Editor editor = sharedPreferences.edit();
		editor.putInt("age", 23);
		editor.putString("name", "小张");
		editor.commit();// 提交保存的数据
	从SharedPreferences获取数据:
	SharedPreferences preferences=getSharedPreferences("user", Context.MODE_PRIVATE);
	String name=preferences.getString("name", "defaultname");
	String age=preferences.getString("age", "0");



2、通过Activity提供的文件存取数据
<span style="font-size:18px;">// 通过Activity提供的文件存储
	public void save() {
		FileOutputStream fileOutputStream = null;
		PrintStream printStream = null;
		try {
			fileOutputStream = openFileOutput("hdh.txt", Activity.MODE_PRIVATE);
			printStream = new PrintStream(fileOutputStream);
			printStream.println("姓名:小张");
			printStream.println("年龄:23");
		} catch (FileNotFoundException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} finally {
			if (printStream != null) {
				printStream.close();
			}
			if (fileOutputStream != null) {
				try {
					fileOutputStream.close();
				} catch (IOException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
			}
		}
	}


	// 通过Activity提供的文件读取方法来读取
	public void read() {
		FileInputStream fileInputStream = null;
		Scanner scanner = null;
		TextView textView = (TextView) findViewById(R.id.text);
		try {
			fileInputStream = openFileInput("hdh.txt");
			scanner = new Scanner(fileInputStream);
			while (scanner.hasNext()) {
				textView.append(scanner.next() + "\n");
			}
		} catch (FileNotFoundException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} finally {
			if (scanner != null) {
				scanner.close();
			}
			if (fileInputStream != null) {
				try {
					fileInputStream.close();
				} catch (IOException e) {
					e.printStackTrace();
				}
			}
		}
	}</span>




第一参数用于指定文件名称,不能包含路径分隔符“/” ,如果文件不存在,Android 会自动创建它。创建的文件保存在/data/data/<package name>/files目录
第二参数用于指定操作模式
Context.MODE_PRIVATE:为默认操作模式,代表该文件是私有数据,只能被应用本身访问,在该模式下,写入的内容会覆盖原文件的内容,如果想把新写入的内容追加到原文件中。可以使用Context.MODE_APPEND
Context.MODE_APPEND:模式会检查文件是否存在,存在就往文件追加内容,否则就创建新文件。
Context.MODE_WORLD_READABLE和Context.MODE_WORLD_WRITEABLE用来控制其他应用是否有权限读写该文件。
Context.MODE_WORLD_READABLE:表示当前文件可以被其他应用读取;MODE_WORLD_WRITEABLE:表示当前文件可以被其他应用写入。


android有一套自己的安全模型,当应用程序(.apk)在安装时系统就会分配给他一个userid,当该应用要去访问其他资源比如文件的时候,就需要userid匹配。
默认情况下,任何应用创建的文件,sharedpreferences,数据库都应该是私有的(位于/data/data/<package name>/files),其他程序无法访问。除非在创
建时指定了Context.MODE_WORLD_READABLE或者Context.MODE_WORLD_WRITEABLE ,只有这样其他程序才能正确访问。


3、通过IO流存取数据
<span style="font-size:18px;">// 通过IO流
	public void iowrite() {
		if(Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)){//判断外置存储是否可用
			//获得文件
			File file = new File(Environment.getExternalStorageDirectory()+File.separator+"sd"+File.separator+"hehehe.txt");
			if (!file.getParentFile().exists()) {
				file.getParentFile().mkdir();
			}
			PrintStream printStream = null;
			try {
				printStream = new PrintStream(new FileOutputStream(file));
				printStream.println("回沙河哈哈1111111111111111111111");
			} catch (FileNotFoundException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			} finally {
				if (printStream != null) {
					printStream.close();
				}
			}
		}else{
			Toast.makeText(this, "SD卡不可用", Toast.LENGTH_SHORT);
		}
	}
	//通过IO读取数据
	public void ioRead(){
		TextView textView = (TextView) findViewById(R.id.text);
		if(Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)){
			File file = new File(Environment.getExternalStorageDirectory()+File.separator+"sd"+File.separator+"hehehe.txt");
			if (!file.getParentFile().exists()) {
				file.getParentFile().mkdir();
			}
			Scanner scanner = null;
			try {
				scanner = new Scanner(new FileInputStream(file));
				while(scanner.hasNext()){
					textView.append(scanner.next()+"\n");
				}
			} catch (FileNotFoundException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			} finally {
				if (scanner != null) {
					scanner.close();
				}
			}
		}else{
			Toast.makeText(this, "SD卡不可用", Toast.LENGTH_SHORT);
		}
	}</span>


4、通过资源文件获得数据,在res文件夹中创建一个raw文件夹(可被系统识别)然后在其中创建问价
<span style="font-size:18px;">//通过资源文件获得数据
	public void rawread(){
		TextView textView = (TextView) findViewById(R.id.text);
		Resources resources=getResources();
		InputStream inputStream=resources.openRawResource(R.raw.hdh);
		Scanner scanner=new Scanner(inputStream);
		while(scanner.hasNext()){
			textView.append(scanner.next());
		}
		scanner.close();
	}</span>


5、通过Document来存取数据
<span style="font-size:18px;">//通过Document来存储
	public void document(){
		EditText nameText=(EditText)findViewById(R.id.nametext);
		EditText ageText=(EditText)findViewById(R.id.agetext);


		DocumentBuilderFactory documentBuilderFactory=DocumentBuilderFactory.newInstance();
		 try {
			 DocumentBuilder documentBuilder=documentBuilderFactory.newDocumentBuilder();
			 Document document=documentBuilder.newDocument();
			 //创建节点
			 Element userElement=document.createElement("user");
			 Element nameElement=document.createElement("name");
			 Element ageElement=document.createElement("age");
			 //给节点赋值
			 nameElement.appendChild(document.createTextNode(nameText.getText().toString()));
			 ageElement.appendChild(document.createTextNode(ageText.getText().toString()));
			 //将节点一层一层嵌套
			 userElement.appendChild(nameElement);
			 userElement.appendChild(ageElement);
			 document.appendChild(userElement);
			 //将xml转换至文本
			 TransformerFactory transformerFactory=TransformerFactory.newInstance();
			 Transformer transformer=transformerFactory.newTransformer();
			 DOMSource domSource=new DOMSource(document);
			 if(Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)){
				File file=new File(Environment.getExternalStorageDirectory()+File.separator+"sd"+File.separator+"userdate.xml"); 
				StreamResult stream=new StreamResult(file);
				transformer.transform(domSource, stream);
			 }
			 
		} catch (Exception e) {
			e.printStackTrace();
		}
		
	}
	public void resultxml(){
		 if(Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)){
				File file=new File(Environment.getExternalStorageDirectory()+File.separator+"sd"+File.separator+"userdate.xml"); 
				DocumentBuilderFactory documentBuilderFactory=DocumentBuilderFactory.newInstance();
				 try {
					DocumentBuilder documentBuilder=documentBuilderFactory.newDocumentBuilder();
					Document document=documentBuilder.parse(file);
					NodeList nodeList=document.getElementsByTagName("user");
					for(int i=0;i<nodeList.getLength();i++){
						Element element=(Element)nodeList.item(i);
						String name=element.getElementsByTagName("name").item(0).getFirstChild().getNodeValue();
						String age=element.getElementsByTagName("age").item(0).getFirstChild().getNodeValue();
						System.out.println(name+","+age);
					}
					//System.out.println(nodeList.item(0).getFirstChild().getFirstChild().getNodeValue());
				 } catch (Exception e) {
					
					e.printStackTrace();
				}
			 }
	}</span>


存储XML为文本文档
(1)首先得到DOM解析器的工厂实例
DocumentBuilderFactory docmfac=DocumentBuilderFactory.newInstance();
(2)然后从DOM工厂中获得DOM解析器
DocumentBuilder dombuilder=docmfac.newDocumentBuilder();
(3)新建根节点
Document document=documentBuilder.newDocument();
(4)创建节点
Element userElement=document.createElement("user");
Element nameElement=document.createElement("name");
(5)给节点赋值
nameElement.appendChild(document.createTextNode(nameText.getText().toString()));
(6)确定节点关系
userElement.appendChild(nameElement);
document.appendChild(userElement);
(7)将XML转换成文本
TransformerFactory transformerFactory=TransformerFactory.newInstance();
Transformer transformer=transformerFactory.newTransformer();
DOMSource domSource=new DOMSource(document);
if(Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)){
File file=new File(Environment.getExternalStorageDirectory()+File.separator+"sd"+File.separator+"userdate.xml"); 
StreamResult stream=new StreamResult(file);
transformer.transform(domSource, stream);
}
解析XML文件
(1)首先得到DOM解析器的工厂实例
DocumentBuilderFactory docmfac=DocumentBuilderFactory.newInstance();
(2)然后从DOM工厂中获得DOM解析器
DocumentBuilder dombuilder=docmfac.newDocumentBuilder();
(3)把要解析的XML文档转换为输入流,以便DOM解析器解析它
InputStream is=new FileInputStream(test1.xml);
(4)解析XML文档的输入流,得到一个Document
Document doc=dombuilder.parse(is);
(5)得到XML文档的根节点
Element root =doc.getDocumentElement();
(6)得到节点的子节点
NodeList books=root.getChildNodes();













Mopria Print Service 2.3推出新的移动打印功能,支持用户使用 安卓设备的“分享”功能进行打印 拓展移动打印功能,方便用户使用其最喜爱的应用程序的“分享”选项打印照片、文本 、网页等 加州圣拉蒙 – 2017年11月15日– 致力于推动全行业移动打印标准的全球非盈利性会员制组织 Mopria®联盟今日发布Mopria Print Service 2.3,以扩大移动打印支持,允许用户使用诸多最喜爱的 应用程序的“分享”功能进行打印。此外,Mopria Print Service 2.3还与Android 8.0 Oreo™兼容,后 者的默认打印解决方案采用Mopria核心技术,支持通过1亿多台经Mopria认证的打印机实现轻松移 动打印。所有安卓设备可在Google Play™商店下载其最新版。 Mopria Print Service 2.3利用Facebook、Flipboard、LinkedIn、Twitter和Pinterest等诸多 备受欢迎的应用现有的“分享”功能,使用户能够轻松打印。当使用“分享”功能时,用户 将看到其包含Mopria Print Service选项,该选项位于电子邮件和消息选项下方。“分享” 图标位于醒目位置,用户只需选择Mopria Print Service选项、选择打印机、调整设置并 打印即可。 该新版本还支持沿多个方向打孔、折边、装订等分页装订选项,同时提供新界面,新增一 项便于用户快速查看可供使用的打印机并确定其状态的功能。该新界面提供便捷的起点, 方便用户添加或隐藏打印机、访问Mopria设置、排除打印故障以及查看经Mopria认证的 打印机列表。该新界面包含教程,已将这一用户请求最多的功能添加至该项服务,为新 用户提供移动打印流程指导及建议。 Mopria联盟指导委员会主席Brent Richtsmeier表示:“我们将继续为Mopria Print Service 添加功能,旨在使安卓设备的移动打印体验尽可能轻松便捷。利用全球最受欢迎的应用 的分享功能新增的打印选项,用户将重新发现移动打印的便利。” 自发布以来,Mopria Print Service已支持通过安卓智能手机和平板电脑连接经Mopria认 证的打印机实现打印。Mopria Print Service允许用户轻松自定义彩色打印、打印份数、 双面打印、纸张尺寸、页面打印范围、介质类型和打印方向等打印设置,同时还可以定制 用户身份验证、点针式打印和会计功能等工作场所功能,而且不需要安装特定打印机品牌 的应用程序。 自创始人佳能、惠普、三星和施乐成立Mopria联盟以来的四年里,该非盈利性会员制组 织成员已增加至21个,他们代表着全球打印机行业。除创始公司之外,Mopria联盟目前 包括:Adobe、柯尼卡美能达、高通、利盟、京瓷、东芝、Brother、爱普生、富士施乐 、微软、NEC、Pantum、理光、YSoft、夏普、戴尔和致伸科技(Primax)。 Mopria技术目前设备安装数量已超过7亿台,预计不出一年便会超过10亿台。在继续努力 使移动打印变得轻松便捷的同时,Mopria联盟还将进一步专注于云打印和扫描标准化。 Mopria联盟的目标在于促使这些解决方案为消费者和企业用户变得更加方便可及、直观 简便。如需获取经Mopria认证的打印机和打印附件的最新列表,敬请访问: http://mopria.org/certified-products。 关于Mopria®联盟 Mopria®联盟是一个非盈利性会员制组织,由全球领先的科技公司组成,其成立初衷为简 化智能手机、平板电脑和其他设备的打印操作。该联盟制定并推广一系列技术标准,旨在 提供连接不同设备和移动操作系统的直观体验。这些标准的普及使用户能够与各种品牌的 打印机进行无缝交互。此外,对新移动设备或打印机而言,将无需进行应用程序的下载和 安装。利用支持Mopria的移动设备寻找经Mopria认证的打印机和附件实现轻松打印,可 在www.mopria.org了解详情或者在Google Play商店下载最新版Mopria软件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值