代码生成器的源码编写

本文探讨如何编写代码生成器的源码,重点关注模板设计,以entity包为例,展示了如何导入必要的库如Serializable和Date,创建可序列化的实体类。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

代码生成器模板
package entity;
import java.util.Date;
import java.io.Serializable;

public class ${table.className} implements Serializable  {

      <#list table.columns as column>
        private ${column.javaType} ${column.filedName};
       </#list>


          <#list table.columns as column>
            public void set${column.upperFiledName}(${column.javaType} ${column.filedName}){
                this.${column.filedName}=${column.filedName};
            }

            public ${column.javaType} get${column.upperFiledName}(){
                return this.${column.filedName};
            }
</#list>	
}
package cn.code;

import freemarker.template.Configuration;
import freemarker.template.Template;

import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStreamWriter;
import java.util.HashMap;
import java.util.Map;


public class Generator {

    private  Configuration configuration;


    //path 模板路径
    public void init(String path) throws Exception{
         configuration = new Configuration(Configuration.getVersion());

           configuration.setDirectoryForTemplateLoading(new File(path));


    }
    //tempName模板文件的名称
    // savePath 保存路径
     public void process(String tempName,String savePath,Map<String,Object> param)throws Exception{
        //获取模板对应实例
        Template template=configuration.getTemplate(tempName);
          //组装数据
        //初始化保存路径
         FileOutputStream fos=new  FileOutputStream(savePath);
         OutputStreamWriter outputStreamWriter=new OutputStreamWriter(fos);
         //传参,生成数据
         template.process(param,outputStreamWriter);

     }



}

package cn.code;
import cn.code.Moudle.Column;
import cn.code.Moudle.Table;
import cn.code.utils.StringUtils;

import java.sql.*;
import java.util.ArrayList;
import java.util.List;

/**
 * Created by zezhong.shang on 17-6-5.
 */
public class TableUtils {

    private static String DBDRIVER = PropertiesUtils.get("database.properties", "driver");

    private static String DBURL = PropertiesUtils.get("database.properties", "url");

    private static String DBUSER = PropertiesUtils.get("database.properties", "user");

    private static String DBPASS = PropertiesUtils.get("databas
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值