Tillbaka till svenska Fidonet
English   Information   Debug  
ENET.LINGUISTIC   0/13
ENET.POLITICS   0/4
ENET.SOFT   0/11701
ENET.SYSOP   33946
ENET.TALKS   0/32
ENGLISH_TUTOR   0/2000
EVOLUTION   0/1335
FDECHO   0/217
FDN_ANNOUNCE   0/7068
FIDONEWS   24159
FIDONEWS_OLD1   21162/49742
FIDONEWS_OLD2   0/35949
FIDONEWS_OLD3   0/30874
FIDONEWS_OLD4   0/37224
FIDO_SYSOP   12852
FIDO_UTIL   0/180
FILEFIND   0/209
FILEGATE   0/212
FILM   0/18
FNEWS_PUBLISH   4436
FN_SYSOP   41708
FN_SYSOP_OLD1   71952
FTP_FIDO   0/2
FTSC_PUBLIC   0/13615
FUNNY   0/4886
GENEALOGY.EUR   0/71
GET_INFO   105
GOLDED   0/408
HAM   0/16075
HOLYSMOKE   0/6791
HOT_SITES   0/1
HTMLEDIT   0/71
HUB203   466
HUB_100   264
HUB_400   39
HUMOR   0/29
IC   0/2851
INTERNET   0/424
INTERUSER   0/3
IP_CONNECT   719
JAMNNTPD   0/233
JAMTLAND   0/47
KATTY_KORNER   0/41
LAN   0/16
LINUX-USER   0/19
LINUXHELP   0/1155
LINUX   0/22112
LINUX_BBS   0/957
mail   18.68
mail_fore_ok   249
MENSA   0/341
MODERATOR   0/102
MONTE   0/992
MOSCOW_OKLAHOMA   0/1245
MUFFIN   0/783
MUSIC   0/321
N203_STAT   930
N203_SYSCHAT   313
NET203   321
NET204   69
NET_DEV   0/10
NORD.ADMIN   0/101
NORD.CHAT   0/2572
NORD.FIDONET   189
NORD.HARDWARE   0/28
NORD.KULTUR   0/114
NORD.PROG   0/32
NORD.SOFTWARE   0/88
NORD.TEKNIK   0/58
NORD   0/453
OCCULT_CHAT   0/93
OS2BBS   0/787
OS2DOSBBS   0/580
OS2HW   0/42
OS2INET   0/37
OS2LAN   0/134
OS2PROG   0/36
OS2REXX   0/113
OS2USER-L   207
OS2   0/4786
OSDEBATE   0/18996
PASCAL   0/490
PERL   0/457
PHP   0/45
POINTS   0/405
POLITICS   0/29554
POL_INC   0/14731
PSION   103
R20_ADMIN   1123
R20_AMATORRADIO   0/2
R20_BEST_OF_FIDONET   13
R20_CHAT   0/893
R20_DEPP   0/3
R20_DEV   399
R20_ECHO2   1379
R20_ECHOPRES   0/35
R20_ESTAT   0/719
R20_FIDONETPROG...
...RAM.MYPOINT
  0/2
R20_FIDONETPROGRAM   0/22
R20_FIDONET   0/248
R20_FILEFIND   0/24
R20_FILEFOUND   0/22
R20_HIFI   0/3
R20_INFO2   3251
R20_INTERNET   0/12940
R20_INTRESSE   0/60
R20_INTR_KOM   0/99
R20_KANDIDAT.CHAT   42
R20_KANDIDAT   28
R20_KOM_DEV   112
R20_KONTROLL   0/13302
R20_KORSET   0/18
R20_LOKALTRAFIK   0/24
R20_MODERATOR   0/1852
R20_NC   76
R20_NET200   245
R20_NETWORK.OTH...
...ERNETS
  0/13
R20_OPERATIVSYS...
...TEM.LINUX
  0/44
