很长时间没有写BLOG了,先啰嗦几句。
我已经从一家不知名的小公司又一次回到了大公司里了,这是我7年工作来又一次回归大公司。当然了小公司有小公司的心胸狭窄和阴险,大公司有严格的管理制度和进升方式,这都不能够相提并论。所以建议有能力的朋友在大公司里做事,能够让自己用正确的方式做正确的事。
-----------------------天行键,君子以自强不息!
话入正题。
在大家的编码过程当中,有没有遇到过这么一种情况,很多零乱的状态、分类和其它常用选项常常是定义死了。但是没有一个完整的东东来约束他,在每个模块当中使用相关的信息时,往往重新COPY一次,或者COPY过来修改一次。如果多人协作的话,务必会让代码变的零乱、不好管理等。
本次主要是把一些静态的分类、状态或者其它常用选项使用二维数组管理起来。如果你是一个使用JSTL或者STRUTS做前台表现的话,你就更应该好好关注了。
以下以一个审核的状态做示例,使用代码实现(光说不练是假功夫).
创建Config.java
<!--<br><br>Code highlighting produced by Actipro CodeHighlighter (freeware)<br>http://www.CodeHighlighter.com/<br><br>-->package com.antbee;
import java.util.ArrayList;
import java.util.List;
/**
* <p>
* </p>
*
* <p>
* Copyright: 版权所有 (c) 2002 - 2006
* </p>
* <p>
* Company: Antbee
* </p>
*
* @author @家军
* @version 1.0
*/
public class Config {
/**
* 客户状态
*/
Object vec[][] = { { new Integer(1), new String("申请"),new String("apply")},
{ new Integer(2), new String("待审核"),new String("auditing") },
{ new Integer(3), new String("签约"),new String("sign up") },
{ new Integer(4), new String("续签中"),new String("nominator") },
{ new Integer(5), new String("过期"),new String("overdue") } };
public List Stutas = GetConfigEntity(vec);
public List GetConfigEntity(Object allconfig[][]) {
List ConfigList = new ArrayList();
ConfigEntity first = new ConfigEntity();
first.setTypeSeri(Integer.valueOf("0"));
first.setTypeCnName("请选择");
first.setTypeEnName("Pls Select");
ConfigList.add(first);
for(int i=0;i<allconfig.length;i++){
ConfigEntity configEntity = new ConfigEntity();
configEntity.setTypeSeri(Integer.valueOf(allconfig[i][0].toString()));
configEntity.setTypeCnName(allconfig[i][1].toString());
configEntity.setTypeEnName(allconfig[i][2].toString());
ConfigList.add(configEntity);
}
return ConfigList;
}
}
对应的PO实体类ConfigEntity.java(如果有数据库的话,你就可以直接从数据库当中取)
<!--<br><br>Code highlighting produced by Actipro CodeHighlighter (freeware)<br>http://www.CodeHighlighter.com/<br><br>-->package com.antbee;
import java.io.Serializable;
public class ConfigEntity implements Serializable {
/** The cached hash code value for this instance. Settting to 0 triggers re-calculation. */
private int hashValue = 0;
/** The composite primary key value. */
private java.lang.Integer typeSeri;
/** The value of the simple typeName property. */
private java.lang.String typeCnName;
/** The value of the simple typeName property. */
private java.lang.String typeEnName;
/**
* Simple constructor of AbstractDicType instances.
*/
public ConfigEntity()
{
}
/**
* Constructor of AbstractDicType instances given a simple primary key.
* @param typeSeri
*/
public ConfigEntity(java.lang.Integer typeSeri)
{
this.setTypeSeri(typeSeri);
}
/**
* Return the simple primary key value that identifies this object.
* @return java.lang.Integer
*/
public java.lang.Integer getTypeSeri()
{
return typeSeri;
}
/**
* Set the simple primary key value that identifies this object.
* @param typeSeri
*/
public void setTypeSeri(java.lang.Integer typeSeri)
{
this.hashValue = 0;
this.typeSeri = typeSeri;
}
/**
* Return the value of the TYPE_NAME column.
* @return java.lang.String
*/
public java.lang.String getTypeCnName()
{
return this.typeCnName;
}
/**
* Set the value of the TYPE_NAME column.
* @param typeName
*/
public void setTypeCnName(java.lang.String typeCnName)
{
this.typeCnName = typeCnName;
}
/**
* Return the value of the TYPE_NAME column.
* @return java.lang.String
*/
public java.lang.String getTypeEnName()
{
return this.typeEnName;
}
/**
* Set the value of the TYPE_NAME column.
* @param typeName
*/
public void setTypeEnName(java.lang.String typeEnName)
{
this.typeEnName = typeEnName;
}
/**
* Implementation of the equals comparison on the basis of equality of the primary key values.
* @param rhs
* @return boolean
*/
public boolean equals(Object rhs)
{
if (rhs == null)
return false;
if (! (rhs instanceof ConfigEntity))
return false;
ConfigEntity that = (ConfigEntity) rhs;
if (this.getTypeSeri() == null || that.getTypeSeri() == null)
return false;
return (this.getTypeSeri().equals(that.getTypeSeri()));
}
/**
* Implementation of the hashCode method conforming to the Bloch pattern with
* the exception of array properties (these are very unlikely primary key types).
* @return int
*/
public int hashCode()
{
if (this.hashValue == 0)
{
int result = 17;
int typeSeriValue = this.getTypeSeri() == null ? 0 : this.getTypeSeri().hashCode();
result = result * 37 + typeSeriValue;
this.hashValue = result;
}
return this.hashValue;
}
}
具体使用方法
<!--<br><br>Code highlighting produced by Actipro CodeHighlighter (freeware)<br>http://www.CodeHighlighter.com/<br><br>-->/*Antbee @家军
*/
Config n = new Config();
List View_Stutas = n.Stutas; request.setAttribute("View_Stutas", View_Stutas);
页面当中示例:
<!--<br><br>Code highlighting produced by Actipro CodeHighlighter (freeware)<br>http://www.CodeHighlighter.com/<br><br>--><c:forEach items="${View_Stutas}" var="View_Stutas">
<option value="<c:out value="${View_Stutas.typeSeri }" />"><c:out value="${View_Stutas.typeEnName}"/></option>
</c:forEach>
可以看出,在实体类里一共有三个方法,其它有两个名字, 一个是中文名字,一个是英文名字,你可以在页面当中截取本地语言并显示其中一个语言就行。
分享到:
相关推荐
- **一维数组形式访问二维数组** (选项B):虽然二维数组在物理存储上是一维的,但通过适当的方法仍然可以直接按行或列访问元素。 - **数组元素的通用性** (选项C):数组元素可以在任何需要内存变量的地方使用,例如...
选项B正确表示了一个3列的二维数组,但初始化时只指定了一个元素,编译器会自动填充剩余元素为0。 2. **数组元素的引用**:正确引用数组元素的方式是通过指针操作。给定定义`int a[10], *p; p=a;`,`*p`代表了数组...
这意味着可以在VFP中声明和使用一维数组和二维数组来存储和处理数据。 ### 5. 全局配置文件 在Web应用程序中,**Web.config**文件是ASP.NET应用的全局配置文件,用于设置应用程序的配置信息,如连接字符串、编译...
二维数组可以使用全下标、单下标和逻辑1进行标识,这些标识方式在数组操作中非常常见。 接下来,我们探讨选择题中的知识点: 1. 变量命名规则:合法的变量名不应以数字开头,所以选项(A)不合法。 2. 矩阵行列式...
` 正确定义了一个2x2的二维数组,并分别初始化了第一行和第二行的第一个元素。 - 选项B中的`int a[][2]={1,2,3,4};` 也是一个合法的二维数组定义方式,其中数组的行数未指定,编译器会自动计算。此例中,编译器将...
在给定的例题中,使用了两个嵌套循环来遍历二维数组,并计算所有元素的总和。 - **选项A**: `10`不正确。 - **选项B**: `6`不正确。 - **选项C**: `9`不正确。 - **选项D**: `13`是正确答案。 因此,正确答案为: ...
实际上,二维数组的行数和列数可以不同,这取决于具体的数组定义。例如,可以定义一个3行4列的二维数组,也可以定义一个4行3列的数组,因此行数和列数不必相同。 ### 4. 浏览网页安全问题 认为“浏览网页不会导致...
文档的最后部分还介绍了NumPy的全局状态管理,如配置选项、运行环境设置等,这些全局设置对整个NumPy环境的运行有着重要影响。 总而言之,根据给定文件内容,NumPy参考手册是涵盖了NumPy库几乎所有方面的详尽文档,...
- **6.3.3 使用二维数组**:说明如何访问和修改二维数组中的元素。 ##### 6.4 数组的基本操作 - **6.4.1 遍历数组**:使用循环结构遍历数组中的每一个元素。 - **6.4.2 填充替换数组元素**:可以通过循环来填充或...
7. 给定的事件代码创建了一个二维数组并填充了部分元素,最后通过 MsgBox 显示 a(2,5) + a(3,4) + a(4,5),计算结果为 32,对应选项 C。 8. PowerPoint 中创建新幻灯片的方法不止内容提示向导,还有其他模板和...
其他选项如`new int[2][3]`虽然可以创建固定大小的二维数组,但在灵活性方面不如`new int[3][]`。 ### 20. 数据库备份的方法 - **知识点**: 直接复制方式备份数据库的特点。 - **详细解释**: 使用直接复制方式备份...
- **详细解释**:在VBA或类似的编程语言中,可以使用嵌套循环来填充和操作二维数组。在示例代码中,通过两层循环分别填充了数组的不同部分,最终输出数组中特定位置元素的值之和。 ### 9. 局域网(LAN) - **知识...
通常可以使用JSON格式,如树形结构或二维数组,以表示属性的层级关系和依赖关系。 2. **前端开发**:前端部分主要负责交互逻辑的实现,这包括监听用户的选择事件,触发相应的属性值更新。常用的前端框架如微信小...
**详细解释**:在二维数组中,计算某个元素位置时,需要考虑数组的行数和列数。对于二维数组 a[m][n],数组 a[j][i] 前面的元素个数可以通过 `i*m+j` 来计算。因此,正确答案是 **B**。 ### 16. if 语句的执行逻辑 ...
23. 创建二维数组:正确创建一个长度为3的二维数组,应使用`new int[3][];`,先指定行数,再在每行中指定列数。 24. DFD的作用:数据流图是需求分析阶段的工具,用于描绘系统的数据流程。 25. Vis...(这部分内容...
- 对于一个m列的二维数组,计算元素a[i][j]的公式为i*m+j,其中i表示行索引,j表示列索引。 ### 15. 数据库系统的核心 题目询问数据库系统的核心。正确答案是数据库管理系统(DBMS)。 - **数据库**:存储数据的集合...
2. 正确定义一维数组的方式是C选项。`char a[] = "012345";` 定义了一个字符数组,而其他选项要么数组长度超出定义,要么格式错误。 3. Telnet或远程登录允许用户从一台计算机远程控制另一台计算机,执行远程计算机...
5. 指针和数组:`int (*p)[3]`定义了一个指针变量p,它指向一个含有三个整数元素的一维数组,即二维数组的一行。 6. CallableStatement接口:在Java数据库连接(JDBC)中,CallableStatement接口专门用于执行数据库...
通过分析这个Python五子棋游戏源码,你可以学习到如何用Python实现一个简单的图形用户界面游戏,理解事件驱动编程、游戏逻辑设计以及如何使用Python进行状态管理和用户交互。这对于提高Python编程技巧和理解面向对象...