忽悠,也是一种学问

我看了一下我最近几个月的博客浏览记录,发现这篇的访问量最高。然而这篇文章里面提到的东西虽然有我这么多年编程生涯中的一些总结,但总体上没有太多实在的东西,缺乏可操作性

而其它的一些文章,比如:

却几乎无人问津。

  就如同在实际工作中,某某某通过调节某个参数,让系统的运行效率提升了20%,太牛逼,太了不起了!而通过优化,甚至重写某些代码,提高了200%的效率,你能保证你的代码一定正确,没 bug 吗?我们的 site up 已经太多了,你还给大家添乱?万幸通过了测试,最终上线也没出问题,不过你这人太“拘泥于细节”,那是没出息的码工干的活。架构师从来都只谈 High Level 的,太慢,加机器!太复杂了,我们得多画图,多开会,得加人,要用生产率高的语言,用 Python, 用 scalar,用Erlang,用 Json,用nodejs……你用 shell+c,会被那些被用Python 的人鄙视的用Perl 的那些人鄙视的……

  服务器间传个文件,再算个sum,要用 shell 驱动 perl,perl 里面要加配置文件,配置文件要用八个XML,十个JSON,还要九个KeyValue pair 文件,要用面向对象,要用多线程,多线程之间要用共享变量,要用消息队列,每个线程再调用 shell,shell 再调用 binary,binary 要用C++写,C++ 要用 boost,解析命令要用 program_options,还能读配置文件,thread_pool 是标配,lambda 也总得用一下吧,记录读取,整数转化,要用 lexical_cast,这还只是平庸的程序员,高手从来是用 spirit 的!你用 iostream,你好意思跟人打招呼?你用strtoXX, 用 XXscanf,你是玛雅人吗?DMR 已经见上帝去了,爷爷辈的人都已经没有用它的了……

  参数解析,有命令行参数,还有配置文件,每个接口层解析两遍才算及格,解析了 5 遍说明你的代码够 robust,搞了8个层说明你架构设计得很 reusable,总共不解析它个50遍,你好意思说自己会写程序。

  5行代码的事情,你真写5行?那是大一新生用来练 Hello World 的!没有 500 行,你敢说是 Industry 级别的 Production System ?500行,这只是庸人的本事,高手从来是开两个月会, 画50张图, 再让手下写5000行代码的!

  增加新功能,我只需要改八个配置文件,不需要改任何代码。看看你那 5 行代码,就要增加一行还要改一行,你知道啥叫软件工程吗?

非常抱歉,我的回答是错误的。在Java的POI库中,确实有一个名为`shiftRows()`的方法,可以用于移动行和删除行。以下是删除第一行的示例代码: ```java import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.ss.usermodel.Sheet; import org.apache.poi.xssf.usermodel.XSSFWorkbook; public class DeleteRowExample { public static void main(String[] args) { try { // 读取工作簿 FileInputStream fis = new FileInputStream(new File("example.xlsx")); Workbook workbook = new XSSFWorkbook(fis); // 获取第一个工作表 Sheet sheet = workbook.getSheetAt(0); // 删除第一行 sheet.shiftRows(1, sheet.getLastRowNum(), -1); // 保存工作簿 FileOutputStream fos = new FileOutputStream(new File("example.xlsx")); workbook.write(fos); fos.close(); System.out.println("Row deleted successfully!"); } catch (Exception e) { e.printStackTrace(); } } } ``` 在上述代码中,我们首先使用`FileInputStream`读取了一个名为`example.xlsx`的工作簿,并使用`XSSFWorkbook`创建了一个`Workbook`对象。然后,我们获取了第一个工作表,并使用`shiftRows()`方法删除了第一行。最后,我们使用`FileOutputStream`将修改后的工作簿保存到磁盘上。 请注意,`shiftRows()`方法的第一个参数是要移动的起始行索引,第二个参数是要移动的结束行索引,第三个参数是要移动的行数。在我们的例子中,我们将从第二行开始的所有行向上移动了一行,因此第一个参数是1,第二个参数是工作表中的最后一行,第三个参数是-1。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值