⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 filecleaner.java

📁 Wicket一个开发Java Web应用程序框架。它使得开发web应用程序变得容易而轻松。 Wicket利用一个POJO data beans组件使得它可以与任何持久层技术相结合。
💻 JAVA
字号:
/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements.  See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License.  You may obtain a copy of the License at * *      http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */package org.apache.wicket.util.file;import java.io.File;import java.lang.ref.PhantomReference;import java.lang.ref.ReferenceQueue;import java.util.Collection;import java.util.Vector;/** * Keeps track of files awaiting deletion, and deletes them when an associated marker object is * reclaimed by the garbage collector. *  * @author Noel Bergman * @author Martin Cooper */public class FileCleaner{	/**	 * Queue of <code>Tracker</code> instances being watched.	 */	private static final ReferenceQueue /* Tracker */q = new ReferenceQueue();	/**	 * Collection of <code>Tracker</code> instances in existence.	 */	private static Collection /* Tracker */trackers = new Vector();	/**	 * The thread that will clean up registered files.	 */	private static Thread reaper = new Thread("File Reaper")	{		/**		 * Run the reaper thread that will delete files as their associated marker objects are		 * reclaimed by the garbage collector.		 */		public void run()		{			// Though q is final, it happens while hot deploying that Wicket runs into an infinite			// loop because q == null (NullPointerException). To prevent that happening ...			while (q != null)			{				Tracker tracker = null;				try				{					// Wait for a tracker to remove.					tracker = (Tracker)q.remove();				}				catch (InterruptedException e)				{					break;				}				catch (Exception e)				{					continue;				}				tracker.delete();				tracker.clear();				trackers.remove(tracker);			}		}	};	/**	 * The static initializer that starts the reaper thread.	 */	static	{		reaper.setPriority(Thread.MAX_PRIORITY);		reaper.setDaemon(true);		reaper.start();	}	/**	 * Stop the daemon thread	 */	public static void destroy()	{		if (reaper != null)		{			reaper.interrupt();			// TODO Do we need to manually remove the temp files now?		}	}	/**	 * Track the specified file, using the provided marker, deleting the file when the marker	 * instance is garbage collected.	 * 	 * @param file	 *            The file to be tracked.	 * @param marker	 *            The marker object used to track the file.	 */	public static void track(File file, Object marker)	{		trackers.add(new Tracker(file, marker, q));	}	/**	 * Track the specified file, using the provided marker, deleting the file when the marker	 * instance is garbage collected.	 * 	 * @param path	 *            The full path to the file to be tracked.	 * @param marker	 *            The marker object used to track the file.	 */	public static void track(String path, Object marker)	{		trackers.add(new Tracker(path, marker, q));	}	/**	 * Retrieve the number of files currently being tracked, and therefore awaiting deletion.	 * 	 * @return the number of files being tracked.	 */	public static int getTrackCount()	{		return trackers.size();	}	/**	 * Inner class which acts as the reference for a file pending deletion.	 */	private static class Tracker extends PhantomReference	{		/**		 * The full path to the file being tracked.		 */		private final String path;		/**		 * Constructs an instance of this class from the supplied parameters.		 * 		 * @param file		 *            The file to be tracked.		 * @param marker		 *            The marker object used to track the file.		 * @param queue		 *            The queue on to which the tracker will be pushed.		 */		public Tracker(File file, Object marker, ReferenceQueue queue)		{			this(file.getPath(), marker, queue);		}		/**		 * Constructs an instance of this class from the supplied parameters.		 * 		 * @param path		 *            The full path to the file to be tracked.		 * @param marker		 *            The marker object used to track the file.		 * @param queue		 *            The queue on to which the tracker will be pushed.		 */		public Tracker(String path, Object marker, ReferenceQueue queue)		{			super(marker, queue);			this.path = path;		}		/**		 * Deletes the file associated with this tracker instance.		 * 		 * @return <code>true</code> if the file was deleted successfully; <code>false</code>		 *         otherwise.		 */		public boolean delete()		{			return new File(path).delete();		}	}}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -