Java @ComponentScan BasePackageClass是否有命名约定?
Spring的@ComponentScan提供了一个类型安全属性——这似乎是一个很好的使用方法,尤其是在我正在处理的项目中,重命名包并不少见。文件说: 考虑在每个包中创建一个特殊的无操作标记类或接口,该类或接口除了被该属性引用之外没有其他用途 。。。但对于此类课程的名称没有提供进一步的指导。我想知道这方面是否有什么惯例Java @ComponentScan BasePackageClass是否有命名约定?,java,spring,dependency-injection,convention,component-scan,Java,Spring,Dependency Injection,Convention,Component Scan,Spring的@ComponentScan提供了一个类型安全属性——这似乎是一个很好的使用方法,尤其是在我正在处理的项目中,重命名包并不少见。文件说: 考虑在每个包中创建一个特殊的无操作标记类或接口,该类或接口除了被该属性引用之外没有其他用途 。。。但对于此类课程的名称没有提供进一步的指导。我想知道这方面是否有什么惯例package info.java已经存在于所有包中(由Checkstyle强制执行)——本希望重用它,但遗憾的是java不允许使用这种名称的类 (如果没有这样的标准,我想可能是P
package info.java
已经存在于所有包中(由Checkstyle强制执行)——本希望重用它,但遗憾的是java不允许使用这种名称的类
(如果没有这样的标准,我想可能是
PackageInfo
、BasePackage
、PackageMarker
或类似的标准,但如果有标准,我更愿意遵循惯例。)还没有答案,必须做出决定,因此:
标记类:
package com.companyname.appname.projectname.package1name;
/**
* Empty marker class used to identify this package when using type-safe basePackageClasses in Spring @ComponentScan.
*/
public class PackageMarker {
// Empty marker class
}
@ComponentScan(basePackageClasses = {
com.companyname.appname.projectname.package1name.PackageMarker.class,
com.companyname.appname.projectname.package2name.PackageMarker.class,
/* ...etc... */
})
用法:
package com.companyname.appname.projectname.package1name;
/**
* Empty marker class used to identify this package when using type-safe basePackageClasses in Spring @ComponentScan.
*/
public class PackageMarker {
// Empty marker class
}
@ComponentScan(basePackageClasses = {
com.companyname.appname.projectname.package1name.PackageMarker.class,
com.companyname.appname.projectname.package2name.PackageMarker.class,
/* ...etc... */
})
PackageMarker
命名对正:
如果有人能给出在更具探索性的环境中使用的标记类的例子,我仍然会感兴趣…我觉得这是一种基于观点的观点。例如,我通常会将我的
@Controller
类型存储在一个包中,因此,我将在Controllers.java
中命名相应的类或接口Controllers
。我同意这可能涉及观点,但希望有人能向我指出标准或广泛使用的方法的证据。这很有用,因为它是类型安全的-指定了类而不是字符串,因此如果包名这似乎主要是观点,尽管你可以重新措辞(也许要求最佳实践)。但是我不认为有任何标准。好的,我认为问题已经给出了要点,但是稍微改写了最后一句,并将其括起来,以使其更清楚。这种方法的一个缺点是用法非常冗长。它只是反映了包的结构,可以根据需要简洁或详细地保证唯一性。是的,但是您也可以给标记接口一个项目唯一的名称,然后注释可以看起来像@ComponentScan(basePackageClasses={TwitterClient.class,EvernoteClient.class}),但我不确定是否会采用这种策略。marker类标识整个包,这将允许名称与包名称不同。随着标记类数量的增加,名称唯一性可能会出现问题。我还将通过使PackageMarker类为final及其构造函数为private来防止实例化它:public final class PackageMarker{private PackageMarker(){throw new assertioneror(“不要实例化”+PackageMarker.class);}}