Raulg's Interface

RaulgRenascence : Mind, Thoughts, Info...overloaded...

 
· 所有网志 (91) · Technology_Note (7) · ☆SP☆-_Football_Hunter_- (29) · Mind_Search (28) · Movie_Music_Comment (9) · L78Z (18) ·
日历
最新的评论
站内搜索
友情链接
· 我的歪酷 非非共享界
· ghostq跳跃前进
· 纯爷们的Blog
· 尼米特兹

订阅 RSS

0018014

歪酷博客

风之子 @ 2006-03-12 01:02

雅思考试创始人谈英语学习


中青网
  英国莱斯特大学语言学家、雅思考试创始人Keith & Taylor教授在福州大学科学报告厅为福州大学师生350余人作了一场题为“英语学习方法”的报告,把自己30多年的教学经验和有效的英语学习方法介绍给了大家。

  “要学的是信息,而不是语言”

  我们要学习一个国家的语言就得知道这个国家的方方面面。要学习英语就得了解英美国家的社会、经济、人文、历史等各方面的信息。大家请看这个公式:“E≠C; C≠E”,翻译成中文就是:英语不等于汉语的翻译;汉语也不等于英语的翻译。学习英语,我们要学习的是英语国家的文化。请问大家,你们能列举出中国的主要港口吗?这个问题应该很简单。但是,请问各位,你们能列出英国的五个主要港口吗?你们知道苏格兰的首府吗?回答这两个问题也许就不是那么容易了。要把英语学习好,请大家记住:L=I=K,;Language=Information=Knowledge。语言就是信息,语言就是知识。要把英语学好,请大家把英语语言本身忘记,把精力投入到语言所包含的信息上来。尽可能多地了解英国的人文知识和目前的社会状况。

  “学英语要有明确的目标”

  我们在学习英语的时候不妨问问自己这些问题:我为什么要学英语?我要学习什么?我什么时候学习英语?我要在哪里学习英语?我要和谁在一起学习英语?

  在回答了这些问题后,再来学英语,你就会发现进步得更快,效果会更好。我们应该成为有想法的学习者。我们学英语是为了什么?为了出国深造?为了移民?为了出国旅游?带着你的目的来学习吧。这样就能更有成效。但是,如果只是为了应付考试而学,是学不好的。为了考试而学习英语是一种不好的学习方式。选择好你的目标,再开始学习吧,不要着急,记住学英语一定要有明确的目标。

  “只要每天花17分钟,你就可以学好英语”

  请问各位,哪儿是学英语最好的地方呢?我在这里要告诉大家:是——洗澡间。洗澡间其实是最好的学英语的地方。大家一定会笑吧。要知道教室并不是学习英语的最好地方,在课堂上,我们所能学到的是如何去学习。而洗澡间才是学习的好地方,在座的肯定有在洗澡时唱歌的吧?的确,洗澡时唱歌是一件令人惬意的事情。下次,大家冲澡的时候不妨朗诵一段英语。要朗诵多久呢?不长,只要两分钟就足够了。大声地朗读,每天坚持大声地朗读两分钟英语就够了。只要坚持几个月,也许三个月,也许两个月,大家就会发现自己的英语突飞猛进。相信我,信任我,这个方法非常有效,如果大家不相信的话,不妨试试。2分钟在洗澡间,那么另外的15分钟呢?在睡觉前的15分钟你可以听听英国广播公司BBC的节目,也就是我们英国人所熟悉的Radio;4。记住:是在睡觉前的15分钟。为什么要在睡觉前15分钟?这是由于当我们睡觉的时候,我们的大脑并没有休息,它依然在不停的运转。这样我们的记忆无形中就得到了加强。2分钟在洗澡间,加上睡觉前的15分钟,只要17分钟,每天只要17分钟,就可以学好英语。请大家记住这17分钟的学习法。要问其中的奥秘?其实很简单:我们是在快乐地学习。人在快乐的时候,学习是最有效率的,工作也是最有效率的。在早晨的时候,我自己冲一杯咖啡,打开电脑,开始写作,我很喜欢这样的感觉——早晨的宁静,咖啡的浓香,感觉就是这样好。带着这样好的感觉,写作可以说就是一种享受,工作是一种享受。大家在学英语的时候,也不妨为自己创造这样的快乐环境。如果看书看累了,可以看看电影,听听音乐。如果你喜欢巧克力,可以在口中嚼一块。如果你喜欢喝啤酒,也可以在学习的时候喝上一杯。学英语要带着快乐的心情来学,充分享受学习的乐趣。

  “互联网是学习英语的好去处”

  互联网上到处都是信息,这些信息就是学习英语的好材料,还有现在的一些聊天工具,比如ICQ就是利用互联网学习英语的好工具。利用好互联网这个工具,可以让你的英语水平提高更快。

  “要学习做一个‘懒惰的学习者’”

  中国的学生,特别是中国的留学生给我印象最深的是:中国的学生比英国学生勤奋多了。中国的学生通常学习到很晚,经常熬夜。但是,你要知道夜晚是睡觉的时间,不是学习的时间。学英语是一项体力劳动,我们的身体在一段时间的体力劳动后,是会疲劳的,这个时候,就很需要休息。不论是学习英语,还是学习其他的科目,都是如此。累了就得休息,这也是有效学习的方法。不要强迫自己。休息过后,再接着学习,你会发现学习的效率会更高。还有一点,书要有选择地阅读,很多书是不需要每一页,每一行地阅读的。在英国,老师会给你推荐很多很多的书,阅读清单有长长的一串。我在教学生的时候,其实是在教他们如何偷懒——如何有选择地念书,没有必要把所有的书都完完整整地阅读一遍。



 
