使用步骤注意:

1. 从http://logging.apache.org/log4j/1.2/ 下载文件

2. 在src目录下加入log4j.properties,将jar包放入build -path,log4j.properties 编译后位于/classes目录下。

3.  配置文件读取解析:

PropertyConfigurator.configure(String configFilename)---->

PropertyConfigurator.java

  1. staticpublic void configure(String configFilename) {
  2. new PropertyConfigurator().doConfigure(configFilename,
  3. LogManager.getLoggerRepository());
  4. }

--->读取配置文件

  1. public
  2. void doConfigure(String configFileName, LoggerRepository hierarchy) {
  3. Properties props = new Properties();
  4. FileInputStream istream = null;
  5. try {
  6. istream = new FileInputStream(configFileName);
  7. props.load(istream);
  8. istream.close();
  9. }
  10. catch (Exception e) {
  11. if (e instanceof InterruptedIOException || e instanceof InterruptedException) {
  12. Thread.currentThread().interrupt();
  13. }
  14. LogLog.error("Could not read configuration file ["+configFileName+"].", e);
  15. LogLog.error("Ignoring configuration file [" + configFileName+"].");
  16. return;
  17. } finally {
  18. if(istream != null) {
  19. try {
  20. istream.close();
  21. } catch(InterruptedIOException ignore) {
  22. Thread.currentThread().interrupt();
  23. } catch(Throwable ignore) {
  24. }
  25.  
  26. }
  27. }
  28. // If we reach here, then the config file is alright.
  29. doConfigure(props, hierarchy);
  30. }

-->读取配置

  1. /**
  2. Read configuration options from <code>properties</code>.
  3.  
  4. See {@link #doConfigure(String, LoggerRepository)} for the expected format.
  5. */
  6. public
  7. void doConfigure(Properties properties, LoggerRepository hierarchy) {
  8. repository = hierarchy;
  9. String value = properties.getProperty(LogLog.DEBUG_KEY);
  10. if(value == null) {
  11. value = properties.getProperty("log4j.configDebug");
  12. if(value != null) {
  13. LogLog.warn("[log4j.configDebug] is deprecated. Use [log4j.debug] instead.");
  14. }
  15. }
  16.  
  17. if(value != null) {
  18. LogLog.setInternalDebugging(OptionConverter.toBoolean(value, true));
  19. }
  20.  
  21. //
  22. // if log4j.reset=true then
  23. // reset hierarchy
  24. String reset = properties.getProperty(RESET_KEY);
  25. if (reset != null && OptionConverter.toBoolean(reset, false)) {
  26. hierarchy.resetConfiguration();
  27. }
  28.  
  29. String thresholdStr = OptionConverter.findAndSubst(THRESHOLD_PREFIX,
  30. properties);
  31. if(thresholdStr != null) {
  32. hierarchy.setThreshold(OptionConverter.toLevel(thresholdStr,
  33. Level.ALL));
  34. LogLog.debug("Hierarchy threshold set to ["+hierarchy.getThreshold()+"].");
  35. }
  36.  
  37. configureRootCategory(properties, hierarchy);
  38. configureLoggerFactory(properties);
  39. parseCatsAndRenderers(properties, hierarchy);
  40.  
  41. LogLog.debug("Finished configuring.");
  42. // We don't want to hold references to appenders preventing their
  43. // garbage collection.
  44. registry.clear();
  45. }

原文:http://zengjinliang.iteye.com/blog/171550

一:log4j配置文件基本含义说明


log4j.properties配置文件讲解如下: 
# Set root logger level to DEBUG and its only appender to A1 
#log4j中有五级logger 
#FATAL 0 
#ERROR 3 
#WARN 4 
#INFO 6 
#DEBUG 7

配置根Logger,其语法为: 
#log4j.rootLogger = [ level ] , appenderName, appenderName, … 
log4j.rootLogger=INFO, A1 ,R 
#这一句设置以为着所有的log都输出 
#如果为log4j.rootLogger=WARN, 则意味着只有WARN,ERROR,FATAL 
#被输出,DEBUG,INFO将被屏蔽掉. 
# A1 is set to be a ConsoleAppender. 
#log4j中Appender有几层如控制台、文件、GUI组件、甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等 
#ConsoleAppender输出到控制台 
log4j.appender.A1=org.apache.log4j.ConsoleAppender 
# A1 使用的输出布局,其中log4j提供4种布局. org.apache.log4j.HTMLLayout(以HTML表格形式布局) 
#org.apache.log4j.PatternLayout(可以灵活地指定布局模式), 
#org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串), 
#org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)

