05 2011 档案

摘要:寻路算法不止 A* 这一种, 还有递归, 非递归, 广度优先, 深度优先, 使用堆栈等等, 有兴趣的可以研究研究. 如图所示简易地图, 其中绿色方块的是起点 (用 A 表示), 中间蓝色的是障碍物, 红色的方块(用 B 表示)是目的地. 为了可以用一个二维数组来表示地图, 我们将地图划分成一个个的小方块... 阅读全文
posted @ 2011-05-26 15:57 Create Chen 阅读(120050) 评论(54) 推荐(28) 编辑
摘要:博皮是基于模板 SimpleBlue 做的修改, 改动前后看上去差别还是挺大的, 但当然不能跟专业的网页美工做的效果相比, 我不是做美工的...只了解一些 html 和 CSS 而已, 让各位见笑了... 阅读全文
posted @ 2011-05-22 20:49 Create Chen 阅读(7240) 评论(44) 推荐(41) 编辑
摘要:线程将 CPU 进行虚拟化后变成一个个的逻辑 CPU, 而物理 CPU 只有1个(多核CPU则有多个CPU), 一个 CPU 同时只能做一件事. 在任何时候, Windows 只将一个线程分配给一个 CPU, 那个线程允许运行一个"时间片", 一旦时间片到期, Windows 就上下文切换到另一个线程, 每次上下文切换都执行以下操作... 阅读全文
posted @ 2011-05-22 14:57 Create Chen 阅读(3261) 评论(7) 推荐(7) 编辑
摘要:记得我第一个独立完成的程序是一个课程表软件 (左图), 用 VB.NET 写的, 花了三天功夫写了 2000 多行, 当时一共写了近 10 个界面用于包括设置一个星期中每天的课程还有其它一些杂七杂八的内容. 当时我也知道 "重复" 的代码很多, 但只想着 "能运行就好了", 于是还光明正大的把一大块代码复制到另外几个模板里. 如果想对这样的代码做点优化的话, 这时不应该是重构, 而应该重写... 阅读全文
posted @ 2011-05-17 12:51 Create Chen 阅读(3320) 评论(7) 推荐(11) 编辑
摘要:类与类之间经常会相互调用, 比如 ClassA 的某个函数里需要 ClassB 里的某个值域或者某个函数的返回值, 因此我将整个 ClassB 作为参数传递给 ClassA 的这个函数, 这意味着 ClassA 的这个函数能够调用 ClassB 里所有的功能, 可不可以给 ClassA 的这个函数划定一个特定的职能呢? 让它只能做某些事情, 而避免其它 "越权行为". 有句话常被人说起 —— 使用接口来降低耦合性, 这就是 Extract Interface 的功劳. 这条重构手段经常被使用到, 主要解决类对另一个类的依赖问题, 降低了耦合性... 阅读全文
posted @ 2011-05-16 17:03 Create Chen 阅读(2235) 评论(5) 推荐(4) 编辑
摘要:"令函数携带参数" 并不是简单的让你在函数里加上参数, 如果函数里需要某个参数, 我们谁都会加上它. 你可能发现这样的几个函数: 它们做着类似的事情, 只是因为极少的几个值导致函数的策略不同, 这时可以使用 Parameterize Method 消除函数中那些重复的代码了, 而且可以用这个参数处理其它更多变化的情况... 阅读全文
posted @ 2011-05-15 19:05 Create Chen 阅读(3098) 评论(5) 推荐(8) 编辑
摘要:"复杂的条件逻辑" 是导致复杂性上升最常见的地方, "条件表达式中堆积的计算过程", "条件式表达得不简洁"等等都是造成复杂的原因. Decompose Conditional 用于将这些复杂的元素从条件表达式中分离出去, 仅在条件表达式中调用简洁的函数. 这样做带来的直接好处是减少重复, 而且代码的可读性提高了... 阅读全文
posted @ 2011-05-14 09:20 Create Chen 阅读(4567) 评论(15) 推荐(13) 编辑
摘要:大部分类中都会有一些值域, 随之还会有一些方法使用到了这些值域. "如果调用这些值域"这个问题分为两种观点: 1. 应该直接调用它们 2. 应该通过访问函数调用它们. 我觉得大部分情况下直接调用比较方便, 过多的访问函数还会造成类中的函数过多, 当然将来如果我觉得直接调用带来了一些问题, 写一个一个的访问函数也并不是很困难... 阅读全文
posted @ 2011-05-13 12:40 Create Chen 阅读(3186) 评论(13) 推荐(11) 编辑
摘要:试想这么一个情况: 有一个Employee类, 这个类中含有一个部门(Department)属性, 并且Department是一种类. 如果我想知道某职工所在部门的经理人是谁的时候, 我需要通过 xxEmployee.Department.Manger来访问. 但这样做有个缺点是对于其它代码, Department是public的, 其它代码能够访问到Department里的其它特性. 可以在 Employee 类中写一个GetManger()方法进行封装, 在调用的时候只需要 xxEmployee.GetManger() 就行了... 阅读全文
posted @ 2011-05-11 15:49 Create Chen 阅读(2444) 评论(12) 推荐(5) 编辑
摘要:某跨国日化公司, 肥皂生产线存在包装时可能漏包肥皂的问题, 肯定不能把空的肥皂盒卖给顾客, 于是该公司总裁命令组成了以博士牵头的专家组对这个问题进行攻关, 该研发团队使用了世界上最高精尖的技术 (如红外探测, 激光照射等), 在花费了大量美金和半年的时间后终于完成了肥皂盒检测系统, 探测到空的肥皂盒以后, 机械手会将空盒推出去. 这一办法将肥皂盒空填率有效降低至5%以内, 问题基本解决... 阅读全文
posted @ 2011-05-10 16:24 Create Chen 阅读(8399) 评论(70) 推荐(37) 编辑
摘要:服务端, 声明ServerSocket, 绑定(Bind)一个IP并指定这个IP的通信端口, 比如是127.0.0.1:9050, ServerSocket可以监听来自多个IP发送的连接请求, 监听(Listen)方法的参数可以设置允许的最多连接请求个数. 然后调用异步接受请求的方法(BeginAccept), 如果接受到某个客户端发来连接请求, 这时定义一个新的CommunicateSocket专门负责与这个客户端通信. 然后可以通过CommunicateSocket.BeginSend()方法给客户端发送数据, CommunicateSocket.BeginReceive()可以接收客户端发来的数据... 阅读全文
posted @ 2011-05-03 16:12 Create Chen 阅读(19608) 评论(40) 推荐(30) 编辑