风之子 @ 2006-01-19 22:14

关于编译选项的文章,豁然开朗
许多Visual C++的使用者都碰到过LNK2005:symbol already defined和LNK1169:one or more multiply defined symbols found这样的链接错误,而且通常是在使用第三方库时遇到的。对于这个问题,有的朋友可能不知其然,而有的朋友可能知其然却不知其所以然,那么本文就试图为大家彻底解开关于它的种种疑惑。

    大家都知道,从C/C++源程序到可执行文件要经历两个阶段:(1)编译器将源文件编译成汇编代码,然后由汇编器(assembler)翻译成机器指令(再加上其它相关信息)后输出到一个个目标文件(object file,VC的编译器编译出的目标文件默认的后缀名是.obj)中;(2)链接器(linker)将一个个的目标文件(或许还会有若干程序库)链接在一起生成一个完整的可执行文件。

    编译器编译源文件时会把源文件的全局符号(global symbol)分成强(strong)和弱(weak)两类传给汇编器,而随后汇编器则将强弱信息编码并保存在目标文件的符号表中。那么何谓强弱呢?编译器认为函数与初始化了的全局变量都是强符号,而未初始化的全局变量则成了弱符号。比如有这么个源文件:

extern int errorno;
int buf[2] = {1,2};
int *p;

int main()
{
   return 0;
}

其中main、buf是强符号,p是弱符号,而errorno则非强非弱,因为它只是个外部变量的使用声明。

    有了强弱符号的概念,我们就可以看看链接器是如何处理与选择被多次定义过的全局符号:

规则1: 不允许强符号被多次定义(即不同的目标文件中不能有同名的强符号);


规则2: 如果一个符号在某个目标文件中是强符号,在其它文件中都是弱符号,那么选择强符号;


