关于perl中和C中的sort机制 (转载)
关于perl中和C中的sort机制
(转载)
细读C++ primer,终于理解了一直比较疑惑的perl和C的sort函数机制。我到不是疑惑它的用法,而是很疑惑它的形式,为什么要传递一个子程序的匿名引用给它呢,而且形式还很古怪,一定要是$a<$b,$a<=>$b之类的。要求严格且古怪。
今夜突然看到p.384页,看到书上对quicksort排序算法的讲解终于弄明白了为什么要传递一个如此古怪的子程序,并略思考一下,推想出perl对下标排序的原理以及为何书上说下标排序要快(对一个字长的指针进行交换而不是对内存数据进行交换,除非数组的内容是超长字符串之类的。我倒是曾经试过下标排序,确实要比数组直接排序要快不少)。
另外,关于perl的reference这个名字起名感到很奇怪。这个名字在其它语言中都意味着别名,相当于perl的alias机制。和perl中实际的ref应用完全不搭边。
有人把perl的ref机制称为指针,看起来倒是非常的像了,可惜最大的问题是perl的ref根本不支持pointer所必有的自增++之类的操作(它的自增操作居然是输出一个整数?)。
个人隐约觉得,perl的ref机制倒是和STL中的iterator非常神似,自由,受到保护却用起来轻松,强大。在很多方面比iterator更自由,因此也是我喜欢用perl的ref地原因。也许larry真的很受STL的影响?也许perl在某方面走得更远一些了。
其实很希望perl 6能把ref机制更上一步,借鉴iterator的优点(可惜我在perl 6的RFC中没有看到有关的意向)。perl 6说要做一个完全Object-Orient的语言,其实我更希望它能做一个Generic的语言(在某些方面,我觉得perl 5比STL更Generic,要是再借鉴一下templates模式就好了)
胡说了些感想,很多地方原理只是有此推彼,没有看过有关的perl源码,不一定正确。
相关文档:
1、开发环境请参考《搭建ACE-5.7.4+VS2008开发环境》一文
2、gSOAP库,下载地址:http://gsoap2.sourceforge.net/,本文使用的版本是:gsoap_2.7.15,gSOAP的编程可以参考doc目录下的soapdoc2.pdf,官方文档写的非常详细。
让我们开始gSOAP编码旅程:
1、创建gsoap_server.h:
//gsoap ns2 service namespace: http://l ......
#include <stdio.h>
#define MAXHIST 15
#define MAXWORD 11
#define IN 1
#define OUT 0
//打印输入中单词长度的水平方向直方图,
void main()
{
int c, i, nc, state;
int len; //length of each bar
int maxvalue; &n ......
在VS中写SQL语句的时候,千万万千要小心再小心,比如 说 数据类型的匹配, 单引号(这个能把人迷死)
where 子句中可千万不能有空格(当查询条件为字符串的时候能把你弄疯,我弄这个的时候都疯了几次了,什么都对就是查不出来,调试了N遍才发现。)不行了,吃饭去,再不吃看见活人都想咬了。 ......
如下代码编译运行就会提示R6002错误 #include
struct xxx{
float score;
};
int main()
{
xxx* p = new xxx;
scanf( "%f" , &p->score );
delete p;
} 解决方案很简单 int main()
{
xxx* p ......
如对Android原生(Natvie)C开发还任何疑问,请参阅http://emck.avaw.com/?p=205
虽然现在能通过交叉环境编译程序,并push到Android上执行,但那只是console台程序,是不是有些单调呢?下面就要看如何通过Linux的 framebuffer 技术在Android上画图形,关于Linux的framebuffer技术,这里就不再详细讲解了,请大家google一下 ......