生成代码的代码 之 POJO生成器

时间:2021-06-26 00:18:38

我们在写Java代码时候,有时候需要写一些POJO类,也就是只有一些属性和get, set方法的类。例如,在写REST 服务时候,利用Jersery + Jackson,可以把输入的JSON字符串自动转换成一个POJO类,也可以自动把POJO类转换成JSON字符串而输出。在这样的情况下,我们往往需要写很多的POJO类,里面包含多个属性和对应的get, set方法,写起来比较麻烦。那么,我们有办法能很快的写出这些POJO类吗。

实际上,这些POJO类的实质就是一个类名和几个属性的类型和名称。既然如此,我们可以只提供这几个信息,而通过一个程序来把这些POJO类生成出来。所以,我们要做的是一个生成代码的代码,用来生成POJO对象。

要做这件事情,可以用各种编程语言来实现。笔者个人偏好JavaScript,而且JavaScript里面的object model比较适合做这件事,因此这里笔者通过Node.js来实现。代码如下,回头会把代码开源到GitHub.

用法为, 把POJO的定义写到schema.js文件中,然后运行node createpojo.js

// createpojo.js
var fs = require('fs');
var schema = require("./schema") var defaultindent = 2; var getIndent = function(i) {
return getIndentCore(i, 0);
};
var getIndentCore = function(len, i) {
if (i >= len) {
return "";
}
return getIndentCore(len, i+1) + " ";
}; var createField = function(field, indentsize) {
var i = indentsize == undefined ? 2 : indentsize;
return getIndent(i) + "private " + field.type + " " + field.name + ";";
}; var createFields = function(fields, indentsize) {
var fieldsstring = fields.map(function(f) {
return createField(f, indentsize);
});
return fieldsstring.join("\n");
}; var createEmptyConstructor = function(clz, indentsize) {
return getIndent(indentsize) + "public " + clz + "() {\n\n" + getIndent(indentsize) + "}";
};
var createVariable = function(f) {
return f.type + " " + f.name;
};
var createArglist = function(fields) {
var args = fields.map(createVariable);
return args.join(", ");
};
var createAssign = function(field, indentsize) {
return getIndent(indentsize) + "this." + field.name + " = " + field.name + ";";
};
var createAssigns = function(fields, indentsize) {
var assigns = fields.map(function(f) {
return createAssign(f, indentsize);
});
return assigns.join("\n");
};
var createConstructor = function(clz, fields, indentsize) {
return getIndent(indentsize) + "public " + clz + "(" + createArglist(fields) + ") {\n" + createAssigns(fields, indentsize + defaultindent) + "\n" + getIndent(indentsize) + "}";
};
var createConstructors = function(clz, fields, indentsize) {
return createEmptyConstructor(clz, indentsize) + "\n\n" + createConstructor(clz, fields, indentsize);
};
var getFuncName = function(name) {
return name.substring(0,1).toUpperCase() + name.substring(1);
};
var createSetter = function(field, indentsize) {
var line1 = getIndent(indentsize) + "public void set" + getFuncName(field.name) + "(" + createVariable(field) + ") {";
var line2 = createAssign(field, indentsize + defaultindent);
var line3 = getIndent(indentsize) + "}";
var lines = [line1, line2, line3];
return lines.join("\n");
};
var createGetter = function(field, indentsize) {
var line1 = getIndent(indentsize) + "public " + field.type + " get" + getFuncName(field.name) + "() {";
var line2 = getIndent(indentsize + defaultindent) + "return this." + field.name + ";";
var line3 = getIndent(indentsize) + "}";
var lines = [line1, line2, line3];
return lines.join("\n");
};
var createAccessor = function(field, indentsize) {
var access = [createSetter(field, indentsize), createGetter(field, indentsize)];
return access.join("\n");
};
var createAccessors = function(fields, indentsize) {
var accesses = fields.map(function(f) {return createAccessor(f, indentsize);});
return accesses.join("\n\n");
};
var createClass = function(pkg, clz, fields) {
var line1 = "package " + pkg + ";";
var line2 = "public class " + clz + " {";
var line3 = createFields(fields, defaultindent);
var line4 = createConstructors(clz, fields, defaultindent);
var line5 = createAccessors(fields, defaultindent);
var line6 = "}";
var lines = [line1, line2, line3, line4, line5, line6];
return lines.join("\n\n");
}; var classcontents = schema.map(function(s) {
return createClass(s["package"], s["name"], s["fields"]);
}); for (var i = 0; i < schema.length; i++) {
fs.writeFile(schema[i].name + ".java", classcontents[i], function(e){
if (e) {
console.log("error: " + e);
}
});
} // schema.js
var schemas = [
{
"name": "TestClass",
"package": "example.com",
"fields": [
{"name": "name", "type": "String"},
{"name": "value", "type": "String"}
]
}
] module.exports = schemas;

代码只是用来做工具用,所以没有写的很完善。如果读者觉得代码有改进之处,欢迎在代码开源之后提交更新。

