Home

用来把一个线程的日志输出到单独文件的脚本

很多开源项目的日志都是把多个线程的日志打印到一个文件的,有时候我们需要查看一个线程号下的所有日志,vim选中高亮线程号固然是一种方法,但是看起来不直观,以下脚本完成输出一个线程所有日志到一个文件的功能。 "plugin-写一个线程的log到单独文件 function! ThreadLog() let file = readfile(expand("%:p")) let pattern = expand('<cword>') let matches = [] for line in file let match = matchstr(line, pattern) if(!empty(match)) ...

Read more

转载王垠的一段话

王垠虽然挺扯,这段话还是有道理的: 我对清华,还有 Princeton,Harvard,MIT,Stanford,Berkeley,CMU 等学校的学生都有了解。这些所谓的“世界一流大学”或者“世界一流大学 wannabee”差不多都是类似的气氛。你冲着它们的名气和“关系网”挤破了头皮进去,然后就每天有人在你耳边对其它人感叹:哇,他好牛啊!发了好多 paper,还得了XX奖。跟参加传销大会似的,让你怀疑这些人还有没有自尊。然后就是填鸭式的教育,无止境的作业和考试,让你感觉他们不是在“教育”你,而是在“筛选”你。这种筛选总是筛掉最差的,但也筛掉最好的。因为最好的学生能意识到你在干什么,他们不给你筛选他们的机会。一旦发现其实没学到东西,中途就辍学出去创业了。所以剩下来的就是最一般的,循规...

Read more

Thinking In Java读书笔记

静态成员只有被引用(首次生成所在类的对象或者被首次访问,即使从为生成过那个类的对象)的时候才会初始化。 一般情况下Java成员变量初始化顺序是,静态成员/静态快->直接初始化的类成员->构造函数 一个简单的例子如下: Cup.java public class Cup { public Cup(int i) { System.out.println("constructor" + i); } } TestJava.java public class TestJava { public Cup cup; public Cup cup3 = new Cup(3); public static Cup cup1 = new Cup(1); ...

Read more

Effective C++ 读书笔记

Effective前面有几节是说构造析构赋值过程中基类和派生类的调用关系的,做了一个综合一点的例子,来验证一下这个问题。代码如下,话说贴代码是在是很没溜的做法,尤其是如果在出版的书中看到的话,这种行为基本属于骗稿费的… object.h #ifndef OCEANBASE_OBJECT_H_ #define OCEANBASE_OBJECT_H_ #include "base_object.h" class Object: public BaseObject { public: Object (); Object (int magic); Object (const Object & obj); virtual ~Object ()...

Read more

分布式调试系列之行为模拟

最近调试分布式系统,感觉实际上什么看日志的方式都不如带集群调试,当然有些行为是比较难以模拟的,可能的情况下,要么重现环境,要么对部分模块做mock。单测带来的便利性是远超过不做mock省下的时间的,比如与sql相关的逻辑完全可以启动一个完整的sql环境,然后把请求发过去,看回来的响应。至于其他的部分,基本的原则是减少变量。比如两个server之间的通信,同时检测两个server只能看日志,所以最好能mock一个server的行为,这样减少调试的不确定性。

Read more

关于ob代码规范里面的行末空格

行尾的空格在post-review的时候会被标识成红色,其实可以通过如下vim配置直接显示出来并全部去掉: " 删除所有行未尾空格 nnoremap <C-f12> :%s/[ \t\r]\+$//g<cr>'' "显示空格 highlight ExtraWhitespace ctermbg=red guibg=red match ExtraWhitespace /\s\+$/ augroup ExtraWhitespaceGroup autocmd! autocmd BufWinEnter * match ExtraWhitespace /\s\+$/ autocmd InsertEnter * match ExtraWhitespa...

Read more

关于得到当前执行文件所在的目录

今天遇到一个问题,程序里面用相对路径引用了同一级目录下的一个文件,shell在上一级目录调用程序的时候,发现当前目录变成了上一级目录,于是程序在上一级目录找那个文件。最简单的办法当然是shell脚本里面加cd操作,但是暂时不方便修改脚本。所以直接通过程序获取绝对路径好了。 首先,直接 realpath(“./”) 和 getcwd 获取的都是当前路径,也就是当前shell所在的路径。__FILE__获取的是文件名,不包含路径,而且是编译过程确定的,最简单的办法当然是argv[0],但是在test_case(gtest)里面不方便传来传去,后来发现最好的办法是这样的: #include "libgen.h" #define MAX_PATH_SIZE 100 char current...

Read more

分布式调试之导入import文件

最近看元启师兄写了一个脚本更新所有重构之后的include引用,我暂时没有需要如此伤筋动骨的代码,所以暂时用不上。但是有时候引用一个类要去找所在的文件,而有时候经常会记错地方。写了一个简单的vim插件依赖ctags来找对象或函数所在的位置。代码如下: if !exists('g:base_dir_mark') "set base_dir_mark to indicate where to generate post-review.sh let g:base_dir_mark = 'tags' endif if !exists('g:strip_prefix_arr') "set base_dir_mark to indicate where to gen...

Read more