log4j.appender.A1.layout=org.apache.log4j.PatternLayout 
#灵活定义输出格式 具体查看log4j javadoc org.apache.log4j.PatternLayout 
#d 时间 .... 
log4j.appender.A1.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n 
#R 输出到文件 RollingFileAppender的扩展,可以提供一种日志的备份功能。 
log4j.appender.R=org.apache.log4j.RollingFileAppender 
#日志文件的名称 
log4j.appender.R.File=log4j.log 
#日志文件的大小 
log4j.appender.R.MaxFileSize=100KB 
# 保存一个备份文件 
log4j.appender.R.MaxBackupIndex=1 log4j.appender.R.layout=org.apache.log4j.TTCCLayout 
#log4j.appender.R.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n

配置根Logger,其语法为:

log4j.rootLogger = [ level ] , appenderName, appenderName, ...

level 是日志记录的优先级 
appenderName就是指定日志信息输出到哪个地方。您可以同时指定多个输出目的地。

配置日志信息输出目的地Appender,其语法为

log4j.appender.appenderName = fully.qualified.name.of.appender.class 
log4j.appender.appenderName.option1 = value1 
... 
log4j.appender.appenderName.option = valueN

Log4j提供的appender有以下几种: 
org.apache.log4j.ConsoleAppender(控制台), 
org.apache.log4j.FileAppender(文件), 
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件), 
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件), 
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)

配置日志信息的格式(布局),其语法为:

log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class 
log4j.appender.appenderName.layout.option1 = value1 
.... 
log4j.appender.appenderName.layout.option = valueN

Log4j提供的layout有以下几种: 
org.apache.log4j.HTMLLayout(以HTML表格形式布局), 
org.apache.log4j.PatternLayout(可以灵活地指定布局模式), 
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串), 
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)

--------------------------------------------------------------------------------

二、Log4j日志管理系统简单使用说明 
----------------------------- 
摘自:http://x.discuz.net/131976/viewspace_42754.html

Log4j有三个主要的组件:Loggers,Appenders和Layouts,这里可简单理解为日志类别,日志要输出的地方和日志以何种形式输出。综合使用这三个组件可以轻松的记录信息的类型和级别,并可以在运行时控制日志输出的样式和位置。下面对三个组件分别进行说明: 
1、 Loggers

Loggers组件在此系统中被分为五个级别:DEBUG、INFO、WARN、ERROR和FATAL。这五个级别是有顺序的,DEBUG < INFO < WARN < ERROR < FATAL,明白这一点很重要,这里Log4j有一个规则:假设Loggers级别为P,如果在Loggers中发生了一个级别Q比P高,则可以启动,否则屏蔽掉。

Java程序举例来说:

//建立Logger的一个实例,命名为“com.foo”

Logger  logger = Logger.getLogger("com.foo");

//设置logger的级别。通常不在程序中设置logger的级别。一般在配置文件中设置。

logger.setLevel(Level.INFO);

Logger barlogger = Logger.getLogger("com.foo.Bar");

//下面这个请求可用,因为WARN >= INFO

logger.warn("Low fuel level.");

//下面这个请求不可用,因为DEBUG < INFO

logger.debug("Starting search for nearest gas station.");

//命名为“com.foo.bar”的实例barlogger会继承实例“com.foo”的级别。因此,下面这个请求可用,因为INFO >= INFO

barlogger.info("Located nearest gas station.");

//下面这个请求不可用,因为DEBUG < INFO

barlogger.debug("Exiting gas station search");

这里“是否可用”的意思是能否输出Logger信息。

在对Logger实例进行命名时,没有限制,可以取任意自己感兴趣的名字。一般情况下建议以类的所在位置来命名Logger实例,这是目前来讲比较有效的Logger命名方式。这样可以使得每个类建立自己的日志信息,便于管理。比如:

static Logger logger = Logger.getLogger(ClientWithLog4j.class.getName());

2、 Appenders

禁用与使用日志请求只是Log4j其中的一个小小的地方,Log4j日志系统允许把日志输出到不同的地方,如控制台(Console)、文件(Files)、根据天数或者文件大小产生新的文件、以流的形式发送到其它地方等等。

其语法表示为:

org.apache.log4j.ConsoleAppender(控制台),

org.apache.log4j.FileAppender(文件), 
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件), 
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)

配置时使用方式为:

log4j.appender.appenderName = fully.qualified.name.of.appender.class

log4j.appender.appenderName.option1 = value1

log4j.appender.appenderName.option = valueN

这样就为日志的输出提供了相当大的便利。

3、 Layouts

