我果然不是星战迷,也没有星战情怀,相比同档期电影可以一看,但是我不是很喜欢这一部。 剧情6分(标准套路,困境解决困境),表演6.5(黑人演员可圈可点,女主没什么说的,机器人没有语言没有表情却异常的生动),娱乐性8分(一分光剑一分BB8)。
星战前六部,正传三部,前传三部,稍早的时候看过了,看原力觉醒之前没有认真补课。但是我知道好莱坞成熟流水线上的电影是不会要求你必须看完前六部再来看这一部电影的,每一部完整的电影都会有其完整的剧情和完整的人物描述。回到这一部原力觉醒,可能是星战迷内心的浴火被燃烧了,从第一部到今年三四十年的时间,足够让一个从青年变成中年甚至老年,伴随星战迷成长的电影总会伴随这一系列的讨论,今天早上看票房成绩已经是影史第四,超过票房第一的阿凡达已经是板上钉钉。基于这样的环境去影院看了。
就像之前说过的那样,这一部在剧情上的设定就是好莱坞标准的剧本设定,产生新的反派,然后需要正义人士组织反抗,制定计划一步一步瓦解反派,实在没有任何需要交代的内容。我甚至在观影过程中连续两次打哈欠,这实属罕见,在以前从来没有出现过,甚至在看《刺客聂隐娘》在场有人睡着的情况下我也没有困意,而这一部看到女主发觉拥有原力,Resistance组织开始制定作战计划开始就已经注定了结局。再到爱情,亲情的设定,总觉得会产生一些问题,大战刚刚结束,公主与将军的见面,再到后面父子的见面总感觉设定上有一些故意而为之。当然这些都是一些小的问题,总体来看剧情还是有一个及格的6分。至少前半部分,已经后面的一些情节,总能够让观众一边被主人公的台词表演逗笑,一边被剧情的紧张气氛而胆战心惊。
再到表演,其实也并没有什么说得,反而到时那个萌萌的机器人能让观众会心一笑,有些时候表演并不需要语言和表情,一举一动都能够看出表演的出彩,或许这也是这部电影在表演上能给我留下的唯一印象,女主,黑人男主,再到哈里森福特,并没有什么特别出彩的地方。
观影风向标定下的娱乐性,其实一直不大明白,娱乐到底是指那一方面,如果是指话题性,新闻性,亦或是卖萌属性的话,就像上面说得那样我会一分给光剑,这一分给的是情怀,一分给BB8,那是因为这个“球”真是太可爱了,可爱到人人都会想要拥有一台。
总之这是一部让我觉得值得票价却也提不出什么优点的电影啦。感谢导演 JJ 艾布拉姆斯,感谢哈里森福特。
Guake is a drop-down terminal for the GNOME desktop which includes split terminal functionality, session save/restore, support for transparency, and many other features.
配置 zsh guake 小记
sudo apt-get update && sudo apt-get install zsh
wget –no-check-certificate https://github.com/robbyrussell/oh-my-zsh/raw/master/tools/install.sh -O – | sh
chsh -s $(which zsh)
From here: https://github.com/robbyrussell/oh-my-zsh
Edit zshrc config vim ~/.zshrc
ZSH_THEME="agnoster"
Install missing fonts here: https://github.com/Lokaltog/powerline-fonts After install missing font, change terminal font to “Melon xx”.
fc-cache -f -v
According to this: https://github.com/coolwanglu/guake-colors-solarized git clone
this repo and run ./set_dark solarized
.
Alt + T
for new tabAlt + W
for close current tabAlt + N
to go to previous tabAlt + P
to go to next tabAlt + C
for copy text to clipboardAlt + V
for paste text from clipboardGuake 自带的终端内搜索 Ctrl + Shift + F
And here is another article about guake, I am taking some shorcut configs from this article. And if you want to build guake from source, you can take a look at thie article.
And all the source code: https://github.com/Guake/guake.
字符串相关库,对应书中第五章 字符串与文本处理,大大增强了C++在文本处理上的能力。 lexical_cast 实现了字符串和数字之间的方便转换;format库提供了C++ 类似 printf() 的能力,用以格式化输出;string_algo 是一个算法库,提供了大量与字符串和文本处理相关的算法;tokenizer 库专注于文本处理领域的分词功能;xpressive 是一个灵活且功能强大的正则表达式解析库。
之前单独有一篇文章讲 lexical_cast 这里不再重复。
format 基本集成了 printf 的格式化语法,每个 printf 格式化选项都以 % 符号开始,后面是格式规则,例如
新增格式:
需要包含头文件
#include <boost/format.hpp>
using namespace boost;
例子:
cout << format ("%s:%d+%d=%d\n" )% "sum" % 1 % 2 % (1+2);
format fmt("(%1% + %2%) * %2% = %3%\n" );
fmt % 2 % 5 % ((2+5) * 5);
cout << fmt.str();
/**
* 程序结果
* sum:1+2=3
* (2 + 5) * 5 = 35
*/
format 还有很多高级的用法,参见文档。
C++98 标准库中提供了字符串标准类 std::string , 它有一些基本成员函数用以查询子串,访问字符,等基本功能。
提供全面的字符串算法库
包含头文件
#include <boost/algorithm/string.hpp>
using namespace boost;
例子:
#include <iostream>
#include <vector>
#include <boost/algorithm/string.hpp>
using namespace std;
using namespace boost;
int main() {
string str("readme.txt");
if (ends_with(str, " txt")) {
cout << to_upper_copy(str) + "UPPER" << endl; // upper case
}
replace_first(str, "readme ", "followme "); // replace
cout << str << endl;
vector<char> v(str.begin(), str.end());
vector<char> v2 = to_upper_copy(erase_first_copy(v, "txt ")); // delete sub string
for (int i = 0; i < v2.size(); ++i) {
cout << v2[i];
}
return 0;
}
string_algo 库命名遵循标准库惯例,算法名均为小写形式,并使用不同前缀或者后缀来区分不同版本,命名规则如下:
string_algo 库提供算法共分为五大类:
每一类算法中都会包含一系列函数。
tokenizer 库是专门用于分词 token 字符串处理库,可以用简单方法把一个字符串分解成若干单词。
tokenizer 库可以容易地执行分词操作,但是它存在一些固有的缺陷。
需包含头文件:
#include <boost/bokenizer.hpp>
using namespace boost;
例子:
#include <iostream>
#include <vector>
#include <cstring>
#include <boost/assign.hpp>
#include <boost/typeof/typeof.hpp>
#include <boost/tokenizer.hpp>
using namespace std;
using namespace boost;
template<typename T>
void print(T &tok) {
for (BOOST_AUTO(pos, tok.begin()); pos != tok.end(); ++pos) {
cout << *pos << "|\t";
}
cout << endl;
}
int main() {
string str("Link radfe the dfafe -adfead");
tokenizer<> tok(str);
print(tok);
/**
* char_separator
* 第一个参数 dropped_delims 分隔符集合,这个集合中的字符不会作为分词结果出现
* 第二个参数 kept_delims 分隔符集合,其中的字符会保留在分词结果中
* 第三个参数 empty_tokens 类似 split 算法 eCompress 参数,处理两个连续出现的分隔符。 keep_empty_tokens 表示连续出现的分隔符标识了一个空字符串。
* 使用默认构造函数,不传入任何参数,行为等同于 char_separator(" ",标点符号字符, drop_empty_tokens) ,以空格和标点符号分词,保留标点符号,不输出空白单词。
*/
char * s = "xxx ;; <yyy-zzz> !!!";
char_separator<char> sep;
tokenizer<char_separator<char>, char *> tok1(s, s + strlen(s), sep);
print(tok1);
char_separator<char> sep1(";-<>!", "", keep_empty_tokens);
tok1.assign(s, s + strlen(s), sep1);
print(tok1);
char_separator<char> sep2(" ;-!", "<>", drop_empty_tokens);
tok1.assign(s, s + strlen(s), sep2);
print(tok1);
/**
* escaped_list_separator
* 专门处理 CSV 格式(Comma Split Value,逗号分割值)的分词对象
* 第一个参数 e 指定了字符串中的转义字符,默认是斜杠\
* 第二个参数是分隔符,默认是逗号
* 第三个参数是引号字符,默认是"
*/
string strcom = "id,100,name,\" mario\"";
escaped_list_separator<char> sepcom;
tokenizer<escaped_list_separator<char> > tokcom(strcom, sepcom);
print(tokcom);
/**
* offset_separator
* 不是基于分隔符,而是使用偏移量,在处理某些不使用分隔符,而使用固定字段宽度文本时非常有用。
* 构造函数接受两个迭代器,也可以是数组指针begin end,指定分词用的整数偏移量序列,整个序列每个元素是分词的宽度
*
bool 参数 bwrapoffsets ,决定是否在偏移量用完之后继续分词
*
bool 参数 return_partial_last 决定在偏移量序列最后是否返回分词不足的部分
* 最后两个参数默认值都是true
*/
string stroffset = "2233344445566666666";
int offsets[] = { 2, 3, 4 };
offset_separator sepoff(offsets, offsets + 3, true, false);
tokenizer<offset_separator> tokoff(stroffset, sepoff);
print(tokoff);
offset_separator sepoff2(offsets, offsets + 3, false);
tokoff.assign(stroffset, sepoff2);
print(tokoff);
offset_separator sepoff3(offsets, offsets + 3, true, false);
print(tokoff);
return 0;
}
正则表达式是处理文本强有力的工具,使用复杂的语法规则,能够解决文本处理领域绝大多数问题,诸如验证、匹配、查找、替换等等。xpressive 是一个先进的、灵活的、功能强大的正则表达式库,提供了对正则表达式全面的支持,而且比原正则表达式库 boost.regex 要好的是它不需要编译,速度快,同时语法又很类似。
xpressive 提供动态和静态两种方式。静态方式使用操作符重载生成编译期的表达对象,可以在编译期进行正则表达式的语法检查。动态的方式则是较传统的用法,与 boost.regex 和 Python 中的 re 模块相似,以字符串作为一个表达式对象,在运行时进行语法检查和处理。
正则表达式定义了一套完善而复杂的语法规则,用于匹配特定模式的字符串,少量字符被用于定义特殊匹配模式语法,它们是: .^$()*+?{}[]\|。
其他经常使用 \d 匹配数字 [0-9] , \w 匹配字母 [a-z] , \s 匹配空格等。
C++ 代码中的斜杠需要变成双斜杠,在使用正则表达式时,在语句前使用注释保存原始表达式,以方便未来的调试和维护。
sregex
和 cregex
用于操作std::string ,和 C风格字符串。须有如下命名空间:
using namespace boost::xpressive;
例子:
#include <iostream>
#include <vector>
#include <cstring>
#include <boost/assign.hpp>
#include <boost/typeof/typeof.hpp>
#include <boost/tokenizer.hpp>
#include <boost/xpressive/xpressive_dynamic.hpp>
using namespace std;
using namespace boost;
int main() {
using namespace boost::xpressive;
string s = "Hi world, I am from Mars!";
sregex reg = sregex::compile("(M\\w{3})");
bool ret = regex_match(s, reg);
// match identity card number
// 18 number , first 6 area code, middle 8 birthday, last 4 random number possible x
// \d{6}(1|2)\d{3}(0|1)\d[0-3]\d\d{3}(X|\d)
// regex_search
// regex_search 检测输入表达式中是否包含正则表达式,即存在一个匹配正则表达式的子串
char* str = "there is a power-suit item";
cregex creg = cregex::compile("(power)-(.{4})\\s(\\w{4})", icase);
ret = regex_search(str, creg);
cmatch what;
regex_search(str , what, creg);
for (int i = 0; i < what.size() ; ++i){
cout << what[i] << endl;
}
// 替换
// regex_replace()
cout << regex_replace(s , reg , "Earth") << endl; // replace Mars with Earth
cout << regex_replace(s , reg , "$1 haha") << endl;
cout << regex_replace(s , reg , "$1 $&") << endl;
s = regex_replace(s , reg , "Earth");
cout << s << endl;
// regex_iterator<>
string ss = "boost1, Boost2, BoOst3, etc";
sregex ssreg = sregex::compile("boost\\d",icase);
sregex_iterator pos(ss.begin(), ss.end(), ssreg);
sregex_iterator end;
while(pos != end){
cout << (*pos)[0] << "\t";
++pos;
}
return 0;
}
如果要更加了解 JVM 启动参数,那么对 JVM 的内存结构需要有一定的了解。JVM 内存主要分为三大块:
初始堆大小,默认值是物理内存的 1/64 . 默认 (MinHeapFreeRatio 参数可以调整)空余堆内存小于 40% 时,JVM 就会增大堆直到 -Xmx 的最大限制。
最大堆大小,物理内存的 1/4(小于 1GB), 默认 (MaxHeapFreeRatio 参数可以调整)空余堆内存大于 70% 时,JVM 会减少堆直到 -Xms 的最小限制。
当堆内存空间溢出时输出堆的内存快照
通常配合 -XX:HeapDumpPath
使用,输出到文件
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/path/to/java_error_xxx.hprof
只有当发生 java.lang.OutOfMemo-ryError
时,才会 dump 到指定文件。
得到 hprof 文件后使用 memory analyzer tool(比如http://eclipse.org/mat/) 来分析。
设置每次年轻代垃圾回收的最长时间,如果无法满足此时间,JVM 会自动调整年轻代大小,以满足此值。
整个堆占用量,开始 GC 。 默认值为 45,当值为 0 时,表示 “do constant GC cycles”。
使用 Garbage First(G1) Collector.
JVM 人为设置了 stack trace 的限制为 1024,可以使用该参数来增加该限制。-1
值表示没有限制。
JVM 致命错误。
该文件包含如下几类关键信息:
查看系统版本和发行版的命令有很多,这里就列一些比较常见的。
uname -a
Linux ev 4.4.0-66-generic #87-Ubuntu SMP Fri Mar 3 15:29:05 UTC 2017 x86_64 x86_64 x86_64 GNU/Linux
uname -r
print distribution-specific information
lsb_release -a
No LSB modules are available.
Distributor ID: Ubuntu
Description: Ubuntu 16.04.1 LTS
Release: 16.04
Codename: xenial
inxi -S
用 Google 日历很多年,但却一直没有体会到 Google Calendar 的精髓,最近在使用过程中越来越得心应手,原因是结合手机的通知栏,能够非常方便的提醒日程。而 Google Calendar 在安排日程之外很棒的一点就是能够共享日历,不管是小到自己的行程安排,再到团队的时间规划安排,再大到一个国家的节假日都能非常轻松的分享出去。
早之前就已经添加了 中国的节假日日历,还有历史上的今天一些有趣的日历,这里就做个总结,在默认情况下 Google Calendar 在左边侧边会有一项 添加日历,在菜单中可以选择 “Browse calendars of interest” 然后在 Google 提供的清单中能够轻松的找到 “宗教日历”,包括 Christian,Jewish,Muslim,Orthodox 的日历,然后还有基于地区的日历,其中包括世界上很多国家的节假日日历,另外还有体育运动的日历,包括篮球、橄榄球、英式足球等各种赛事分类,甚至还有月相(Phases of the Moon) 的日历。简单的勾选即可添加到日历中。
比如说:
其实仔细观察一下就能发现这些日历的 ID,都是语言加上地区,比如说 zh-cn.china#holiday
,zh_cn.china#holiday
表示的就是中文显示中国的节假日,而 en.china#holiday
就表示英文显示中国的假日。
不得不说,其实已经不用添加农历日历了,Google Calendar 已经默认自带了农历,并且和整体搭配非常美观。在设置中,“视图选项”,其中有其他日历选项,选择中文简体,那么就会添加农历日历到界面中。
一个综合型日历分享网站
萨勒姆的女巫
朋友邀请,去北影看了场话剧—-萨勒姆的女巫—-原本对话剧并不了解,最开始了解话剧也才是从《夏洛特烦恼》主演开心麻花,而对于话剧的概念只停留在了电影电视剧的创作中。话剧的表演确实于电影电视剧作品不同,我要刷新一下我的世界观。原来我错过了世界上很多美好的东西,而我却不知道。
原剧本为,亚瑟 米勒 1953年剧本,四幕剧。该剧于1953年1月22日于百老汇的贝克剧院首次演出。之后成为了话剧经典。
小说原标题为 坩埚 “Crucible”,金属容器,可以将金属或者其他物质放入其中高温加热。剧中每个角色隐喻某种金属,接受着周围环境高温的考验。那些拥有超越死亡的道德人物,例如 约翰 普罗克托 和 瑞贝卡 寓指拒绝融化的物质。
帕里斯 牧师
艾比 帕里斯侄女
蒂图巴 Tituba
约翰 普罗克托 John Proctor 率直正直的农场主,剧本的绝对男主
伊丽莎白 普罗克托 John妻子
黑尔 牧师
托马斯帕特南 想要占领别人的土地
安 帕特南 托马斯的妻子,怀孕8次,流产7次
几个想留住的画面:
开场时全员亮相的时候,开场时虽然有一些恐怖,但开场幽灵似得全员亮相震慑住了我。
第二幕家中的对白,虽平淡,故事也很悲伤,但画面却很美好。
第四幕开场伊丽莎白从台阶上出场,画面太美了。
约翰和伊丽莎白的告别戏,将矛盾与个人命运推向高潮,命运的选择只在一瞬间。
很可惜的是这些画面并没有全部留下成为影像,观看的时候,我更愿意融入剧情而不愿意跳脱出来拿起相机。最后只从朋友那边盗来一些影像,不过我个人更加愿意将这些画面留在脑海。
在第一幕,最开始以为 帕里斯牧师 是非常正直的人物形象,而到后面几幕中形象大转变,从收受房契,到金子做的烛台,人物形象一落万丈。而同样人物形象转变的还有黑尔牧师,本来善良正直的牧师,到后来只能堕落颓废到劝说人们认罪。同样帕特南无理指控别人想要强行占他人领土地等等。人物形象的转变和刻画推动着剧情的发展。
而从第二幕开始约翰和伊丽莎白的戏开始,我才渐渐的进入剧情的设定,或者说,到第二幕的时候所有的背景故事,背景人物都才有所交代,故事才得以铺展开来。而第二幕过后剧情渐渐走向高潮,第三幕的审判,引入法官,将矛盾凸显,再到第四幕约翰伊丽莎白以及观众感到深深的绝望,将故事推向结局。
剧情中,几乎每个人的形象都刻画的比较生动。反派为各自的私心陷害别人,受到奴隶遭遇的女孩们的反抗,帕特南为夺取地产而进行的无理指控,而身为牧师的帕里斯为个人的私欲利用人们对上帝的信仰收敛钱财。(这里让我想到了那部印度电影《我个神啊》)而正面的角色,约翰虽然诚实正直,却也背叛了妻子,犯有奸淫罪,在为人上略有瑕疵,一直理性的黑尔牧师也在最后一幕变成了说服别人认罪的绝望者,而 伊丽莎白 为了拯救自己的丈夫,无奈得在法庭上作出了谎言。人人都在萨勒姆这样的炼狱中遭受折磨。
在真正的压抑和悲伤中让剧情达到高潮,然后结束整个舞台,才是真正好的剧本。
对于表演真是,没办法说,就像之前一位同学和我说的一样,无论是电影还是话剧等等的剧情和表演中,在第一遍观看的时候总是让人无法集中到演员的表演上。我在看话剧的时候,第一二幕基本将注意力放到了剧情上,记忆剧情中人物的名字和相貌,整理故事中发生主角的关系,了解故事发生的地点和背景。直到第二幕过后才渐渐的融入到故事的本身。哎,真应该在事前就做一下功课的,不然观看太累太累。当然没有做事前功课也带来另外的好处,也就是剧情发展无法预料到,只有真正到黑幕降下才能知道最后的结局。有的时候心中会设定一个剧情,就像最后我会希望那些女孩会为自己的说谎和无理指控而受到惩罚,而约翰和伊丽莎白会被判为无罪,而这其实都是无力的空想,如果剧作真的做了此结局那就落入了俗套。
关于表演,第一幕中的帕里斯牧师和艾比的表演,后几幕中约翰和妻子的表演都让我印象深刻。其实个人最初的时候最喜欢帕里斯牧师的表演,但是在后来剧情的推进中帕里斯牧师渐渐地走向反面,对角色的厌恶消弱了帕里斯的表演。自第二幕起就喜欢上了约翰和伊丽莎白,就个人偏好来说,其实更加喜欢伊丽莎白平铺的对白,没有约翰激动时口喷唾沫,也没有艾比陷害别人时的高声呐喊,伊丽莎白的表演最能让我感受到自然。虽然伊丽莎白在剧中不是唯一女主,剧情扮演上分量适中,但是其诚实正直的基督徒形象让人无法忘却。
或许我们在评价一个角色表演的时候经常带入角色形象,观众永远只会喜欢剧中的正面角色,从而忽略反派角色,而事实上此剧的艾比和蒂图巴 这两个反面的角色表演同样精彩,hen 同样在第三幕出现的审判长,出现再对立面,而我却无法喜欢上他,或许是因为对长官的天然敌意,亦或许是对审判长审判的公平性的质疑,总之无法让我公正地去评价他的形象。
类Unix系统下最棒的gif录屏应用—- byzanz record 。可能大部分的人会在需要用到gif时,会先用录屏软件将需要截取的内容录成视频,然后用 ffmpeg 或者其他的应用将视频转成 gif 动画。而这样会产生几个问题:
convert
优化,大小依然不乐观。而现在要介绍的 byzanz-record 就是一个轻量级的直接录屏产生 gif 的应用。Byzanz 可以直接避免以上两个问题,将录屏这件事情变得非常容易。看Debian package上面的介绍:
Byzanz is a desktop recorder and command line tool allowing you to record your current desktop or parts of it to an animated GIF, Ogg Theora, Flash or WebM. This is especially useful for publishing on the web.
Byzanz also allows recording of audio, when the output format supports it.
上面的介绍能够看到 Byzanz 的主要功能,同时说了支持的格式 GIF, Ogg Theora, Flash 和 WebM。同时使用的情况就是想要将内容发布到互联网上的时候。如果输出文件支持音频 Byzanz 也支持。
有维护者将 Debian 的代码移植到 PPA,这样我们可以通过 PPA 来安装使用,打开终端,输入以下内容安装:
sudo add-apt-repository ppa:fossfreedom/byzanz
sudo apt-get update && sudo apt-get install byzanz
如果 Ubuntu 14.04 和以上版本,直接使用:
sudo apt-get install byzanz
安装完毕之后可以在终端使用如下命名来熟悉使用 Byzanz:
byzanz-record --duration=10 --x=100 --y=200 --width=700 --height=400 out.gif
通过参数名字能够非常容易的知道含义,duration
就是时长,x
和 y
就是坐标,截取画面左上角的值,width
和 height
就是截取画面的寛和高,也就是画面的大小,最后就是输出文件的名字。
到现在可能有人发现 Byzanz 比较麻烦的地方了,有的时候我不知道要截取的目标的屏幕坐标和大小的时候呢,有的时候只想截取屏幕的某一个部分呢,如果只想录制一个窗口呢?
于是有人写了三个shell脚本文件:
byzanz-record-window
选择一个窗口录制byzanz-record-region
选择部分窗口录制下面分别介绍这三个脚本使用,分别将这些脚本保存到本地,赋予执行权限 chmod +x filename
,如果想要在终端任何地方使用,加入 $PATH
系统环境变量。
下载脚本,加入 $PATH
,使用例子:
byzanz-record-window 30 -c output.gif
$DELAY
变量设置)-c
参数表示byzanz将录制鼠标。
需要依赖: xrectsel
link. 使用 make
命令编译获取可执行的二进制。更多的配置参考项目文件。
使用详情参考上一个 section。
脚本由MHC提供。修改了以上脚本,做出了一个简单的GUI版本。
长达30s钟的gif,而文件大小只有3.5M,对于Web使用来说这是非常可喜的一个大小。而对于10s左右的动画,几乎1M左右的大小,让我感到非常的震惊。
下面就是30s的gif,画质虽然损失较大,但是完全不影响观感。
在我的 https://github.com/einverne/dotfiles 项目中有自动安装 byzanz 的脚本,一键安装然后使用即可。
年初的时候定下计划 2015 年一年至少阅读 20 本书,不管是小说还是专业书,现在离 2015 结束只有短短几天时间了,就梳理一下看过的书好了,顺带检查一下是否完成了任务。可惜结果很令我伤心。满心以为今年能读 20 本书,最后满打满算也只算读了 16 本书。今年欠了 4 本的债,明年 2016 年期望自己能够看下 24 本书吧。
看完电影之后还是不过瘾,于是乎补完小说。小说比电影更加精彩,电影因为时长的原因做了很多删减和改编,看小说更能体会到那种在绝境中想要生存下去的力量。
小说摘录
舍友推荐,舍友因为是英语文学专业,推荐的这本黑色预言式的小说非常的赞,小说对人性的刻画实在是不能让人忘记。这本小说更让我认识了威廉·戈尔丁,英国很著名的小说家。这部小说主要讲述的就是因为战争流失到荒岛的一群小孩,因为利益形成各自集团,之间发生的冲突与矛盾。
摘录
乔治奥威尔 反乌托邦小说,很早以前就想看不过没有坚持下来,今年总算是看完了。然后摘录一些警句。
约翰密尔,其实是很薄的书,因为当时英语课做 presentation 查资料找到,所以一直保存在待看列表。
全书要义可以概括为两条基本原则:
摘录
快乐学哲学 英语课课程材料,通俗易懂的语言介绍西方哲学。推荐看英文原版。
学习 bash 今年系统的学习一下 Linux,但 Linux 体系太复杂,先从 bash 看起。
更加详细一点的 bash 教程
参考bash 学习笔记.
很经典,很详细,却也略显啰嗦的 Linux 入门书
笔记可以参考 linux 学习笔记
因项目需要 C++,Python 的结合,看了 boost.python 部分,后来又自学了 boost 中的 property_tree 用来解析 json。其他部分未详细看,只大略扫过。
学期中做了个讲座,大略的看了一些知识,Git 实在强大,很多特性到现在我也没搞懂。这书要一直备着。
笔记参考git 学习笔记
只学了个大概,因为平时用 C++多。
年初的时候读的,似乎已经忘得差不多了,总之“大数据”很玄乎。
剧本结构设计 忘记了什么时候 200-100 的时候买的了,喜欢看电影,而我们总是谈论到剧情设计,于是就买了一本看。
一直订阅着这位作者的博客,看完这本书之后就全面使用 Evernote 中,放弃了 OneNote,和 Google Keep
摘录
在观看纪录片《操作系统革命》中提到的这本书的作者,正好实验室有这本书,就拿了看了。这本书主要将软件开发的两大方式,正如书名所述,一种是公司内部集中式的开发,另外一种就是类似 GitHub 上那种分工合作式开发。这两者各有利弊,但作者作为 GNU 的倡导者必然是支持开源的。
别告诉我你会记笔记 学会记笔记是很重要的事情。
摘录
看到最后一句话其实感触挺大,回想起 Google Reader 关闭,这真是 Google 做出的很差的一件事情。Reader 中的东西都曾经是阅读过,甚至做过笔记的东西,那也就是自己的东西,再怎么使用 Google 搜索,出来的东西也都不是自己的经验。所以现在我也在培养我隔断时间总结上一阶段的习惯,这样自己总结,自己写下来的东西才真正属于自己。
期待 2016 年美好的开始。
很久没有看到这样反正真实中国的电影了,近两年的国产电影不是被早恋打胎的青春片,就是被各种古怪离奇的古装片,在就是无厘头的喜剧片所霸占。幸而有这样一部电影能够让2015年的国产电影画上一个稍稍圆满的句号。
剧情上,这样一部电影融入了太多真实的新闻,以至于会让人一一和某某事件联系上,人们往往说,电影往往是现实的表现。而这样一部老炮儿正是在真实这件事情上花了太多的功夫。从老北京的腔调到巷口胡同,从酒吧夜宿到马路飙车,从故友借钱到朋友援手,一件一件的小事敲打着人们的心,虽然故事发生在北京,虽然故事的主人公有着特殊的经历,可正是从这样的角度让我们看到了现代人们的人情冷漠,看到了整个中国的一个缩影,城管会不顾形象的殴打底层的百姓,匆匆的行人不会停下匆忙的脚步帮助路边无助的少女,甚至在看到别人跳楼时无情的煽动,更甚至于几十年的友情会在金钱面前变得一文不值。电影中的情节虽是虚构,却真实的让人发抖。电影看至一半就无法忍住打转的眼泪,同情六爷以及他的遭遇,为六爷的仁义感动。我们的社会正迈向黑暗,却少有六爷这样的人出面维护。为何我们会不相信路边求助的少女?为何我们不敢搀扶跌倒的老人?为何我们的眼里只有金钱?是我们少了什么东西吗?是我们被欺骗多次吗?亦或是像电影中说得那样“现在的人们,遇事都躲”。越来越多的人都不讲理,不讲规矩。往小了说就是百姓的日常百态,而往大了说就是三环十二少无法无天,在大就是他爹千万的账单。社会越来越没有理,越来越混乱,而这也仅仅是电影所表现出来的一部分而已。
在说到剧本设计上面,到现在很少的国产电影能够做到情节上的呼应,很多的时候就是主角想要做什么就凭空能够出现什么,而老炮儿在这方面做的非常的棒。现在能够列举的很多情节在前后发展中都能找打影子,六爷用报纸裹挟遗物扔到理发店呼应话匣子在理发店发现用报纸卷着的房产证,六爷心脏病发作呼应早先话匣子一直说心脏的问题,六爷在路边给建工女孩200元钱呼应片末女孩从远方寄来的挂号信,六爷在片尾穿军大衣用日本军刀独自约架呼应儿子和话匣子对话中对六爷十几年前一人单挑十几人的回忆。这样的剧本设计无意让故事的说服力大大增强。电影虽然有很多未交待的事情,但也正是因为这样才造就一部好电影的剧情。一部好电影就应该是将故事的一个切片展现给人们看,甚至能让人们产生就是电影结束了故事还在继续的错觉。如果真能做到那样,这样的电影离佳片也就不远了。而老炮儿正是这样一部电影,剧情没有交代六爷的妻子,也没有交代六爷故友的生活种种,同样也没有交代三环十二少,但是通过一些侧面的描述,通过电影的叙事交代,电影想要讲述的故事是完整的,那就够了。
不得不说的冯小刚表演,早在电影上映之前就被无数的消息所报道,冯小刚凭借此片获得了金马影帝。一直很想看一看一个导演的表演功力,但是不得不说我被冯小刚的演技震撼到失语。可能原先还有一丝的“嘲讽”,只刚刚开头的城管戏,就让我对冯小刚刮目相看。以至于到最后和三环十二少演对手戏,再到拜访故人借钱救子,一丝一毫的表情动作,刷新了我对冯小刚的认识。片中饰演的六爷有着无比庞大的气场,平时看只是胡同巷子里面普普通通的市井小民,而一旦遇事,六爷凭借自己地位打抱不平,用“规矩”解决所有事情。
六爷的几场戏深深的印在了我的脑海里,一是开场和城管的戏,再就是到修车厂和三环十二少的戏,再到朋友(洋火儿)家借钱,到最后颐和园后野湖。每一个和冯小刚演对手戏的演员,无不给冯小刚的气场所压倒。
而其他的表演也就不想说什么了,这部电影只需要看冯小刚一个人演就够了,而六爷身边的一身肌肉的闷三儿(张涵予),无时不刻不在帮助六爷的话匣子(许晴),还有老实憨厚的灯罩儿,他们都个性十足,表演也到没有太大的瑕疵。尤其是闷三儿在修车厂,还有六爷被打闷三儿带领一帮人砸修车厂的几个镜头让张涵予非常帅气。只是在六爷面前就显得弱很多了。
因此最后在剧本上给7.5分,表演给8分,娱乐性思考性给8分。