规则3: 如果一个符号在所有目标文件中都是弱符号,那么选择其中任意一个;

    由上可知多个目标文件不能重复定义同名的函数与初始化了的全局变量,否则必然导致LNK2005和LNK1169两种链接错误。可是,有的时候我们并没有在自己的程序中发现这样的重定义现象,却也遇到了此种链接错误,这又是何解?嗯,问题稍微有点儿复杂,容我慢慢道来。

    众所周知,ANSI C/C++ 定义了相当多的标准函数,而它们又分布在许多不同的目标文件中,如果直接以目标文件的形式提供给程序员使用的话,就需要他们确切地知道哪个函数存在于哪个目标文件中,并且在链接时显式地指定目标文件名才能成功地生成可执行文件,显然这是一个巨大的负担。所以C语言提供了一种将多个目标文件打包成一个文件的机制,这就是静态程序库(static library)。开发者在链接时只需指定程序库的文件名,链接器就会自动到程序库中寻找那些应用程序确实用到的目标模块,并把(且只把)它们从库中拷贝出来参与构建可执行文件。几乎所有的C/C++开发系统都会把标准函数打包成标准库提供给开发者使用(有不这么做的吗?)。

    程序库为开发者带来了方便,但同时也是某些混乱的根源。我们来看看链接器是如何解析(resolve)对程序库的引用的。
   
    在符号解析(symbol resolution)阶段,链接器按照所有目标文件和库文件出现在命令行中的顺序从左至右依次扫描它们,在此期间它要维护若干个集合:(1)集合E是将被合并到一起组成可执行文件的所有目标文件集合;(2)集合U是未解析符号(unresolved symbols,比如已经被引用但是还未被定义的符号)的集合;(3)集合D是所有之前已被加入到E的目标文件定义的符号集合。一开始,E、U、D都是空的。

(1): 对命令行中的每一个输入文件f,链接器确定它是目标文件还是库文件,如果它是目标文件,就把f加入到E,并把f中未解析的符号和已定义的符号分别加入到U、D集合中,然后处理下一个输入文件。

(2): 如果f是一个库文件,链接器会尝试把U中的所有未解析符号与f中各目标模块定义的符号进行匹配。如果某个目标模块m定义了一个U中的未解析符号,那么就把m加入到E中,并把m中未解析的符号和已定义的符号分别加入到U、D集合中。不断地对f中的所有目标模块重复这个过程直至到达一个不动点(fixed point),此时U和D不再变化。而那些未加入到E中的f里的目标模块就被简单地丢弃,链接器继续处理下一输入文件。

(3): 如果处理过程中往D加入一个已存在的符号,或者当扫描完所有输入文件时U非空,链接器报错并停止动作。否则,它把E中的所有目标文件合并在一起生成可执行文件。

    VC带的编译器名字叫cl.exe,它有这么几个与标准程序库有关的选项: /ML、/MLd、/MT、/MTd、/MD、/MDd。这些选项告诉编译器应用程序想使用什么版本的C标准程序库。/ML(缺省选项)对应单线程静态版的标准程序库(libc.lib);/MT对应多线程静态版标准库(libcmt.lib),此时编译器会自动定义_MT宏;/MD对应多线程DLL版(导入库msvcrt.lib,DLL是msvcrt.dll),编译器自动定义_MT和_DLL两个宏。后面加d的选项都会让编译器自动多定义一个_DEBUG宏,表示要使用对应标准库的调试版,因此/MLd对应调试版单线程静态标准库(libcd.lib),/MTd对应调试版多线程静态标准库(libcmtd.lib),/MDd对应调试版多线程DLL标准库(导入库msvcrtd.lib,DLL是msvcrtd.dll)。虽然我们的确在编译时明白无误地告诉了编译器应用程序希望使用什么版本的标准库,可是当编译器干完了活,轮到链接器开工时它又如何得知一个个目标文件到底在思念谁?为了传递相思,我们的编译器就干了点秘密的勾当。在cl编译出的目标文件中会有一个专门的区域(关心这个区域到底在文件中什么地方的朋友可以参考COFF和PE文件格式)存放一些指导链接器如何工作的信息,其中有一种就叫缺省库(default library),这些信息指定了一个或多个库文件名,告诉链接器在扫描的时候也把它们加入到输入文件列表中(当然顺序位于在命令行中被指定的输入文件之后)。说到这里,我们先来做个小实验。写个顶顶简单的程序,然后保存为main.c :

/* main.c */
int main() { return 0; }

用下面这个命令编译main.c(什么?你从不用命令行来编译程序?这个......) :

cl /c main.c

/c是告诉cl只编译源文件,不用链接。因为/ML是缺省选项,所以上述命令也相当于: cl /c /ML main.c 。如果没什么问题的话(要出了问题才是活见鬼!当然除非你的环境变量没有设置好,这时你应该去VC的bin目录下找到vcvars32.bat文件然后运行它。),当前目录下会出现一个main.obj文件,这就是我们可爱的目标文件。随便用一个文本编辑器打开它(是的,文本编辑器,大胆地去做别害怕),搜索"defaultlib"字符串,通常你就会看到这样的东西: "-defaultlib:LIBC -defaultlib:OLDNAMES"。啊哈,没错,这就
是保存在目标文件中的缺省库信息。我们的目标文件显然指定了两个缺省库,一个是单线程静态版标准库libc.lib(这与/ML选项相符),另外一个是oldnames.lib(它是为了兼容微软以前的C/C++开发系统)。

    VC的链接器是link.exe,因为main.obj保存了缺省库信息,所以可以用

link main.obj libc.lib

或者

link main.obj

来生成可执行文件main.exe,这两个命令是等价的。但是如果你用

link main.obj libcd.lib

的话,链接器会给出一个警告: "warning LNK4098: defaultlib "LIBC" conflicts with use of other libs; use /NODEFAULTLIB:library",因为你显式指定的标准库版本与目标文件的缺省值不一致。通常来说,应该保证链接器合并的所有目标文件指定的缺省标准库版本一致,否则编译器一定会给出上面的警告,而LNK2005和LNK1169链接错误则有时会出现有时不会。那么这个有时到底是什么时候?呵呵,别着急,下面的一切正是为喜欢追根究底的你准备的。

    建一个源文件,就叫mylib.c,内容如下:

/* mylib.c */
#include <stdio.h>

void foo()
{
   printf("%s","I am from mylib!\n");
}

cl /c /MLd mylib.c

命令编译,注意/MLd选项是指定libcd.lib为默认标准库。lib.exe是VC自带的用于将目标文件打包成程序库的命令,所以我们可以用

lib /OUT:my.lib mylib.obj

将mylib.obj打包成库,输出的库文件名是my.lib。接下来把main.c改成:

/* main.c */
void foo();

int main()
{
   foo();
   return 0;
}

cl /c main.c

编译,然后用

link main.obj my.lib

进行链接。这个命令能够成功地生成main.exe而不会产生LNK2005和LNK1169链接错误,你仅仅是得到了一条警告信息:"warning LNK4098: defaultlib "LIBCD" conflicts with use of other libs; use /NODEFAULTLIB:library"。我们根据前文所述的扫描规则来分析一下链接器此时做了些啥。

    一开始E、U、D都是空集,链接器首先扫描到main.obj,把它加入E集合,同时把未解析的foo加入U,把main加入D,而且因为main.obj的默认标准库是libc.lib,所以它被加入到当前输入文件列表的末尾。接着扫描my.lib,因为这是个库,所以会拿当前U中的所有符号(当然现在就一个foo)与my.lib中的所有目标模块(当然也只有一个mylib.obj)依次匹配,看是否有模块定义了U中的符号。结果mylib.obj确实定义了foo,于是它被加入到E,foo从U转移到D,mylib.obj引用的printf加入到U,同样地,mylib.obj指定的默认标准库是libcd.lib,它也被加到当前输入文件列表的末尾(在libc.lib的后面)。不断地在my.lib库的各模块上进行迭代以匹配U中的符号,直到U、D都不再变化。很明显,现在就已经到达了这么一个不动点,所以接着扫描下一个输入文件,就是libc.lib。链接器发现libc.lib里的printf.obj里定义有printf,于是printf从U移到D,而printf.obj被加入到E,它定义的所有符号加入到D,它里头的未解析符号加入到U。链接器还会把每个程序都要用到的一些初始化操作所在的目标模块(比如crt0.obj等)及它们所引用的模块(比如malloc.obj、free.obj等)自动加入到E中,并更新U和D以反应这个变化。事实上,标准库各目标模块里的未解析符号都可以在库内其它模块中找到定义,因此当链接器处理完libc.lib时,U一定是空的。最后处理libcd.lib,因为此时U已经为空,所以链接器会抛弃它里面的所有目标模块从而结束扫描,然后合并E中的目标模块并输出可执行文件。

    上文描述了虽然各目标模块指定了不同版本的缺省标准库但仍然链接成功的例子,接下来你将目睹因为这种不严谨而导致的悲惨失败。

    修改mylib.c成这个样子:

#include <crtdbg.h>

void foo()
{
   // just a test , don't care memory leak
   _malloc_dbg( 1, _NORMAL_BLOCK, __FILE__, __LINE__ );
}

其中_malloc_dbg不是ANSI C的标准库函数,它是VC标准库提供的malloc的调试版,与相关函数配套能帮助开发者抓各种内存错误。使用它一定要定义_DEBUG宏,否则预处理器会把它自动转为malloc。继续用

cl /c /MLd mylib.c
lib /OUT:my.lib mylib.obj

编译打包。当再次用

link main.obj my.lib

进行链接时,我们看到了什么?天哪,一堆的LNK2005加上个贵为"fatal error"的LNK1169垫底,当然还少不了那个LNK4098。链接器是不是疯了?不,你冤枉可怜的链接器了,我拍胸脯保证它可是一直在尽心尽责地照章办事。

    一开始E、U、D为空,链接器扫描main.obj,把它加入E,把foo加入U,把main加入D,把libc.lib加入到当前输入文件列表的末尾。接着扫描my.lib,foo从U转移到D,_malloc_dbg加入到U,libcd.lib加到当前输入文件列表的尾部。然后扫描libc.lib,这时会发现libc.lib里任何一个目标模块都没有定义_malloc_dbg(它只在调试版的标准库中存在),所以不会有任何一个模块因为_malloc_dbg而加入E,但是每个程序都要用到的初始化模块(如crt0.obj等)及它们所引用的模块(比如malloc.obj、free.obj等)还是会自动加入到E中,同时U和D被更新以反应这个变化。当链接器处理完libc.lib时,U只剩_malloc_dbg这一个符号。最后处理libcd.lib,发现dbgheap.obj定义了_malloc_dbg,于是dbgheap.obj加入到E,它里头的未解析符号加入U,它定义的所有其它符号也加入D,这时灾难便来了。之前malloc等符号已经在D中(随着libc.lib里的malloc.obj加入E而加入的),而dbgheap.obj又定义了包括malloc在内的许多同名符号,这引发了重定义冲突,链接器只好中断工作并报告错误。

    现在我们该知道,链接器完全没有责任,责任在我们自己的身上。是我们粗心地把缺省标准库版本不一致的目标文件(main.obj)与程序库(my.lib)链接起来,导致了大灾难。解决办法很简单,要么用/MLd选项来重编译main.c;要么用/ML选项重编译mylib.c。

    在上述例子中,我们拥有库my.lib的源代码(mylib.c),所以可以用不同的选项重新编译这些源代码并再次打包。可如果使用的是第三方的库,它并没有提供源代码,那么我们就只有改变自己程序的编译选项来适应这些库了。但是如何知道库中目标模块指定的默认库呢?其实VC提供的一个小工具便可以完成任务,这就是dumPBin.exe。运行下面这个命令

dumpbin /DIRECTIVES my.lib

然后在输出中找那些"Linker Directives"引导的信息,你一定会发现每一处这样的信息都会包含若干个类似"-defaultlib:XXXX"这样的字符串,其中XXXX便代表目标模块指定的缺省库名。

    知道了第三方库指定的默认标准库,再用合适的选项编译我们的应用程序,就可以避免LNK2005和LNK1169链接错误。喜欢IDE的朋友,你一样可以到 "Project属性" -> "C/C++" -> "代码生成(code generation)" -> "运行时库(run-time library)" 项下设置应用程序的默认标准库版本,这与命令行选项的效果是一样的



 
风之子 @ 2005-11-01 23:29

又被朋友点名-_-###

承蒙susan点名说怪癖,今天吃饭在饭桌上恐吓:“被点名的,再不写生气了”云云,赶快扔下手里的一大堆事儿,跑来数怪癖,哈哈。

之前被一个朋友点名过,http://raulg.yculblog.com/post.866464.html
现在想想好像除了那些,自己好像还有不少怪癖,心里很是不安-_-###

譬如:
1、看碟片喜欢一次性看完,唯一可能interrupt的就是踢球,否则无论多晚多困也要看完。虽然看到后来自己都可能睡着了(多半是碟片本身吸引力的问题),还是不会上床睡觉。然后这部片子就算看过了。

2、有时候总感觉自己有第七感,至少也有第六感觉。总之认为自己是那种先知先觉的人,有点自负,哈哈。 而且我一直认为周围很多人都有特异功能,只是可能99%的人到老也未必知道。

3、能晚睡就尽量晚睡,能晚起就尽量晚起。如果周末吃上早饭,不是因为早起,100%的原因是因为没有睡觉。周末一般都是要熬夜看球的,所以一般是第二天中午才能懒懒的爬起来。然后又熬夜,然后又到第二天中午爬起来。一个周末过后,生物钟总是要重新调整,幸好已经适应这种不规律。

4、奇特的卫生习惯。可能这一阵子比较注意,会经常换洗衣服。突然有一天一件衣服仍那里两天没洗,然后就任其置于一边,然后就会积攒一堆衣服然后哪天想起来或者不得不洗的时候一起洗掉。然后又会经常换洗衣服,然后如此反复。哎,怪癖怪癖。

5、一双鞋穿到破。先说足球鞋,刚开始踢足球,第一双足球鞋穿了将近2年,底磨平了还磨了一层皮,才扔掉,这双鞋洗了很多次,鞋面都发白了。后来的足球鞋就从此再也没洗过,一直穿,穿破的时候扔掉。皮鞋也是的,上大学以来就经常穿皮鞋,一双穿烂了买一双继续穿,如此反复,工作了之后也差不多。

6、怕蚊子咬。当年填报志愿最终选定一南一北两所学校,我分析北方冷,蚊子应该不会太活跃,毅然决然的北上了,事实上东北的文字不但多而且特凶猛,惨,每年早早就挂上蚊帐。

当然还有很多,说起来滔滔不绝。诸如 喜欢用手心或手背擦下巴,一个人想事情的时候最容易犯。对陌生的留长发穿裙子的女孩子比较有好感等等等等。。。不过还是算了。。。适当保留一些吧。^_^


好了,最后再说一个。我对网上一切的传播活动都敬谢不敏。例如“收到这封信后在24小时内转发给20个朋友的就会有好运来临,否则一定会倒霉的”,像这种东西我一般都会直接删除。我总觉得这是一种了无生趣的无聊举动,想着都觉得难受。不过谈论自己的怪癖还算有点意思,所以关于这个怪癖的游戏,我也用了一番心思哦~~


 
风之子 @ 2005-09-14 19:26



有点意思~~
买个T恤竟然要20$,虽然创意不错。
我还是得闪,没钱的日子真可怕。。。


 
风之子 @ 2005-09-12 16:57

9月10日

中午和晚上连续吃火锅。
顺便喝了15瓶啤酒。

9月11日

中午在外面吃饭,没敢要酒。(主要是贵)
晚上又喝了3瓶。

晚上接到济南几个兄弟的电话
说因为...所以他们也多喝了几杯,呵呵。

好久没这么喝的这么爽了。