有时用户希望根据自己的喜好格式化自己的日志输出。Log4j可以在Appenders的后面附加Layouts来完成这个功能。Layouts提供了四种日志输出样式,如根据HTML样式、自由指定样式、包含日志级别与信息的样式和包含日志时间、线程、类别等信息的样式等等。

其语法表示为:

org.apache.log4j.HTMLLayout(以HTML表格形式布局), 
org.apache.log4j.PatternLayout(可以灵活地指定布局模式), 
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串), 
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)

配置时使用方式为:

log4j.appender.appenderName.layout =       fully.qualified.name.of.layout.class 
     log4j.appender.appenderName.layout.option1 = value1 
     … 
     log4j.appender.appenderName.layout.option = valueN

以上是从原理方面说明Log4j的使用方法,在具体Java编程使用Log4j可以参照以下示例: 
1、 建立Logger实例: 
    语法表示:public static Logger getLogger( String name) 
    实际使用:static Logger logger = Logger.getLogger   (ServerWithLog4j.class.getName ()) ; 
2、 读取配置文件: 
    获得了Logger的实例之后,接下来将配置Log4j使用环境: 
    语法表示: 
    BasicConfigurator.configure():自动快速地使用缺省Log4j环境。 
    PropertyConfigurator.configure(String configFilename):读取使用Java的特性文件编写的配置文件。 
    DOMConfigurator.configure(String filename):读取XML形式的配置文件。 
    实际使用:PropertyConfigurator.configure("ServerWithLog4j.properties"); 
3、 插入日志信息 
    完成了以上连个步骤以后,下面就可以按日志的不同级别插入到你要记录日志的任何地方了。 
    语法表示: 
    Logger.debug(Object message); 
    Logger.info(Object message); 
    Logger.warn(Object message); 
    Logger.error(Object message); 
    实际使用:logger.info("ServerSocket before accept: " + server);

在实际编程时,要使Log4j真正在系统中运行事先还要对配置文件进行定义。定义步骤就是对Logger、Appender及Layout的分别使用,具体如下: 
1、 配置根Logger,其语法为: 
    log4j.rootLogger = [ level ] , appenderName, appenderName, … 
这里level指Logger的优先级,appenderName是日志信息的输出地,可以同时指定多个输出地。如:log4j.rootLogger= INFO,A1,A2 
2、 配置日志信息输出目的地,其语法为: 
    log4j.appender.appenderName = fully.qualified.name.of.appender.class 
    可以指定上面所述五个目的地中的一个。 
3、 配置日志信息的格式,其语法为: 
    log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class 
    这里上面三个步骤是对前面Log4j组件说明的一个简化;下面给出一个具体配置例子,在程序中可以参照执行: 
    log4j.rootLogger=INFO,A1 
    log4j.appender.A1=org.apache.log4j.ConsoleAppender 
    log4j.appender.A1.layout=org.apache.log4j.PatternLayout 
    log4j.appender.A1.layout.ConversionPattern= 
                                        %-4r %-5p %d{yyyy-MM-dd HH:mm:ssS} %c %m%n 
    这里需要说明的就是日志信息格式中几个符号所代表的含义: 
    -X号: X信息输出时左对齐; 
    %p: 日志信息级别 
    %d{}: 日志信息产生时间 
    %c: 日志信息所在地(类名) 
    %m: 产生的日志具体信息 
    %n: 输出日志信息换行

根据上面的日志格式,某一个程序的输出结果如下: 
0    INFO  2003-06-13 13:23:46968 ClientWithLog4j Client socket: Socket[addr=localhost/127.0.0.1,port=8002,localport=2014] 
16   DEBUG 2003-06-13 13:23:46984 ClientWithLog4j Server says: 'Java server with log4j, Fri Jun 13 13:23:46 CST 2003' 
16   DEBUG 2003-06-13 13:23:46984 ClientWithLog4j GOOD 
16   DEBUG 2003-06-13 13:23:46984 ClientWithLog4j Server responds: 'Command 'HELLO' not understood.' 
16   DEBUG 2003-06-13 13:23:46984 ClientWithLog4j HELP 
16   DEBUG 2003-06-13 13:23:46984 ClientWithLog4j Server responds: 'Vocabulary: HELP QUIT' 
16   DEBUG 2003-06-13 13:23:46984 ClientWithLog4j QUIT

-------------------------------------------------------------------------------- 
三、配置Log4j

摘自:http://x.discuz.net/131976/viewspace_42752.html

Log4J的配置文件(Configuration File)就是用来设置记录器的级别、存放器和布局的,它可接key=value格式的设置或xml格式的设置信息。通过配置,可以创建出Log4J的运行环境。

1. 配置文件 
Log4J配置文件的基本格式如下:

#配置根Logger 
log4j.rootLogger  =   [ level ]   ,  appenderName1 ,  appenderName2 ,  …

#配置日志信息输出目的地Appender 
log4j.appender.appenderName  =  fully.qualified.name.of.appender.class 
  log4j.appender.appenderName.option1  =  value1 
  … 
  log4j.appender.appenderName.optionN  =  valueN

#配置日志信息的格式(布局) 
log4j.appender.appenderName.layout  =  fully.qualified.name.of.layout.class 
  log4j.appender.appenderName.layout.option1  =  value1 
  … 
  log4j.appender.appenderName.layout.optionN  =  valueN  
其中 [level] 是日志输出级别,共有5级: 
FATAL      0  
ERROR      3  
WARN       4  
INFO       6  
DEBUG      7

Appender 为日志输出目的地,Log4j提供的appender有以下几种: 
org.apache.log4j.ConsoleAppender(控制台), 
org.apache.log4j.FileAppender(文件), 
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件), 
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件), 
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方) 
Layout:日志输出格式,Log4j提供的layout有以下几种: 
org.apache.log4j.HTMLLayout(以HTML表格形式布局), 
org.apache.log4j.PatternLayout(可以灵活地指定布局模式), 
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串), 
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息) 
打印参数: Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,如下: 
  %m   输出代码中指定的消息 
  %p   输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL 
  %r   输出自应用启动到输出该log信息耗费的毫秒数 
  %c   输出所属的类目,通常就是所在类的全名 
  %t   输出产生该日志事件的线程名 
  %n   输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n” 
  %d   输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss , SSS},输出类似:2002年10月18日  22 : 10 : 28 , 921  
  %l   输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java: 10 )  
2. 在代码中初始化Logger: 
1)在程序中调用BasicConfigurator.configure()方法:给根记录器增加一个ConsoleAppender,输出格式通过PatternLayout设为"%-4r [%t] %-5p %c %x - %m%n",还有根记录器的默认级别是Level.DEBUG. 
2)配置放在文件里,通过命令行参数传递文件名字,通过PropertyConfigurator.configure(args[x])解析并配置; 
3)配置放在文件里,通过环境变量传递文件名等信息,利用log4j默认的初始化过程解析并配置; 
4)配置放在文件里,通过应用服务器配置传递文件名等信息,利用一个特殊的servlet来完成配置。

3. 为不同的 Appender 设置日志输出级别: 
当调试系统时,我们往往注意的只是异常级别的日志输出,但是通常所有级别的输出都是放在一个文件里的,如果日志输出的级别是BUG!?那就慢慢去找吧。 
这时我们也许会想要是能把异常信息单独输出到一个文件里该多好啊。当然可以,Log4j已经提供了这样的功能,我们只需要在配置中修改Appender的Threshold 就能实现,比如下面的例子:

[配置文件] 
### set log levels ### 
log4j.rootLogger = debug ,  stdout ,  D ,  E

### 输出到控制台 ### 
log4j.appender.stdout = org.apache.log4j.ConsoleAppender 
log4j.appender.stdout.Target = System.out 
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout 
log4j.appender.stdout.layout.ConversionPattern =  %d{ABSOLUTE} %5p %c{ 1 }:%L - %m%n

### 输出到日志文件 ### 
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender 
log4j.appender.D.File = logs/log.log 
log4j.appender.D.Append = true 
log4j.appender.D.Threshold = DEBUG ## 输出DEBUG级别以上的日志 
log4j.appender.D.layout = org.apache.log4j.PatternLayout 
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n

