自己的工具类以及for循环的一个问题

先看例子:

var obj = {
    id:'123',
    name:'Hank',
    age:22
};
var array = ['id','name','age'];
for(var i in obj){
   console.log(i);//i的值依次为:id name age 
}


for(var j in array){
  console.log(j);//j的值依次为0 1 2

}


忘记哪篇博文细讲for in 对象与数组的区别了(昨天的博文或则是昨天看别人的博文)。结论是 for in使用与对象。数组的循环是这样滴~:

for(var i=0,len = array.length;i<len;i++){

       console.log(array[i]);

}

至于为何不写作:

for(var i=0;i<array.length;i++)}{

//your code...

}

原因:前一代码段长度计算在循环时只计算一次,而后则每次循环都要计算一次。这样就节省计算时间啊~~~~

之上不是重点,今日多写一篇的原因是同事感慨之前没好好的保存自己的代码,特别是可做工具的方法代码(没维护自己的工具类),感觉好可惜。深受其感染,将一些感想的代码和语言好好处理。以下是部分工具类方法:(Javascript版)

/**
 * @FileDirections: 工具类方法--用于调用 简洁代码使用
 * @Author: hank.
 * @E-mail: haw_king@foxmail.com
 * @Tools: Created with JetBrains WebStorm.
 * @Date: 12-10-19
 * @Time: 下午4:25
 * To change this template use File | Settings | File Templates.
 */
Tools = {
    /**
     * 循环遍历方法
     * @param arrays 循环对象数组
     * @param callbackFun 回调函数
     */
    forEach:function(arrays,callbackFun){
        for(var i= 0,len = arrays.length;i<len;i++){
            callbackFun(arrays[i]);
        }
    },
    /**
     * for in 循环 使用与对象的遍历
     * @param obj 对象
     * @param callbackFn 回调函数
     */
    forIn:function(obj,callbackFn){
        for(var i in obj){
            callbackFn(obj[i],i);//i为对象obj的属性 obj[i]为对应的属性值
        }
    },
    extend:function(childFn,parentFn){
        var c = childFn.prototype;
        var p = parentFn.prototype;
        for(var i in p){
            c[i] = p[i];
        }
    }
};

-----------------------------------------------------------------------------------------

看书,睡觉,坚持写代码!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个可以读取XLSB文件并输出数据的Java工具类,使用了Apache POI库: ```java import org.apache.poi.ss.usermodel.*; import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.util.ArrayList; import java.util.List; public class XLSBReader { private File file; private Workbook workbook; private Sheet sheet; public XLSBReader(String filePath) throws IOException { this.file = new File(filePath); FileInputStream fileInputStream = new FileInputStream(file); this.workbook = WorkbookFactory.create(fileInputStream); this.sheet = workbook.getSheetAt(0); } public List<String[]> read() { List<String[]> data = new ArrayList<>(); for (Row row : sheet) { String[] rowData = new String[row.getLastCellNum()]; for (Cell cell : row) { int cellIndex = cell.getColumnIndex(); switch (cell.getCellType()) { case BOOLEAN: rowData[cellIndex] = String.valueOf(cell.getBooleanCellValue()); break; case NUMERIC: rowData[cellIndex] = String.valueOf(cell.getNumericCellValue()); break; case STRING: rowData[cellIndex] = cell.getStringCellValue(); break; case BLANK: rowData[cellIndex] = ""; break; default: rowData[cellIndex] = ""; break; } } data.add(rowData); } return data; } public void close() throws IOException { this.workbook.close(); } } ``` 这个工具类的构造函数需要传入要读取的XLSB文件的路径,read方法将返回一个List,其中每个元素都是一个String数组,表示一行数据。close方法用于关闭Workbook对象和相关资源。 以下是一个使用这个工具类读取XLSB文件并输出数据的示例: ```java public class Demo { public static void main(String[] args) { try { XLSBReader reader = new XLSBReader("example.xlsb"); List<String[]> data = reader.read(); for (String[] row : data) { for (String cell : row) { System.out.print(cell + "\t"); } System.out.println(); } reader.close(); } catch (IOException e) { e.printStackTrace(); } } } ``` 在上面的示例中,我们创建了一个XLSBReader对象,并将要读取的XLSB文件的路径传递给它。然后,我们使用read方法读取XLSB文件中的数据,并将其存储在data变量中。最后,我们遍历data变量,并将其输出到控制台。注意,这里使用了一个嵌套循环,以便逐行逐列输出数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值