Java使用Preference类保存上一次记录的方法
本文实例讲述了Java使用Preference类保存上一次记录的方法。分享给大家供大家参考。具体分析如下:
在使用java中JFileChooser选择文件的时候,我们总希望在下次打开的时候能保存上次浏览的记录,即打开文件对话框的时候,总能追溯到上一次的路径。
有一个很愚蠢的方法,那就是在每次打开的时候把选择的文件的路径保存到本地文件中,再打开JFileChooser对话框的时候,先查看是否有内容,如果文件中有内容则按照存储的路径打开对话框。
如果我说Java里面可以不使用JNI的手段操作Windows的注册表你信不信?很多软件 的菜单里都有“Setting”或“Preferences”这样的选项用来设定或修改软件的配置,这些配置信息可以保存到一个像上面所述的配置文件当 中,如果是Windows平台下,也可能会保存到系统注册表中。从JDK 1.4开始,Java在java.util下 加入了一个专门处理用户和系统配置信息的java.util.prefs包, 其中一个类Preferences是 一种比较“高级”的玩意。
从本质上讲,Preferences本身是一个与平台无关的东西,但不同的OS对它的 SPI(Service Provider Interface)的实现却是与平台相关的,因此,在不同的系统中你可能看到首选项保存为本地文件、 LDAP目录项、数据库条目等,像在Windows平台下,它就保存到了系统注册表中。不仅如此,你还可以把首选项导出为XML文件或从XML文件导 入。
① systemNodeForPackage() //根据指定的Class对象得到一个Preferences对象,这个对象的注册表路径是从 “HKEY_LOCAL_MACHINE\”开始的
② systemRoot() //得到以注册表路径HKEY_LOCAL_MACHINE\SOFTWARE\Javasoft \Prefs 为根结点的Preferences对象
③ userNodeForPackage() //根据指定的Class对象得到一个Preferences对象,这个对象的注册表路径 是从“HKEY_CURRENT_USER\”开始的
④ userRoot() //得到以注册表路径HKEY_CURRENT_USER\SOFTWARE\Javasoft \Prefs 为根结点的Preferences对象
下面代码简单演示了Preference类的用法,代码来自网上
import java.util.prefs.Preferences; public class PreferrenceTest { private Preferences prefs; public void setPreference() { // This will define a node in which the preferences can be stored prefs = Preferences.userRoot().node(this.getClass().getName()); String ID1 = "Test1"; String ID2 = "Test2"; String ID3 = "Test3"; // First we will get the values // Define a boolean value System.out.println(prefs.getBoolean(ID1, true)); // Define a string with default "Hello World System.out.println(prefs.get(ID2, "Hello World")); // Define a integer with default 50 System.out.println(prefs.getInt(ID3, 50)); // Now set the values prefs.putBoolean(ID1, false); prefs.put(ID2, "Hello Europa"); prefs.putInt(ID3, 45); // Delete the preference settings for the first value prefs.remove(ID1); System.out.println(prefs.get(ID2, "")); } public static void main(String[] args) { PreferrenceTest test = new PreferrenceTest(); test.setPreference(); } }
这里演示一下如何实现选择文件保存上一次路径
Preferences pref = Preferences.userRoot().node(this.getClass().getName()); String lastPath = pref.get("lastPath", ""); JFileChooser chooser = null; if(!lastPath.equals("")){ chooser = new JFileChooser(lastPath); } else chooser=new JFileChooser(); //MyFileFilter 是自己写的一个文件过滤类,只接受xls格式文件 MyFileFilter filter = new MyFileFilter("xls","只接受xls格式文件,即Excel 2003版文件"); chooser.setFileFilter(filter); int state; //文件选择器返回状态 state=chooser.showOpenDialog(null);//显示打开文件对话框 File file = chooser.getSelectedFile(); //得到选择的文件 pref.put("lastPath",file.getPath()); import java.io.File; import javax.swing.filechooser.FileFilter; //文件过滤器 public class MyFileFilter extends FileFilter { public String ends; //文件后缀 public String description; //文件描述文字 public MyFileFilter (String ends, String description) { //构造函数 this.ends = ends; //设置文件后缀 this.description=description; //设置文件描述文字 } public boolean accept (File file) { //重载FileFilter中的accept方法 if (file.isDirectory ()) //如果是目录,则返回true return true; String fileName = file.getName (); //得到文件名称 if (fileName.toUpperCase ().endsWith (ends.toUpperCase ())) //把文件后缀与可接受后缀转成大写后比较 return true; else return false; } public String getEnds() { return ends; } public void setEnds(String ends) { this.ends = ends; } public String getDescription() { return description; } public void setDescription(String description) { this.description = description; } }
希望本文所述对大家的java程序设计有所帮助。
相关文章
Java EasyExcel实现导出多sheet并设置单元格样式
EasyExcel是一个基于Java的、快速、简洁、解决大文件内存溢出的Excel处理工具,下面我们就来学习一下EasyExcel如何实现导出多sheet并设置单元格样式吧2023-11-11
最新评论