切换到宽版
  • 22129阅读
  • 31回复

Free Pascal 和 Turbo Pascal 的主要区别 [复制链接]

上一主题 下一主题
离线李逍遥
 
只看楼主 正序阅读 0 发表于: 2005-10-30
— 本帖被 archimedes 执行取消置顶操作(2007-07-12) —
Free Pascal 和 Turbo Pascal 的主要区别
摘自大榕树www.mydrs.org/dv7

------------------------------------------------------------------------------

虽然Free Pascal尽量设计得和Turbo Pascal接近,但是由于以下的两个原因,两者之间还是有一些区别的:
1.Free Pascal是一个32位的编译器,而Turbo Pascal只是16位编译器;
2.Free Pascal是一个跨平台的编译器,而Turbo Pascal只在windows上使用。

如果你的代码是遵守ANSI Pascal的,那么代码从Turbo Pascal移植到Free Pascal是没有问题的。

下面是在Turbo Pascal上可以使用,但是在Free Pascal就不能使用的一些语言特性:
1.函数和过程在使用时,参数的类型必须和定义时完全一致。原因是在Free Pascal中添加了函数重载功能。
2.PROTECTED,PUBLIC,PUBLISHED,TRY,FINALLY,EXCEPT,RAISE成为了关键字,因此不能作为函数和过程的名字。
3.FAR,NEAR不再是关键字了。原因是Free Pascal是32位系统,不再需要这些关键字。
4.布尔表达式不一定要全部进行计算。只要最终结果已经能够确定,就不再计算其它还没有计算的部分了。比如布尔表达式exp1 AND exp2 AND exp3,如果已知exp1的结果是false,那么怎么表达式的结果肯定是false,exp2和exp3就不用进行计算了。
5.在Free Pascal中,集合中的元素都是4个字节长的。
6.表达式执行的顺序是不确定的。比如对于表达式a:=g(2)+f(3); 不保证g(2)一定在f(3)之前执行。
7.如果用Rewrite打开文件,那么文件就只能被写入了。如果需要读取这个文件,要对文件执行Reset。
8.Free Pascal在程序结束之前一定要关闭输出文件,否则输出文件可能不能被正确的写入。
9.Free Pascal理论上可以使用4GB的内存,因此实际上几乎可以使用系统中的所有剩余内存(除非赛题中有内存限制)。这是Free Pascal由于32位的编译器。但是对于Turbo Pascal来说,由于是16位的编译器,因此不能定义大小超过64KB的数据类型和变量,并且在DOS实模式下可以使用的内存总数只有640KB。

下面是Free Pascal相对于Turbo Pascal扩充的一些功能:

1.函数可以返回复杂的类型,比如记录和数组。

2.在函数中,函数的返回值可以作为一个变量来处理。比如:

function a : longint;
begin
a:=12;
while a>4 do
begin
{...}
end;
end;

这个例子在Turbo Pascal中,a>4会被认为是函数的递归调用,但是在Free Pascal中会认为a只是一个变量。如果想在Free Pascal中实现递归调用,就要写成下面的形式:

function a : longint;
begin
a:=12;
{ this is the recursive call }
if a()>4 then
begin
{...}
end;
end;

3.exit可以接受一个参数作为函数的返回值。比如:

function a : longint;
begin
a:=12;
if a>4 then
begin
exit(a*67); {函数的返回值就是a*67 }
end;
end;

4.Free Pascal支持函数重载。可以用相同的名字定义不同的函数,只要这些函数的参数不同,就是不同的函数。比如:

procedure DoSomething (a : longint);
begin
{...}
end;

procedure DoSomething (a : real);
begin
{...}
end;

可以使用不同的参数类型longint或者real来调用不同的DoSomething过程。

由于这个功能,函数的提前声明必须有完整的参数声明:

procedure x (v : longint); forward;
{...}

procedure x;{ 这里定义的过程x重载了前面声明的过程x。因此这里的两个x是不同的}
begin
{...}
end;

5.Free Pascal容许运算符重载。比如,可以自己为矩阵运算定义一个“+”运算。

6.Free Pascal在windows 95及其以上的windows版本上支持长文件名。对于文件名,由于windows系统对大小写不敏感,因此在程序中,文件名的大小写是无关的。但是对于其它大小写敏感的系统,比如linux,程序中用到的文件名必须和系统中的文件名完全一致。但是由于信息学竞赛的评测系统一般是linux,因此要求程序中的文件名和系统中的文件名一样。
[ 此贴被李逍遥在2005-11-11 21:11重新编辑 ]
离线haiwei
只看该作者 31 发表于: 2007-07-12
谢谢!!!!!!!!!!!!!!!!!!!!!!!!1
haiwei
http://user.qzone.qq.com/317048955
离线yingxiong
只看该作者 30 发表于: 2007-06-29
请看看题解:
program v1318(input,output);
const maxn=26;
var i,j,k,s,t,w:integer;
   a:array[1..maxn] of integer;
   ch:char;
begin
read(s,t,w);
readln;
for i:=1 to w do begin
  read(ch);
  a:=ord(ch)-ord('a')+1;
end;
for i:=1 to 5 do begin
k:=w;
while a[k]+1>t+k-w do dec(k);
inc(a[k]);
for j:=k+1 to w do a[j]:=a[j-1]+1;
for j:=1 to w do begin
ch:=chr(ord('a')-1+a[j]);
write(ch);
end;
writeln;
end;
end.
离线yingxiong
只看该作者 29 发表于: 2007-06-29
描述 Description  
  Jam是个喜欢标新立异的科学怪人。他不使用阿拉伯数字计数,而是使用小写英文字母计数,他觉得这样做,会使世界更加丰富多彩。在他的计数法中,每个数字的位数都是相同的(使用相同个数的字母),英文字母按原先的顺序,排在前面的字母小于排在它后面的字母。我们把这样的“数字”称为Jam数字。在Jam数字中,每个字母互不相同,而且从左到右是严格递增的。每次,Jam还指定使用字母的范围,例如,从2到10,表示只能使用{b,c,d,e,f,g,h,i,j}这些字母。如果再规定位数为5,那么,紧接在Jam数字“bdfij”之后的数字应该是“bdghi”。(如果我们用U、V依次表示Jam数字“bdfij”与“bdghi”,则U<V,且不存在Jam数字P,使U<P<V)。你的任务是:对于从文件读入的一个Jam数字,按顺序输出紧接在后面的5个Jam数字,如果后面没有那么多Jam数字,那么有几个就输出几个。

 
 
输入格式 Input Format
  输入有2行,第1行为3个正整数,用一个空格隔开:
s t w
(其中s为所使用的最小的字母的序号,t为所使用的最大的字母的序号。w为数字的位数,这3个数满足:1≤s<t≤26, 2≤w≤t-s )
第2行为具有w个小写字母的字符串,为一个符合要求的Jam数字。
所给的数据都是正确的,不必验证。

 
 
输出格式 Output Format
  输出最多为5行,为紧接在输入的Jam数字后面的5个Jam数字,如果后面没有那么多Jam数字,那么有几个就输出几个。每行只输出一个Jam数字,是由w个小写字母组成的字符串,不要有多余的空格。

 
 
 
 
 
样例输入 Sample Input  
  2 10 5
bdfij


 
 
样例输出 Sample Output  
  bdghi
bdghj
bdgij
bdhij
befgh

 

  背景 Background
  noip2006普及第3题.
 
 
描述 Description  
  Jam是个喜欢标新立异的科学怪人。他不使用阿拉伯数字计数,而是使用小写英文字母计数,他觉得这样做,会使世界更加丰富多彩。在他的计数法中,每个数字的位数都是相同的(使用相同个数的字母),英文字母按原先的顺序,排在前面的字母小于排在它后面的字母。我们把这样的“数字”称为Jam数字。在Jam数字中,每个字母互不相同,而且从左到右是严格递增的。每次,Jam还指定使用字母的范围,例如,从2到10,表示只能使用{b,c,d,e,f,g,h,i,j}这些字母。如果再规定位数为5,那么,紧接在Jam数字“bdfij”之后的数字应该是“bdghi”。(如果我们用U、V依次表示Jam数字“bdfij”与“bdghi”,则U<V,且不存在Jam数字P,使U<P<V)。你的任务是:对于从文件读入的一个Jam数字,按顺序输出紧接在后面的5个Jam数字,如果后面没有那么多Jam数字,那么有几个就输出几个。

 
 
输入格式 Input Format
  输入有2行,第1行为3个正整数,用一个空格隔开:
s t w
(其中s为所使用的最小的字母的序号,t为所使用的最大的字母的序号。w为数字的位数,这3个数满足:1≤s<t≤26, 2≤w≤t-s )
第2行为具有w个小写字母的字符串,为一个符合要求的Jam数字。
所给的数据都是正确的,不必验证。

 
 
输出格式 Output Format
  输出最多为5行,为紧接在输入的Jam数字后面的5个Jam数字,如果后面没有那么多Jam数字,那么有几个就输出几个。每行只输出一个Jam数字,是由w个小写字母组成的字符串,不要有多余的空格。

 
 
 
 
 
样例输入 Sample Input  
  2 10 5
bdfij


 
 
样例输出 Sample Output  
  bdghi
bdghj
bdgij
bdhij
befgh

 
 
时间限制 Time Limitation
  各个测试点1s
离线yingxiong
只看该作者 28 发表于: 2007-06-29
是这样的,我知道了,多谢你们!
离线hy6210cs
只看该作者 27 发表于: 2007-02-08
不错嘛~~~~~~~~~~~~~~~~~~~~~~~
离线yours诌
只看该作者 26 发表于: 2006-12-09
这次NOIP说推荐用Lazarus,考完试后老师也让我们都改了。能不能提供一下这些方面的资料?
离线archimedes

只看该作者 25 发表于: 2006-11-11
引用第18楼jhtcywbchh2006-01-14 19:32发表的:
怎样定义

很简单啊
operator + (a,b :matrix c:matrix);
离线z410341083
只看该作者 24 发表于: 2006-11-09
我非常需要这个
离线stevenjl

只看该作者 23 发表于: 2006-10-22
我这里没有这个问题
Dream Walker...
快速回复
限100 字节
 
上一个 下一个