### 保存异常信息到单独文件 ### 
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender 
log4j.appender.D.File = logs/error.log ## 异常日志文件名 
log4j.appender.D.Append = true 
log4j.appender.D.Threshold = ERROR ## 只输出ERROR级别以上的日志!!! 
log4j.appender.D.layout = org.apache.log4j.PatternLayout 
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n 
[代码中使用] 
  public   class  TestLog4j   { 
     public   static   void  main(String[] args)   { 
        PropertyConfigurator.configure( " D:/Code/conf/log4j.properties " ); 
        Logger logger  =  Logger.getLogger(TestLog4j. class ); 
        logger.debug( " debug " ); 
        logger.error( " error " ); 
    } 

运行一下,看看异常信息是不是保存在了一个单独的文件error.log中。

log4j配置文件详解---转的更多相关文章

  1. log4j 配置文件详解

    [1]从零开始 a). 新建Java Project>>新建package>>新建java类: b). import jar包(一个就够),这里我用的是log4j-1.2.14 ...

  2. log4j配置文件详解(转)

    Log4J的配置文件(Configuration File)就是用来设置记录器的级别.存放器和布局的,它可接key=value格式的设置或xml格式的设置信息.通过配置,可以创建出Log4J的运行环境 ...

  3. MyBatis使用模糊查询用户信息及log4j配置文件详解

    1.1 根据用户名称模糊查询用户信息 根据用户名模糊查询用户信息,只需要我们更改映射文件中的sql语句.其他的内容跟上一篇的内容是一样的 1.2添加根据用户名称模糊查询用户信息的sql语句 实例中是查 ...

  4. log4j配置文件详解

    在开发中经常会碰到日志,网上关于日志的框架也很多,像log4j.self4j.common-logging等,下面对log4j进行介绍. log4j是java开发的日志框架,具有低侵入的特点,其重点使 ...

  5. Log4j配置文件详解及实例

     1 ) . 配置根 Logger ,其语法为:   log4j.rootLogger = [ level ] , appenderName, appenderName, … 其中, level 是日 ...

  6. Log4j2配置文件详解

    目录[-] 1 系列目录 2 默认配置 3 第一个配置例子 4 复杂一点的配置 4.1 Appender之Syslog配置 4.2 Syslog及Syslog-ng相关配置(Fedora) 5 Log ...

  7. org.apache.log4j.Logger详解

    org.apache.log4j.Logger 详解 1. 概述 1.1. 背景 在应用程序中添加日志记录总的来说基于三个目的 :监视代码中变量的变化情况,周期性的记录到文件中供其他应用进行统计分析工 ...

  8. log4j.properties 详解与配置步骤(转)

    找的文章,供参考使用 转自 log4j.properties 详解与配置步骤 一.log4j.properties 的使用详解 1.输出级别的种类 ERROR.WARN.INFO.DEBUGERROR ...

  9. Java学习-007-Log4J 日志记录配置文件详解及实例源代码

    此文主要讲述在初学 Java 时,常用的 Log4J 日志记录配置文件详解及实例源代码整理.希望能对初学 Java 编程的亲们有所帮助.若有不足之处,敬请大神指正,不胜感激!源代码测试通过日期为:20 ...

随机推荐

  1. C#遍历所有的Textbox控件并赋值为String.Empty

    foreach (Control control in this.Controls) { if (control.GetType().Name.Equals("TextBox")) ...

  2. ICE学习第三步-----Slice语言

    ICE:Slice语言(一)-编译 Introduce简介 Slice(Specification language for ice)是分离对象和对象的实现的基础的抽象机制.Slice在客户端和服务器 ...

  3. linux安装时提示发生不正常错误问题

    跳过md5系统较检(每个系统版本都有一个md5编码唯一) 在安装CentOS时 提示 找不到磁盘,是否安装程序,选择安装程序进行"下一步" 提示: 发生不规则,不正常错误 原因:没 ...

  4. HDU 1996

    Problem Description n个盘子的汉诺塔问题的最少移动次数是2^n-1,即在移动过程中会产生2^n个系列.由于发生错移产生的系列就增加了,这种错误是放错了柱子,并不会把大盘放到小盘上, ...

  5. 从NIB中加载VIEW

    NSArray *nib = [[NSBundle mainBundle] loadNibNamed:@"ChatMoreView" owner:nil options:nil]; ...

  6. Solr4.8.0源码分析(21)之SolrCloud的Recovery策略(二)

    Solr4.8.0源码分析(21)之SolrCloud的Recovery策略(二) 题记:  前文<Solr4.8.0源码分析(20)之SolrCloud的Recovery策略(一)>中提 ...

  7. 转:.NET中使用Redis (二)

    原文来自于:http://blog.jobbole.com/83824/ 原文出处: 寒江独钓   欢迎分享原创到伯乐头条 很久以前写了一篇文章 .NET中使用Redis 介绍了如何安装Redis服务 ...

  8. JavaScript Application Architecture On The Road To 2015

    JavaScript Application Architecture On The Road To 2015 I once told someone I was an architect. It’s ...

  9. IntegerCache详解

    IntegerCache是Integer的内部类,用来将-128——high之间的对象进行实例化 private static class IntegerCache {        static f ...

  10. setjmp/longjmp 使用

    C语言中有一个goto语句,其可以结合标号实现函数内部的任意跳转(通常情况下,很多人都建议不要使用goto语句,因为采用goto语句后,代码维护工作量加大).另外,C语言标准中还提供一种非局部跳转“n ...