⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 dhrystone.cc

📁 早期freebsd实现
💻 CC
📖 第 1 页 / 共 2 页
字号:
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 + -