R20_PROGRAMVAROR   0/1
R20_REC2NEC   534
R20_SFOSM   0/341
R20_SF   0/108
R20_SPRAK.ENGLISH   0/1
R20_SQUISH   107
R20_TEST   2
R20_WORST_OF_FIDONET   12
RAR   0/9
RA_MULTI   106
RA_UTIL   0/162
REGCON.EUR   0/2056
REGCON   0/13
SCIENCE   0/1206
SF   0/239
SHAREWARE_SUPPORT   0/5146
SHAREWRE   0/14
SIMPSONS   0/169
STATS_OLD1   0/2539.065
STATS_OLD2   0/2530
STATS_OLD3   0/2395.095
STATS_OLD4   0/1692.25
SURVIVOR   0/495
SYSOPS_CORNER   0/3
SYSOP   0/84
TAGLINES   0/112
TEAMOS2   0/4530
TECH   0/2617
TEST.444   0/105
TRAPDOOR   0/19
TREK   0/755
TUB   0/290
UFO   0/40
UNIX   0/1316
USA_EURLINK   0/102
USR_MODEMS   0/1
VATICAN   0/2740
VIETNAM_VETS   0/14
VIRUS   0/378
VIRUS_INFO   0/201
VISUAL_BASIC   0/473
WHITEHOUSE   0/5187
WIN2000   0/101
WIN32   0/30
WIN95   0/4289
WIN95_OLD1   57668/70272
WINDOWS   0/1517
WWB_SYSOP   0/419
WWB_TECH   0/810
ZCC-PUBLIC   0/1
ZEC   4

 
4DOS   0/134
ABORTION   0/7
ALASKA_CHAT   0/506
ALLFIX_FILE   0/1313
ALLFIX_FILE_OLD1   0/7997
ALT_DOS   0/152
AMATEUR_RADIO   0/1039
AMIGASALE   0/14
AMIGA   0/331
AMIGA_INT   0/1
AMIGA_PROG   0/20
AMIGA_SYSOP   0/26
ANIME   0/15
ARGUS   0/924
ASCII_ART   0/340
ASIAN_LINK   0/651
ASTRONOMY   0/417
AUDIO   0/92
AUTOMOBILE_RACING   0/105
BABYLON5   0/17862
BAG   135
BATPOWER   0/361
BBBS.ENGLISH   0/382
BBSLAW   0/109
BBS_ADS   0/5290
BBS_INTERNET   0/507
BIBLE   0/3563
BINKD   0/1119
BINKLEY   0/215
BLUEWAVE   0/2173
CABLE_MODEMS   0/25
CBM   0/46
CDRECORD   0/66
CDROM   0/20
CLASSIC_COMPUTER   0/378
COMICS   0/15
CONSPRCY   0/899
COOKING   33441
COOKING_OLD1   0/24719
COOKING_OLD2   0/40862
COOKING_OLD3   0/37489
COOKING_OLD4   0/35496
COOKING_OLD5   9370
C_ECHO   0/189
C_PLUSPLUS   0/31
DIRTY_DOZEN   0/201
DOORGAMES   0/2065
DOS_INTERNET   0/196
duplikat   6002
ECHOLIST   0/18295
EC_SUPPORT   0/318
ELECTRONICS   0/359
ELEKTRONIK.GER   1534
Möte FIDONEWS_OLD1, 49742 texter
 lista första sista föregående nästa
Text 41237, 155 rader
Skriven 2006-10-13 21:23:02 av Michiel van der Vlist (2:280/5555)
  Kommentar till text 41213 av mark lewis (1:3634/12.0)
Ärende: smart compilers (was: pi)
=================================
Hello mark!

On Friday October 13 2006 11:37, you wrote to me:

 MvdV>> I have done quit a bit in Pascal programming, but that was a
 MvdV>> long time ago. Before the  IBM PC (clones) dominated the
 MvdV>> market. My compiler went to the museum together with my home
 MvdV>> brew 8 bit system running 6809 FLEX. Haven't written a line of
 MvdV>> Pascal in over fifteen years. So maybe someone will point out
 MvdV>> that it will not complie at all because something is missing...

 ml> don't look at "the language"... look at the code... t'is a mismash of
 ml> at least three...

I would perhaps have been better if you had chosen a specific language. That
way we would not have to make assumptions on how exactly it interprets this
"code". Or in what order it parses...

 ml>>   if (2+2==5) and (3+3==7) then print "EGADS!";

 ml>>   if (2+2==4) or (3+3==7) then print "whew!";

 ml>>   if (2+2==5) or (3+3==6) then print "Whew!";

 ml>>   if (2+2==4) and (3+3==6) then print "WHEW!";

 MvdV>> All these examples are variations of one ande the same thing. A
 MvdV>> constant between the if and the then. The constant is either
 MvdV>> TRUE or it is FALSE. If it is true the print statement will be
 MvdV>> compiled and executed when the object code is run. If it is
 MvdV>> FALSEe, the smart compiler will skip it so nothing will ever be
 MvdV>> printed.

 ml> ahhh... you see one constant where i see three... a large one made of
 ml> two seperate smaller ones... the large one being made of the "and" and
 ml> "or" between the two smaller ones...

An expression made up of only constants is itself a constant. I was referring
to the (boolean) constant that is the result of evaluating the expression
between the if and the then,


 MvdV>> You want me to do the leg work? Ok...

 MvdV>> EGADS! : skipped
 MvdV>> whew!  : printed
 MvdV>> Whew!  : printed
 MvdV>> WHEW!  : printed

 ml> hey! you didn't take the short-circut like you seemed to be doing
 ml> before... otherwise, you'd have skipped the "Whew!" because the
 ml> evaluation of the first was false and short-circut boolean evaluation
 ml> would have jumped out right there assuming the whole thing was
 ml> false...

Skipping after the first term would have been wrong as it is followed by an or
and what is after the or can change the FALSE into TRUE.

Mind you: in my original example I was just saying that if what is between the
If end the then evaluates to FALSE, then it is irrelevant what follow the then
and it can be skipped.

You are now narrowing it down to the individual terms in the expression bewteen
the if and then but then things become a little bit more complicated. I never
meant to imply that applying short circuit boolen evaluation *that* way is a
good way to handle things.

 ml>> now, try these...

 ml>>   a=2; b=2; c=5; d=3; e=3; f=7;
 ml>>   if (a+b==c) or (d+e==f) then print "egads!";

 MvdV>> Ah, that is a bit more tough. If it is a *very* smart
 MvdV>> optimising compiler it will be aware that although the terms in
 MvdV>> the if statement are written as variables, the actual values
 MvdV>> are already known at compile time and so the compiler will
 MvdV>> handle it the same as when the actual values were substituted:

 ml> yeah, but we're not studying compiler design so please... don't let
 ml> that bother your noggin', eh? each of those variables could have been
 ml> grabbed by some randomizing function... but i had to have some way of
 ml> presenting the scenerios to you...

Well, then it would have been better to say so instead of just presenting them
as hard coded in the source....

 MvdV>> if (2+2==5) or (3+3==7) then print "egads!"

 MvdV>> The compiler will skip it and nothing will be printed

 MvdV>> If it is a less smart compiler, it will treat the terms in the
 MvdV>> if statement as true variables - like the ones that are only
 MvdV>> entered at run time - and generate the complete object code
 MvdV>> needed to handle the general case.

 ml> yes...

Ok, lets us take it from there. a..f are true variables.

 MvdV>> Still, when the object code is run, it will evaluate, the
 MvdV>> condition as FALSE (2+2 is not equal to 5 and 3+3 inot equal to
 MvdV>> 7) and it will not look what is after the then and just skip to
 MvdV>> the statement following the print "egads!"

 ml> and yes...

So far so good.

 ml>>   if (a+b==c) and (d+e==f) then print "EGADS!";

 MvdV>> In this example, when the object code is run, is will not
 MvdV>> evaluate the (d+e==f) part as the condition has already failed
 MvdV>> on the first part.  Whatever is after the and can never make
 MvdV>> the condition come TRUE, so no need to waste time evaluating
 MvdV>> it.

 ml> you're sure? there's several assumptions being made... one is that the
 ml> first statement is on the left ;)

A reasonable assumption. In fact I do not know of any language using this
algebraic notation that does not evaluate left to right. If you ment to use an
exotic language that does it different and still uses this standard algebraic
notation, you should have said so in advance...

 ml>>   c=4;
 ml>>   if (a+b==c) or (d+e==f) then print "whew!";

 ml>>   c=5; f=6;
 ml>>   if (a+b==c) or (d+e==f) then print "Whew!";

 ml>>   c=4; f=6;
 ml>>   if (a+b==c) and (d+e==f) then print "WHEW!";

 MvdV>> I will leave it to the reader to work out the rest, I think I
 MvdV>> have explained the basics.

 ml> yes, the basics as well as some shortcuts that can bite at not so good
 ml> times...

I don't think I have used any such shortcuts. Maybe you misunderstood what I
was trying to convey.

 ml> witness bill gates' numerous demonstrations of various windows
 ml> platforms in front of hundreds of people :0 :) :) :)  witness,
 ml> also, how many bugs have lead to some very severe security holes in
 ml> those same windows platforms...

I am not Bill gates. My programmes, at least the ones I wrote while having full
control over the results do not have holes like that.


Cheers, Michiel

--- GoldED+/W32-MSVC 1.1.5-b20060315
 * Origin: http://www.vlist.eu (2:280/5555)