Groovy:找不到匹配的构造函数

时间:2020-03-23 10:28:31

标签: oop groovy runtime-error groovyshell groovy-console

任何人都可以帮助我解决以下类(JobStage)出现此运行时错误(找不到匹配的构造函数)的原因。我试图创建以下类的实例,但会导致以下运行时错误。

class JobStage {
    String name
    StageType stageType
    String transformationType
    List<ImField> fields
    TableAttribute tableAttributes
    List<Connector> inputConnectors
    List<Connector> outputConnectors
    JobStageProperties stageProperties

    JobStage(String name, StageType stageType, String transformationType,
              List<ImField> fields,TableAttribute tableAttributes, List<Connector> inputConnectors,
             List<Connector> outputConnectors, JobStageProperties stageProperties){

        this.name = name
        this.stageType = stageType
        this.transformationType = transformationType
        this.fields = fields
        this.tableAttributes = tableAttributes
        this.inputConnectors = inputConnectors
        this.outputConnectors = outputConnectors
        this.stageProperties = stageProperties
    }
}


groovy.lang.GroovyRuntimeException: Could not find matching constructor for: com.starling.informatica.dto.jobstage.JobStage(String, com.starling.informatica.dto.StageType, String, ArrayList, null, ArrayList, com.starling.informatica.dto.stageProperties.SourceRelationalStageProperties)

此处的错误假定TableAttribute类为null,并使用igonres List<Connector> outputConnectors参数

我试图像这样创建实例:

JobStageProperties stageProperties = TeradataSpecUtil.getSourceStageProperties()
List<ImField> fields = [new SourceField("integer","","customer_id","NULL","","10","0","","1","NOT A KEY","0","ELEMITEM","NO","11","0","0","0","10","0",""),
 new SourceField("varchar","","customer_name","NULL","","50","0","","2","NOT A KEY","0","ELEMITEM","NO","0","0","0","11","50","10","")
]
List<Connector> inputConnectors = []
List<Connector> outputConnectors = [new Connector("customer_id","informatica_customer_source","Source Definition","customer_id","SQ_informatica_customer_source" ,"Source Qualifier"),
 new Connector("customer_name","informatica_customer_source","Source Definition","customer_name","SQ_informatica_customer_source" ,"Source Qualifier")
]
TableAttribute tableAttribute = null
List<JobStage> expectedJobStage= [new JobStage("informatica_customer_source",
 StageType.TERADATA_CONNECTOR, "Source Definition", fields,tableAttribute, inputConnectors,
 outputConnectors, stageProperties)]

1 个答案:

答案 0 :(得分:0)

我的代码在逻辑上是正确的,问题出在Intellij。我执行了“使缓存无效并重新启动”后,代码成功运行。