PLT 板


LINE

看板 PLT  RSS
※ 引述《mark1357945 (浮梦)》之铭言: : 我最近在大学的程式语言课程选了Self当作自己的主题语言 : 不过似乎这个语言还满冷门的 周遭的人很多都没听过 : 搜寻过也看了一些论文 但有关Self的sorting相关资料也不太多 : Smalltalk相关的却是找到了不少 : 可是第一次接触Prototype-based的OO语言 (之前只学了C++ 一、两年) : 现在还没有把握能把Smalltalk的code直接看文法转译成Self的版本 : 有高手对这个语言熟悉可以推荐一些书本或参考资料适合入门 : 或是能讲解一下有关实作heap sort的吗? 上次见到这问题,花了一些时间将Self和Smalltalk学起来,终於觉得能掌握一二分, 现在来写写心得. | Smalltalk | Smalltalk这个语言很妙,从1990年之前,发明者开始设计时,就说这个语言包容了 语言,平台与环境,所以到目前的实作是包含作业系统的虚拟机器,即使档案系统 也加以抽象包覆,最後可以说是一套pure object-oriented programming language. 然後他们比较鼓励你,写程式是在一个现成的虚拟平台上,把码加上去,把Unit Test 做上去,你的程式码加进现有的系统,结果就产生新的系统. 於是Kent Back这位 Xtrame Programming的发扬者也蛮喜爱Smalltalk这个语言平台,因为充份发挥了 XP精神. 我选择一种特定的Smalltalk实作,称为Pharo. 所谓排序,大概就是先定义你的资料 是 #(5 2 3 7 6 4) 像这样的阵列,然後对这个阵列送一个讯息sort,请它排序. 呼叫程式如下: #(5 2 3 7 6 4) sort Smalltalk讲物件导向,是说凡是都是物件. 而像上面一行程式那样有二个物件排在 一起的时候,最前面的物件是接收者,而後面全部的物件或标签,数字等等,全都是 讯息. 物件导向最原始的精神就是,对物件传送讯息,这些讯息也就构成你与物件之间 的介面. 回头来看现在Java,有哪些人写熟了能够意识到像以下这行究竟如何称为物件导向: sorter.sort(data); // data = {5, 2, 3, 7, 6, 4} 什麽是物件? 什麽是讯息? 什麽是介面? 搞不清楚,然而就算搞不清楚,很重要吗? 或者这麽说,将一些东西归类为Java所称的interface之後,所获得的只是专属於 interface的制式语法...... 诸如此类,如此一来,反而被语法绑得死死的. Smalltalk的排序. 像泡沫排序大概是这样子写: | list n maybeSwap | "宣告区域变数" list := #(5 2 3 7 6 4). n := list size. "对list送size讯息" maybeSwap := [ :i :j | |x y| i < j ifTrue: [ x := i. y := j ] ifFalse: [ x := j. y := i ]. {x. y} ]. "定义 if a > b swap(a,b) 排序逻辑" 1 to: n-1 do: [ :i | 1 to: n-i do: [ :j | |p| p := maybeSwap value: (list at: j) value: (list at: j+1). list replaceFrom: j to j with: p startingAt: 1. list replaceFrom: j+1 to j+1 with: p startingAt: 2 ] ]. "根据排序逻辑修改list内容" list "list为传回值" 以上这段程式码看起来是程序式的,不过在Pharo,除了只有在称为workspace的 类似记事本的区域可以写写这种脚本之外,没有别的地方让你存放一个脚本. 环境中有一大堆Smalltalk的物件类别,你只能找到适合的类别,把程式写成方法塞进去. 以前面所提到,原本的呼叫程式来说, #(5 2 3 7 6 4) sort 因为#(5 2 3 7 6 4)属於Array类别,所以自己弄个Array>>sort方法,把程式贴进去即可. (Pharo手册说,提到什麽类别拥有什麽方法,是用 Object>>Method 语法来标记. 不过 >> 这不是Smalltalk的语法,而是Pharo自己的标记法,使文件说明时比较方便.) | Self | Self这倒蛮特别的,说是prototype-based programming, 可是仔细看看,Self与 Smalltalk的关系,就像是Javascript自称object-based相对於Java称为object- oriented那样的差别,也就是说,其实是没差的: Smalltalk本来就可以算是 prototype-based programming system. Self跟Smalltalk的程式开发风格一样,都比较是鼓励你先拖拉一些GUI物件出来, 然後把程式码加进去. 不同之处是,恰如prototype-based此称呼之其份,Self比较少了程式语言中较基本的 物件,例如以排序这个题目来看,我一时找不到有关array的语法. 奇怪了,难道Self都不需要array吗? 我仔细看看文件,发现Self已经提供许多 collection prototype了,包括有vector, set, dictionary, list, sequence等等. 如果要读资料,应该是从开档案开始,使用iterator将档案纪录读进物件中. 先启动Self,启动方式是 /usr/bin/Self -s Clean-4.4.snap 即使用VM Self打开OS Clean-4.4.snap. 一开起来看到环境中有一个shell方块, 就从这个物件开始. 在shell方块的evaluation文字编辑区域输入 set copy 然後下面有三个按钮 "Get it", "Do it", "Close" 点 "Get it" 就会产生一个 新的匿名的set物件. 同理, vector copy 然後 "Get it" 就会出现vector物件. 如果有编译错误或执行错误,错误讯息也会变成一小块细细红色的方块,跳出来. 这种作法蛮可爱的. Self 操作手册,基本是耐心读仅有的官方网站提供的tutorial和reference manual 就很够了. 真的最好先熟悉Smalltalk系统操作方式,然後再练习操作Self. 语法方面, Self和Smalltalk有一点点不同. 我在shell物件中输入程式如下: | v. s. i | "宣告区域变数" s: set copy. "取一个set, set是unordered collection" s add: 5. s add: 6. s add: 3. s add: 2. s add: 7. s add:4. v: vector copySize: (s size) FillingWith: 0. "取一个vector,尺寸跟set s一样大" "vector是ordered collection, index是0-based" i: 0. s do: [| :n | v at: i Put: n. i: i+1 ]. v 按 "Get it" 得到一个vector v. 然後我把v的属性框展开来看,发现资料已经排序了. 如此看来,在Self环境中,排序的演算及操作不是很重要的问题. 难怪叫作prototype- based,因为set是未排序资料的prototype,而vector是以排序资料的prototype. 我觉得好像是这样子. --



※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 61.231.68.98 ※ 编辑: yauhh 来自: 61.231.68.98 (03/03 23:09)
1F:→ yauhh:哦哦,核对一下,发现我选错资料结构了. set资料不重复,不适合 03/04 00:37
2F:→ yauhh:一开始拿来存资料. 03/04 00:37
3F:→ yauhh:reference manual提到有PriorityQueue对heapsort很有用.. 03/04 00:38
4F:→ yauhh:以上推文所说的是Self. 03/04 00:41
5F:→ stopcrying:不太明白你说的 prototype是指那方面?是方便做原型? 03/12 01:36
7F:→ yauhh:就是像这个意思,你要用什麽东西都先从系统中找一个像的,copy 03/12 19:46
8F:→ yauhh:来用. 03/12 19:46
9F:→ stopcrying:先把 heapsort放一边,纯 sort的话有个 sortedSequence 03/13 16:19
10F:→ stopcrying:把东西塞塞塞进去就好了说... 03/13 16:19
11F:→ yauhh:所以那样的sort线性几乎是insertion sort,非线性大概就是 03/15 20:26
12F:→ yauhh:sort by search tree 03/15 20:27
13F:→ yauhh:或heap sort 03/15 20:27







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:e-shopping站内搜寻

TOP