亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? dailyrollingfileappender.java

?? log4j的源碼
?? JAVA
字號:
/* * Copyright 1999-2005 The Apache Software Foundation. *  * Licensed 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.log4j;import java.io.IOException;import java.io.File;import java.text.SimpleDateFormat;import java.util.Date;import java.util.GregorianCalendar;import java.util.Calendar;import java.util.TimeZone;import java.util.Locale;import org.apache.log4j.helpers.LogLog;import org.apache.log4j.spi.LoggingEvent;/**   DailyRollingFileAppender extends {@link FileAppender} so that the   underlying file is rolled over at a user chosen frequency.   <p>The rolling schedule is specified by the <b>DatePattern</b>   option. This pattern should follow the {@link SimpleDateFormat}   conventions. In particular, you <em>must</em> escape literal text   within a pair of single quotes. A formatted version of the date   pattern is used as the suffix for the rolled file name.   <p>For example, if the <b>File</b> option is set to   <code>/foo/bar.log</code> and the <b>DatePattern</b> set to   <code>'.'yyyy-MM-dd</code>, on 2001-02-16 at midnight, the logging   file <code>/foo/bar.log</code> will be copied to   <code>/foo/bar.log.2001-02-16</code> and logging for 2001-02-17   will continue in <code>/foo/bar.log</code> until it rolls over   the next day.   <p>Is is possible to specify monthly, weekly, half-daily, daily,   hourly, or minutely rollover schedules.   <p><table border="1" cellpadding="2">   <tr>   <th>DatePattern</th>   <th>Rollover schedule</th>   <th>Example</th>   <tr>   <td><code>'.'yyyy-MM</code>   <td>Rollover at the beginning of each month</td>   <td>At midnight of May 31st, 2002 <code>/foo/bar.log</code> will be   copied to <code>/foo/bar.log.2002-05</code>. Logging for the month   of June will be output to <code>/foo/bar.log</code> until it is   also rolled over the next month.   <tr>   <td><code>'.'yyyy-ww</code>   <td>Rollover at the first day of each week. The first day of the   week depends on the locale.</td>   <td>Assuming the first day of the week is Sunday, on Saturday   midnight, June 9th 2002, the file <i>/foo/bar.log</i> will be   copied to <i>/foo/bar.log.2002-23</i>.  Logging for the 24th week   of 2002 will be output to <code>/foo/bar.log</code> until it is   rolled over the next week.   <tr>   <td><code>'.'yyyy-MM-dd</code>   <td>Rollover at midnight each day.</td>   <td>At midnight, on March 8th, 2002, <code>/foo/bar.log</code> will   be copied to <code>/foo/bar.log.2002-03-08</code>. Logging for the   9th day of March will be output to <code>/foo/bar.log</code> until   it is rolled over the next day.   <tr>   <td><code>'.'yyyy-MM-dd-a</code>   <td>Rollover at midnight and midday of each day.</td>   <td>At noon, on March 9th, 2002, <code>/foo/bar.log</code> will be   copied to <code>/foo/bar.log.2002-03-09-AM</code>. Logging for the   afternoon of the 9th will be output to <code>/foo/bar.log</code>   until it is rolled over at midnight.   <tr>   <td><code>'.'yyyy-MM-dd-HH</code>   <td>Rollover at the top of every hour.</td>   <td>At approximately 11:00.000 o'clock on March 9th, 2002,   <code>/foo/bar.log</code> will be copied to   <code>/foo/bar.log.2002-03-09-10</code>. Logging for the 11th hour   of the 9th of March will be output to <code>/foo/bar.log</code>   until it is rolled over at the beginning of the next hour.   <tr>   <td><code>'.'yyyy-MM-dd-HH-mm</code>   <td>Rollover at the beginning of every minute.</td>   <td>At approximately 11:23,000, on March 9th, 2001,   <code>/foo/bar.log</code> will be copied to   <code>/foo/bar.log.2001-03-09-10-22</code>. Logging for the minute   of 11:23 (9th of March) will be output to   <code>/foo/bar.log</code> until it is rolled over the next minute.   </table>   <p>Do not use the colon ":" character in anywhere in the   <b>DatePattern</b> option. The text before the colon is interpeted   as the protocol specificaion of a URL which is probably not what   you want.   @author Eirik Lygre   @author Ceki G&uuml;lc&uuml; */public class DailyRollingFileAppender extends FileAppender {  // The code assumes that the following constants are in a increasing  // sequence.  static final int TOP_OF_TROUBLE=-1;  static final int TOP_OF_MINUTE = 0;  static final int TOP_OF_HOUR   = 1;  static final int HALF_DAY      = 2;  static final int TOP_OF_DAY    = 3;  static final int TOP_OF_WEEK   = 4;  static final int TOP_OF_MONTH  = 5;  /**     The date pattern. By default, the pattern is set to     "'.'yyyy-MM-dd" meaning daily rollover.   */  private String datePattern = "'.'yyyy-MM-dd";  /**     The log file will be renamed to the value of the     scheduledFilename variable when the next interval is entered. For     example, if the rollover period is one hour, the log file will be     renamed to the value of "scheduledFilename" at the beginning of     the next hour.      The precise time when a rollover occurs depends on logging     activity.   */  private String scheduledFilename;  /**     The next time we estimate a rollover should occur. */  private long nextCheck = System.currentTimeMillis () - 1;  Date now = new Date();  SimpleDateFormat sdf;  RollingCalendar rc = new RollingCalendar();  int checkPeriod = TOP_OF_TROUBLE;  // The gmtTimeZone is used only in computeCheckPeriod() method.  static final TimeZone gmtTimeZone = TimeZone.getTimeZone("GMT");  /**     The default constructor does nothing. */  public DailyRollingFileAppender() {  }  /**    Instantiate a <code>DailyRollingFileAppender</code> and open the    file designated by <code>filename</code>. The opened filename will    become the ouput destination for this appender.    */  public DailyRollingFileAppender (Layout layout, String filename,				   String datePattern) throws IOException {    super(layout, filename, true);    this.datePattern = datePattern;    activateOptions();  }  /**     The <b>DatePattern</b> takes a string in the same format as     expected by {@link SimpleDateFormat}. This options determines the     rollover schedule.   */  public void setDatePattern(String pattern) {    datePattern = pattern;  }  /** Returns the value of the <b>DatePattern</b> option. */  public String getDatePattern() {    return datePattern;  }  public void activateOptions() {    super.activateOptions();    if(datePattern != null && fileName != null) {      now.setTime(System.currentTimeMillis());      sdf = new SimpleDateFormat(datePattern);      int type = computeCheckPeriod();      printPeriodicity(type);      rc.setType(type);      File file = new File(fileName);      scheduledFilename = fileName+sdf.format(new Date(file.lastModified()));    } else {      LogLog.error("Either File or DatePattern options are not set for appender ["		   +name+"].");    }  }  void printPeriodicity(int type) {    switch(type) {    case TOP_OF_MINUTE:      LogLog.debug("Appender ["+name+"] to be rolled every minute.");      break;    case TOP_OF_HOUR:      LogLog.debug("Appender ["+name		   +"] to be rolled on top of every hour.");      break;    case HALF_DAY:      LogLog.debug("Appender ["+name		   +"] to be rolled at midday and midnight.");      break;    case TOP_OF_DAY:      LogLog.debug("Appender ["+name		   +"] to be rolled at midnight.");      break;    case TOP_OF_WEEK:      LogLog.debug("Appender ["+name		   +"] to be rolled at start of week.");      break;    case TOP_OF_MONTH:      LogLog.debug("Appender ["+name		   +"] to be rolled at start of every month.");      break;    default:      LogLog.warn("Unknown periodicity for appender ["+name+"].");    }  }  // This method computes the roll over period by looping over the  // periods, starting with the shortest, and stopping when the r0 is  // different from from r1, where r0 is the epoch formatted according  // the datePattern (supplied by the user) and r1 is the  // epoch+nextMillis(i) formatted according to datePattern. All date  // formatting is done in GMT and not local format because the test  // logic is based on comparisons relative to 1970-01-01 00:00:00  // GMT (the epoch).  int computeCheckPeriod() {    RollingCalendar rollingCalendar = new RollingCalendar(gmtTimeZone, Locale.ENGLISH);    // set sate to 1970-01-01 00:00:00 GMT    Date epoch = new Date(0);    if(datePattern != null) {      for(int i = TOP_OF_MINUTE; i <= TOP_OF_MONTH; i++) {	SimpleDateFormat simpleDateFormat = new SimpleDateFormat(datePattern);	simpleDateFormat.setTimeZone(gmtTimeZone); // do all date formatting in GMT	String r0 = simpleDateFormat.format(epoch);	rollingCalendar.setType(i);	Date next = new Date(rollingCalendar.getNextCheckMillis(epoch));	String r1 =  simpleDateFormat.format(next);	//System.out.println("Type = "+i+", r0 = "+r0+", r1 = "+r1);	if(r0 != null && r1 != null && !r0.equals(r1)) {	  return i;	}      }    }    return TOP_OF_TROUBLE; // Deliberately head for trouble...  }  /**     Rollover the current file to a new file.  */  void rollOver() throws IOException {    /* Compute filename, but only if datePattern is specified */    if (datePattern == null) {      errorHandler.error("Missing DatePattern option in rollOver().");      return;    }    String datedFilename = fileName+sdf.format(now);    // It is too early to roll over because we are still within the    // bounds of the current interval. Rollover will occur once the    // next interval is reached.    if (scheduledFilename.equals(datedFilename)) {      return;    }    // close current file, and rename it to datedFilename    this.closeFile();    File target  = new File(scheduledFilename);    if (target.exists()) {      target.delete();    }    File file = new File(fileName);    boolean result = file.renameTo(target);    if(result) {      LogLog.debug(fileName +" -> "+ scheduledFilename);    } else {      LogLog.error("Failed to rename ["+fileName+"] to ["+scheduledFilename+"].");    }    try {      // This will also close the file. This is OK since multiple      // close operations are safe.      this.setFile(fileName, false, this.bufferedIO, this.bufferSize);    }    catch(IOException e) {      errorHandler.error("setFile("+fileName+", false) call failed.");    }    scheduledFilename = datedFilename;  }  /**   * This method differentiates DailyRollingFileAppender from its   * super class.   *   * <p>Before actually logging, this method will check whether it is   * time to do a rollover. If it is, it will schedule the next   * rollover time and then rollover.   * */  protected void subAppend(LoggingEvent event) {    long n = System.currentTimeMillis();    if (n >= nextCheck) {      now.setTime(n);      nextCheck = rc.getNextCheckMillis(now);      try {	rollOver();      }      catch(IOException ioe) {	LogLog.error("rollOver() failed.", ioe);      }    }    super.subAppend(event);   }}/** *  RollingCalendar is a helper class to DailyRollingFileAppender. *  Given a periodicity type and the current time, it computes the *  start of the next interval.   * */class RollingCalendar extends GregorianCalendar {  int type = DailyRollingFileAppender.TOP_OF_TROUBLE;  RollingCalendar() {    super();  }    RollingCalendar(TimeZone tz, Locale locale) {    super(tz, locale);  }    void setType(int type) {    this.type = type;  }  public long getNextCheckMillis(Date now) {    return getNextCheckDate(now).getTime();  }  public Date getNextCheckDate(Date now) {    this.setTime(now);    switch(type) {    case DailyRollingFileAppender.TOP_OF_MINUTE:	this.set(Calendar.SECOND, 0);	this.set(Calendar.MILLISECOND, 0);	this.add(Calendar.MINUTE, 1);	break;    case DailyRollingFileAppender.TOP_OF_HOUR:	this.set(Calendar.MINUTE, 0);	this.set(Calendar.SECOND, 0);	this.set(Calendar.MILLISECOND, 0);	this.add(Calendar.HOUR_OF_DAY, 1);	break;    case DailyRollingFileAppender.HALF_DAY:	this.set(Calendar.MINUTE, 0);	this.set(Calendar.SECOND, 0);	this.set(Calendar.MILLISECOND, 0);	int hour = get(Calendar.HOUR_OF_DAY);	if(hour < 12) {	  this.set(Calendar.HOUR_OF_DAY, 12);	} else {	  this.set(Calendar.HOUR_OF_DAY, 0);	  this.add(Calendar.DAY_OF_MONTH, 1);	}	break;    case DailyRollingFileAppender.TOP_OF_DAY:	this.set(Calendar.HOUR_OF_DAY, 0);	this.set(Calendar.MINUTE, 0);	this.set(Calendar.SECOND, 0);	this.set(Calendar.MILLISECOND, 0);	this.add(Calendar.DATE, 1);	break;    case DailyRollingFileAppender.TOP_OF_WEEK:	this.set(Calendar.DAY_OF_WEEK, getFirstDayOfWeek());	this.set(Calendar.HOUR_OF_DAY, 0);	this.set(Calendar.MINUTE, 0);	this.set(Calendar.SECOND, 0);	this.set(Calendar.MILLISECOND, 0);	this.add(Calendar.WEEK_OF_YEAR, 1);	break;    case DailyRollingFileAppender.TOP_OF_MONTH:	this.set(Calendar.DATE, 1);	this.set(Calendar.HOUR_OF_DAY, 0);	this.set(Calendar.MINUTE, 0);	this.set(Calendar.SECOND, 0);	this.set(Calendar.MILLISECOND, 0);	this.add(Calendar.MONTH, 1);	break;    default:	throw new IllegalStateException("Unknown periodicity type.");    }    return getTime();  }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕日本乱码精品影院| 国内成人自拍视频| 久久激五月天综合精品| 床上的激情91.| 在线不卡中文字幕播放| 亚洲免费高清视频在线| 国产成人在线免费观看| 欧美一区二区三区免费| 亚洲一区av在线| av亚洲精华国产精华精| 国产婷婷色一区二区三区 | 麻豆精品国产91久久久久久| 成人网在线免费视频| 欧美成人一区二区三区片免费| 伊人婷婷欧美激情| 99这里都是精品| 久久激五月天综合精品| 国内欧美视频一区二区 | 欧美日韩美女一区二区| 国产精品久久久久久久久免费相片| 26uuu国产电影一区二区| 青青草97国产精品免费观看无弹窗版 | 91精品久久久久久久99蜜桃 | 欧美大片一区二区| www.久久精品| 日韩高清一区二区| 国产三级欧美三级日产三级99| 99国产精品久久| 免费成人在线播放| 亚洲丝袜美腿综合| 精品少妇一区二区| 91小视频免费看| 极品少妇xxxx精品少妇偷拍| 国产精品丝袜91| 91麻豆精品国产| 色8久久人人97超碰香蕉987| 琪琪久久久久日韩精品| 亚洲视频免费在线观看| 日韩欧美在线网站| 91浏览器打开| 国产精品中文欧美| 日韩综合一区二区| 亚洲欧美日韩小说| 久久综合久久鬼色中文字| 91老师片黄在线观看| 国产丶欧美丶日本不卡视频| 图片区日韩欧美亚洲| 亚洲婷婷综合久久一本伊一区 | 国产成人一级电影| 午夜精品影院在线观看| 国产精品久久午夜| 国产午夜亚洲精品午夜鲁丝片| 欧美三电影在线| 97精品久久久午夜一区二区三区 | 欧美日韩色综合| 成人黄色片在线观看| 国产呦萝稀缺另类资源| 免费的国产精品| 日韩精品1区2区3区| 亚洲图片欧美视频| 亚洲综合另类小说| 日韩和欧美一区二区| 欧美高清在线一区| 欧美精品一区二| 精品国产亚洲在线| 日韩一区二区三区视频| 欧美日韩激情在线| 欧美日韩精品一区二区三区四区| 色综合久久66| 欧美亚男人的天堂| 在线观看视频91| 91成人在线精品| 色视频成人在线观看免| 一本色道久久综合亚洲精品按摩| 成人综合在线网站| 成人免费看片app下载| 国产精品一区二区你懂的| 国产精品一卡二卡在线观看| 国产综合久久久久久鬼色| 国产在线国偷精品产拍免费yy| 蜜臀av一区二区在线观看| 日本午夜一本久久久综合| 午夜欧美一区二区三区在线播放| 午夜精品久久久久久久久久| 婷婷成人综合网| 久久精品国产77777蜜臀| 久久超碰97中文字幕| 紧缚捆绑精品一区二区| 国产精品77777竹菊影视小说| 国产精品99久久久久久有的能看 | 日韩一区二区三区视频在线观看 | 欧美精品一区二区三区视频| 欧美精品一区二| 中文字幕一区二区在线播放 | 国产色产综合产在线视频| 国产片一区二区三区| 综合在线观看色| 午夜激情一区二区三区| 麻豆精品一区二区三区| 成人精品一区二区三区中文字幕| 成人av网址在线| 欧美日韩一区二区三区免费看 | 欧洲精品一区二区| 欧美午夜电影在线播放| 日韩一区二区三区视频在线观看| 久久久久久久综合日本| 亚洲欧美日韩人成在线播放| 日韩精品一区第一页| 国产一区二区福利| 色婷婷综合久久久久中文一区二区 | 欧美一区二区免费视频| 久久久久久久久岛国免费| 国产成人精品在线看| 91在线观看成人| 欧美一区二区三区四区视频| 国产亚洲成年网址在线观看| 亚洲影视资源网| 国产一区二区三区在线观看免费| 91在线你懂得| 欧美大黄免费观看| 亚洲免费看黄网站| 国产做a爰片久久毛片| 日本二三区不卡| 久久精品一区二区| 亚洲图片一区二区| 成人一级黄色片| 日韩丝袜美女视频| 亚洲蜜臀av乱码久久精品| 极品少妇一区二区三区精品视频| 色综合一个色综合亚洲| 精品91自产拍在线观看一区| 亚洲一区二区精品视频| 成人午夜视频免费看| 日韩一区二区在线观看视频 | 久久噜噜亚洲综合| 亚洲一区二区av在线| 成人性生交大片免费看中文 | 欧美一区二区三区喷汁尤物| 国产精品乱人伦| 精品一区二区三区av| 欧美日韩精品一区视频| 最新国产成人在线观看| 国产成人午夜高潮毛片| 精品奇米国产一区二区三区| 夜夜嗨av一区二区三区四季av| 国产二区国产一区在线观看| 欧美一区二区精美| 亚洲国产美女搞黄色| 91色在线porny| 国产在线一区二区综合免费视频| 色天天综合久久久久综合片| 国产精品每日更新| 国产乱一区二区| 日韩免费看的电影| 免费观看在线色综合| 日韩一区二区在线观看视频播放| 亚洲一卡二卡三卡四卡无卡久久| www.欧美日韩国产在线| 国产精品毛片高清在线完整版| 国产精品综合视频| 国产女同互慰高潮91漫画| 国产毛片一区二区| 国产亚洲视频系列| 国产呦萝稀缺另类资源| 久久久亚洲国产美女国产盗摄| 久久精品国产亚洲5555| 欧美一区二区精美| 蜜臀久久久久久久| 日韩视频一区二区三区在线播放| 免费亚洲电影在线| 精品久久国产字幕高潮| 韩国欧美国产一区| 日韩一级片网站| 国产一区久久久| 国产欧美精品一区| 91亚洲国产成人精品一区二区三 | 日韩精品中文字幕一区二区三区| 午夜精品福利一区二区蜜股av| 欧美日韩色一区| 麻豆精品新av中文字幕| 久久久久久97三级| 国产·精品毛片| 亚洲丝袜制服诱惑| 欧美日韩国产免费| 久久精品999| 国产精品久久福利| 91九色最新地址| 免费高清成人在线| 国产精品美女久久福利网站| 色94色欧美sute亚洲13| 在线视频欧美区| 五月综合激情婷婷六月色窝| 91精品免费在线观看| 成人性生交大片免费看视频在线| 亚洲人精品午夜| 日韩欧美中文一区| 北条麻妃一区二区三区| 亚洲成人午夜电影| 久久久久亚洲综合| 欧美日韩国产成人在线免费|