- 浏览: 341629 次
- 性别:
- 来自: 北京
文章列表
从开始编程到现在,呆过的公司,呆过的每个项目组,几十上百行的函数都比比皆是。以此为美的还不在少数,认为这是“紧凑”;变量太多也不认为是问题,统统提到函数开头就行了,认为这样“更易读”;变量命名也很简短,一个字母的,两个字母的大行其道,也不认为是问题,可能认为这样并不影响阅读,相反还使得代码更简短。代码嵌套太深也不认为是问题,反对分拆函数,认为不是公用的代码就不用分拆,是否分拆与函数长度基本没有关系。
我已经不相信国内有严格践行重构的公司了,觉得多数公司的代码都是这样写的。
尽管阅读了《重构》一书,并自认为初窥门径,但仍无法说服同事们,除非他们也读过并认同。 ...
抽象是软件体系结构的灵魂。一个“优秀”的软件体系,必然是抽象层次恰到好处的结构。软件需要抽象,就如同书籍需要目录和章节一样;又好似茂盛的树木需要树干和枝丫。任何具备面向抽象编程意味的动作,都使软件体系朝质变迈出实实在在的一步,虽然不见得一定是变好。
面向过程语言与面向对象语言最大的区别就是,对抽象的支持不一样。两者都可以抽象,只是后者容易多了,它专为抽象而生。
但最重要的是,作为一个使用面向对象语言的程序员,要有这个意识,知道自己使用的这些特性有什么意义,会起到什么作用。只有意识到自己在做什么,才能有针对性地把它做到更好。
很难想象完全没有这种意识的程序员能用好任 ...
要成功就现在,不要推到将来
- 博客分类:
- 提醒自己
人生为某一个终极目标而活,很荒谬。这样的一生时间再长,也只等于一瞬间。为了六十岁的成功牺牲前面的二十岁、三十岁、四十岁乃至五十岁,得到的是一,失去的也许是十。
每个时期都做最大程度发挥潜能的事情,赢得了现在就是赢得了未来。等到了未来,那也只是短暂的一瞬,再大的成功也享受不了多久,也未必就真的需要多大的成功;另一方面,也完全没有理由说未来就比当前重要,没有理由为了未来的成功,就可以放弃当前的成功,所以做好眼前的,确保当前的成功才是最重要的。
一、卸载现有ubuntu系统(参考linuxidc.com)
1、下载MBRFix工具,放在c盘
2、
cd c:\mbrfix
执行
MBRFix /drive 0 fixmbr /yes
二、格式化现有ubuntu分区
1、控制面板-系统和安全-创建并格式化硬盘分区
选中ubuntu所在的几个主分区,并右键选择'删除卷'
于是硬盘多出了“可用空间”
三、使用easyBCD(参考linuxidc.com)
1、依次点击:
Add New Entry --NeoGrub -- Install --Configure
2、将ubuntu镜像文件在D盘根目录,保存如下配置文件:
root ...
学习感悟--编程语言
- 博客分类:
- 编程心得
从前觉得学校的教材太浅,只讲语法,根本不讲一种语言能用来做什么。后来不论学习什么语言都要认真钻研一番,看它到底有哪些功能。时间长了,就发现,现在感兴趣的又回到了语言本身的语法、特性上。因为,每种语言能做的事都差不多,语言之间的差异最大的部分反而就是它的语法规则。要掌握一门语言,首要掌握的,也是这个。至于功能,翻翻资料,大同小异。比如,网络编程,c、java、ruby、python,这些功能它们都有,但各自的语法区别是很大的。
用js操作DOM元素会引起页面频繁的reflow和repaint,加重页面负担。能用html和css达到效果的,就不要用js。
一、actionscript调用javascript
function method4As() {
alert('This is js code ')
}
ExternalInterface.call('method4As');//as
二、javascript 调用 actionscript
ExternalInterface.addCallback('callAS', function():void {
trace('This is as code');
});
var swf = document.getElementById('swfI ...
若干个行内元素并排排列,margin,padding都设成0了,但它们相互之间还是莫名其妙地多出了几像素的空白。这不是那个ie6bug,但很容易被忽略,也很难查出原因:和元素的排版方式有关。
<!doctype html>
<html>
<head>
<title>model</title>
<style><!--
body * {margin:0;padding:0;}
--></style>
</head>
<body>
...
曾经钻研过卡耐基的这本著作,也老老实实地实践过一阵子,但大多不了了之。究其原因,无外是逼自己做另一个完全不同的人,太难了,简直不可能。
比如说,作者建议不吝自己真诚的赞美。这点看起来容易,实际 ...
第一条,也是最根本的一条:抽象出了代码的整体框架、脉络,同时也隔离了具体的变化。没有分层,把逻辑都写在一个方法里面的代码就好比是一本没有目录的电子书,要找哪一章哪一节全得凭感觉,得点进去看,得结合 ...
VMWare虚拟机上网方式总结
- 博客分类:
- 学习资料
一、宿主机处于局域网。
1、bridge(桥接)
将虚拟机的ip设为局域网其中的一个,确保无冲突。
2、nat
本地连接-->属性-->共享-->允许其他网络用户通过....来连接
-->选择VMnet8。
将虚拟机的ip设为自动获取。
二、宿主机直接宽带上网,或任意使其拥有固定物理IP地址的上网方式。
只能选择nat。
与上述步骤2同。
最后重启虚拟机。
兼容各浏览器盒子模型
- 博客分类:
- JavaScript/CSS
各浏览器盒模型的组成结构是一致的,区别只是在"怪异模式"下宽度和高度的计算方式,而“标准模式”下则没有区别。组成结构以宽度为例:总宽度=marginLeft+borderLeft+paddingLeft+contentWidth+paddingRight+borderRight+marginRight。 ...
获取鼠标相对位置
- 博客分类:
- JavaScript/CSS
获取鼠标相对于html的位置:
function mousePosition(evt){
if(evt.pageX||evt.pageY){
return {x:evt.pageX,y:evt.pageY};
}
return {
x:evt.clientX+document.documentElement.scrollLeft-document.body.clientLeft,
y:evt.clientY+document.documentElement.scrollTop-document.body.clientTop
} ...
时间复杂度为O(k*n)的排序算法。目前只适用于非负整数,当然改造下也可用于负整数。
/**
* 过程:1、从个位数起,使用计数排序作为内排序方法,针对各个数位即“基数”进行排序。
*
*
* @param arr
* @param digit 最大数据的位数,比如100则输入3
*
*/
public int[] sort(int[] arr, int digit) {
if(arr==null){
return null;
}
for (int i = 1; i <= Math.pow(10, digi ...
快速排序。基于比较的排序中基本上最快的算法O(nlgn)。数据基本有序且每次取第一个元素作划分点(含基本相同)时将遭遇“最坏”情形,时间复杂度为O(n^2)。换言之数据越乱越高效。缺点:非稳定排序。
public void q_sort(int[] arr, int from, int to) {
if (arr == null || arr.length == 0 || to < 0 || from < 0) {
return;
}
if (from >= to) {
return;
}
if (to - from < ...