生成代码的代码 之 POJO生成器的更多相关文章

  1. 生成代码的代码 之 POJO生成器 之二 模板实现

    在之前的一篇博客中,我们写了利用node.js来生成JAVA的POJO代码的方法.有评论说可以利用模板来做这件事.当时认为模板只能做简单的字符串替换,所以可能无法完成任务.但是,仔细的学习了一个模板 ...

  2. mybatis自定义代码生成器(Generator)——自动生成model&amp&semi;dao代码

    花了两天的时间研究了下mybatis的generator大体了解了其生成原理以及实现过程.感觉generator做的非常不错,给开发者也留足了空间.看完之后在generator的基础上实现了自定义的生 ...

  3. SNF开发平台-SNF&period;CodeGenerator-升级生成BS页面代码-支持视图-数据库配置-快速开发者的利器

    有一段时间没有进行总结SNF快速开发平台了,这段时间把今年在框架升级部分进行整理说明. 下面就把代码生成器升级部分介绍一下: 1.新增BS页面生成代码 2.新增视图支持 3.新增 数据库配置 1.新增 ...

  4. JSON生成c&num;类代码小工具

    JSON生成c#类代码小工具 为什么写这么个玩意 最近的项目中需要和一个服务端程序通讯,而通讯的协议是基于流行的json,由于是.net,所以很简单的从公司代码库里找到了Newtonsoft.dll( ...

  5. 分享:根据webservice WSDL地址自动生成java调用代码及JAR包

    分享:根据webservice WSDL地址自动生成java调用代码及JAR包使用步骤:一.安装java 并配置JAVA_HOME 及 path二.安装ANT 并配置ANT_HOME三.解压WsdlT ...

  6. 命令行方式使用abator&period;jar生成ibatis相关代码和sql语句xml文件

    最近接手一个老项目,使用的是数据库是sql server 2008,框架是springmvc + spring + ibatis,老项目是使用abator插件生成的相关代码,现在需要增加新功能,要添加 ...

  7. MATLAB Coder从MATLAB生成C&sol;C&plus;&plus;代码步骤

    MATLAB Coder可以从MATLAB代码生成独立的.可读性强.可移植的C/C++代码. 使用MATLAB Coder产生代码的3个步骤: 准备用于产生代码的MATLAB算法: 检查MATLAB代 ...

  8. soupUI生成webservice客户端代码

    在Apache网站下载axis2软件包,同时本机安装soapUI工具.例如,当前我使用的axis2版本为axis2-1.4-bin.zip,soapUI版本为3.6. Apache Axis下载地址: ...

  9. 如何通过VIM把代码格式化后生成HTML网页代码

    本文转自http://wangxiaoyu.blog.51cto.com/922065/203471 需求及思路:演示需要,需要网站上嵌入一些代码,我的建议做法是根据代码文件,生成相应的HTML代码, ...

随机推荐

  1. iOS开发系列--视图切换

    概述 在iOS开发中视图的切换是很频繁的,独立的视图应用在实际开发过程中并不常见,除非你的应用足够简单.在iOS开发中常用的视图切换有三种,今天我们将一一介绍: UITabBarController ...

  2. Qlikview 处理交叉表数据

    数据来源于crossTable的时候,如何将数据做明细显示. 如图示交叉表数据 使用表格向导,选择交叉表按钮, 结果达到目的. 相关脚本. Month, 表示将要新加的字段的列明,Orders 为明细 ...

  3. Linux下面使用rpm命令

    RPM是RedHat Package Manager(RedHat软件包管理工具)类似Windows里面的“添加/删除程序” rpm 执行安装包二进制包(Binary)以及源代码包(Source)两种 ...

  4. LightOJ1360 Skyscraper(DP)

    题目大概是,一个数轴上n个线段,每个线段都有起始坐标.长度和权值,问从中取出没有公共交点的线段的最大权和. 取k次是个经典的最小费用最大流问题,不过这题建容量网络有20W个点,离散化最多也要6W个点, ...

  5. &lbrack;LeetCode&rsqb;题解(python):046-Permutations

    题目来源 https://leetcode.com/problems/permutations/ Given a collection of distinct numbers, return all ...

  6. jsp eclipse 创建jsp项目

    选择File菜单 File->new->Other... 选择Dynamic Web Project项目->Next 写入项目->Finish 在WebContent鼠标右键- ...

  7. POJ2752 - Seek the Name&comma; Seek the Fame&lpar;KMP&rpar;

    题目大意 给定一个字符串S,求出所有既是S的前缀又是S的后缀的子串长度 题解 从末尾位置倒推,经过的失配函数值就是题目要求求的 代码: #include <iostream> #inclu ...

  8. PHP算法 《树形结构》 之 伸展树&lpar;1&rpar; - 基本概念

    伸展树的介绍 1.出处:http://dongxicheng.org/structure/splay-tree/ A. 概述 二叉查找树(Binary Search Tree,也叫二叉排序树,即Bin ...

  9. python 3---if判断成绩练习

    需求根据用户输入的成绩分档,要求如下: 1. 如果成绩大于60分,输出"及格"2. 如果成绩大于70分,输出"良"3. 如果成绩大于80分,输出"好& ...

  10. VGG

    2019-04-08 13:30:58 VGG模型是2014年ILSVRC竞赛的第二名,第一名是GoogLeNet.但是VGG模型在多个迁移学习任务中的表现要优于googLeNet.而且,从图像中提取 ...