📄 dhrystone.cc
字号:
struct Record{ struct Record *PtrComp; Enumeration Discr; Enumeration EnumComp; OneToFifty IntComp; String30 StringComp;};typedef struct Record RecordType;typedef RecordType * RecordPtr;typedef int boolean;#define TRUE 1#define FALSE 0#ifndef REG#define REG#endif/* added: - dl */extern "C" {extern int printf(const char* ...);extern void exit(int);}void Proc0();void Proc1(RecordPtr PtrParIn);void Proc2(OneToFifty *IntParIO);void Proc3(RecordPtr *PtrParOut);void Proc4();void Proc5();boolean Func3(Enumeration EnumParIn);void Proc6(REG Enumeration EnumParIn, REG Enumeration *EnumParOut);void Proc7(OneToFifty IntParI1, OneToFifty IntParI2, OneToFifty *IntParOut);void Proc8(Array1Dim Array1Par, Array2Dim Array2Par, OneToFifty IntParI1, OneToFifty IntParI2);Enumeration Func1(CapitalLetter CharPar1, CapitalLetter CharPar2);boolean Func2(String30 StrParI1, String30 StrParI2);boolean Func3(Enumeration EnumParIn);void mystrcpy(String30 s, char* t){ for (; *t != '\0'; ++s, ++t) *s = *t; *s = '\0';}char mystrcmp(String30 s, String30 t){ for (; *s == *t; ++s, ++t) if (*s == '\0') return 0; return char(*s - *t);}/*end - dl */main(){ Proc0(); exit(0);}/* * Package 1 */Int IntGlob;boolean BoolGlob;char Char1Glob;char Char2Glob;Array1Dim Array1Glob;Array2Dim Array2Glob;RecordPtr PtrGlb;RecordPtr PtrGlbNext;void Proc0(){ OneToFifty IntLoc1; REG OneToFifty IntLoc2; OneToFifty IntLoc3; REG char CharLoc; REG char CharIndex; Enumeration EnumLoc; String30 String1Loc; String30 String2Loc;#ifdef TIME long starttime; long benchtime; long nulltime; register unsigned int i; starttime = time( (_G_time_t *) 0); for (i = 0; i < LOOPS; ++i); nulltime = time( (_G_time_t*) 0) - starttime; /* Computes o'head of loop */#endif#ifdef TIMES time_t starttime; time_t benchtime; time_t nulltime; struct tms Tms; register unsigned int i; times(&Tms); starttime = Tms.tms_utime; for (i = 0; i < LOOPS; ++i); times(&Tms); nulltime = Tms.tms_utime - starttime; /* Computes overhead of looping */#endif PtrGlbNext = new Record; PtrGlb = new Record; PtrGlb->PtrComp = PtrGlbNext; PtrGlb->Discr = Ident1; PtrGlb->EnumComp = Ident3; PtrGlb->IntComp = 40; mystrcpy(PtrGlb->StringComp, "DHRYSTONE PROGRAM, SOME STRING"); mystrcpy(String1Loc, "JUST INITIALIZED TO SOME JUNK.");/*****************-- Start Timer --*****************/#ifdef TIME starttime = time( (_G_time_t*) 0);#endif#ifdef TIMES times(&Tms); starttime = Tms.tms_utime;#endif for (i = 0; i < LOOPS; ++i) { Proc5(); Proc4(); IntLoc1 = 2; IntLoc2 = 3; mystrcpy(String2Loc, "DHRYSTONE PROGRAM, 2'ND STRING"); EnumLoc = Ident2; BoolGlob = ! Func2(String1Loc, String2Loc); while (IntLoc1 < IntLoc2) { IntLoc3 = 5 * IntLoc1 - IntLoc2; Proc7(IntLoc1, IntLoc2, &IntLoc3); ++IntLoc1; } Proc8(Array1Glob, Array2Glob, IntLoc1, IntLoc3); Proc1(PtrGlb); for (CharIndex = 'A'; CharIndex <= Char2Glob; ++CharIndex) if (EnumLoc == Func1(CharIndex, 'C')) Proc6(Ident1, &EnumLoc); IntLoc3 = IntLoc2 * IntLoc1; IntLoc2 = IntLoc3 / IntLoc1; IntLoc2 = 7 * (IntLoc3 - IntLoc2) - IntLoc1; Proc2(&IntLoc1); }/*****************-- Stop Timer --*****************/#ifdef TIME benchtime = time( (_G_time_t *) 0) - starttime - nulltime; printf("Dhrystone time for %ld passes = %ld\n", (long) LOOPS, benchtime); printf("This machine benchmarks at %ld dhrystones/second\n", ((long) LOOPS) / benchtime);#endif#ifdef TIMES times(&Tms); benchtime = Tms.tms_utime - starttime - nulltime; printf("Dhrystone time for %ld passes = %ld\n", (long) LOOPS, benchtime/HZ); printf("This machine benchmarks at %ld dhrystones/second\n", ((long) LOOPS) * HZ / benchtime);#endif}void Proc1(RecordPtr PtrParIn){#define NextRecord (*(PtrParIn->PtrComp)) structassign(NextRecord, *PtrGlb); PtrParIn->IntComp = 5; NextRecord.IntComp = PtrParIn->IntComp; NextRecord.PtrComp = PtrParIn->PtrComp;/* - added coercion (glossing over error in original code) - dl */ Proc3(&(NextRecord.PtrComp)); if (NextRecord.Discr == Ident1) { NextRecord.IntComp = 6; Proc6(PtrParIn->EnumComp, &NextRecord.EnumComp); NextRecord.PtrComp = PtrGlb->PtrComp; Proc7(NextRecord.IntComp, 10, &NextRecord.IntComp); } else structassign(*PtrParIn, NextRecord);#undef NextRecord}void Proc2(OneToFifty *IntParIO){ REG OneToFifty IntLoc; REG Enumeration EnumLoc; IntLoc = *IntParIO + 10; for(;;) { if (Char1Glob == 'A') { --IntLoc; *IntParIO = IntLoc - IntGlob; EnumLoc = Ident1; } if (EnumLoc == Ident1) break; }}void Proc3(RecordPtr *PtrParOut){ if (PtrGlb) *PtrParOut = PtrGlb->PtrComp; else IntGlob = 100; Proc7(10, IntGlob, &PtrGlb->IntComp);}void Proc4(){ REG boolean BoolLoc; BoolLoc = Char1Glob == 'A'; BoolLoc |= BoolGlob; Char2Glob = 'B';}void Proc5(){ Char1Glob = 'A'; BoolGlob = FALSE;}void Proc6(REG Enumeration EnumParIn, REG Enumeration *EnumParOut){ *EnumParOut = EnumParIn; if (! Func3(EnumParIn) ) *EnumParOut = Ident4; switch (EnumParIn) { case Ident1: *EnumParOut = Ident1; break; case Ident2: if (IntGlob > 100) *EnumParOut = Ident1; else *EnumParOut = Ident4; break; case Ident3: *EnumParOut = Ident2; break; case Ident4: break; case Ident5: *EnumParOut = Ident3; }}void Proc7(OneToFifty IntParI1, OneToFifty IntParI2, OneToFifty *IntParOut){ REG OneToFifty IntLoc; IntLoc = IntParI1 + 2; *IntParOut = IntParI2 + IntLoc;}void Proc8(Array1Dim Array1Par, Array2Dim Array2Par, OneToFifty IntParI1, OneToFifty IntParI2){ REG OneToFifty IntLoc; REG OneToFifty IntIndex; IntLoc = IntParI1 + 5; Array1Par[IntLoc] = IntParI2; Array1Par[IntLoc+1] = Array1Par[IntLoc]; Array1Par[IntLoc+30] = IntLoc; for (IntIndex = IntLoc; IntIndex <= (IntLoc+1); ++IntIndex) Array2Par[IntLoc][IntIndex] = IntLoc; ++Array2Par[IntLoc][IntLoc-1]; Array2Par[IntLoc+20][IntLoc] = Array1Par[IntLoc]; IntGlob = 5;}Enumeration Func1(CapitalLetter CharPar1, CapitalLetter CharPar2){ REG CapitalLetter CharLoc1; REG CapitalLetter CharLoc2; CharLoc1 = CharPar1; CharLoc2 = CharLoc1; if (CharLoc2 != CharPar2) return (Ident1); else return (Ident2);}boolean Func2(String30 StrParI1, String30 StrParI2){ REG OneToThirty IntLoc; REG CapitalLetter CharLoc; IntLoc = 1; while (IntLoc <= 1) if (Func1(StrParI1[IntLoc], StrParI2[IntLoc+1]) == Ident1) { CharLoc = 'A'; ++IntLoc; } if (CharLoc >= 'W' && CharLoc <= 'Z') IntLoc = 7; if (CharLoc == 'X') return(TRUE); else { if (mystrcmp(StrParI1, StrParI2) > 0) { IntLoc += 7; return (TRUE); } else return (FALSE); }}boolean Func3(Enumeration EnumParIn){ REG Enumeration EnumLoc; EnumLoc = EnumParIn; if (EnumLoc == Ident3) return (TRUE); return (FALSE);}#ifdef NOSTRUCTASSIGNmemcpy(d, s, l)register char *d;register char *s;int l;{ while (l--) *d++ = *s++;}#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -