@Slf4j在test目录下可以使用,在main目录下使用报错

问题:

@Slf4j在test目录下可以正常使用,但是在main目录下使用报错:
在这里插入图片描述

解决思路

怀疑是在哪里配置了只在test下起作用,后来发现在logback-classic的jar包下有一个配置“test”,查了一下其中“test”表示依赖项目仅仅参与测试相关的工作,后来把“test”改成“compile”,就可以正常在main目录下使用log了,直接把“”标签删掉也是可以的。


<dependency>
    <groupId>ch.qos.logbackgroupId>
    <artifactId>logback-classicartifactId>
    <version>1.3.0-alpha4version>
    <scope>testscope>
dependency>

解决办法

将“”标签里的“test”改为“compile”


<dependency>
    <groupId>ch.qos.logbackgroupId>
    <artifactId>logback-classicartifactId>
    <version>1.3.0-alpha4version>
    <scope>compilescope>
dependency>

scope分类

  • compile:默认值 他表示被依赖项目需要参与当前项目的编译,还有后续的测试,运行周期也参与其中,是一个比较强的依赖。打包的时候通常需要包含进去
  • test:依赖项目仅仅参与测试相关的工作,包括测试代码的编译和执行,不会被打包,例如:junit
  • runtime:表示被依赖项目无需参与项目的编译,不过后期的测试和运行周期需要其参与。与compile相比,跳过了编译而已。例如JDBC驱动,适用运行和测试阶段
  • provided:打包的时候可以不用包进去,别的设施会提供。事实上该依赖理论上可以参与编译,测试,运行等周期。相当于compile,但是打包阶段做了exclude操作
  • system:从参与度来说,和provided相同,不过被依赖项不会从maven仓库下载,而是从本地文件系统拿。需要添加systemPath的属性来定义路径

你可能感兴趣的:(java,在main目录下使用报错,在test目录下可以正常使用,Slf4j,scope)