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

📄 frexp.c

📁 著名操作系统Plan 9的第三版的部分核心源代码。现在很难找到了。Plan 9是bell实验室开发的Unix后继者。
💻 C
字号:
#include <u.h>#include <libc.h>#define	MASK	0x7ffL#define	SHIFT	20#define	BIAS	1022Ltypedef	union{	double	d;	struct	{		long	ls;		long	ms;	};} Cheat;doublefrexp(double d, int *ep){	Cheat x;	if(d == 0) {		*ep = 0;		return 0;	}	x.d = d;	*ep = ((x.ms >> SHIFT) & MASK) - BIAS;	x.ms &= ~(MASK << SHIFT);	x.ms |= BIAS << SHIFT;	return x.d;}doubleldexp(double d, int e){	Cheat x;	if(d == 0)		return 0;	x.d = d;	e += (x.ms >> SHIFT) & MASK;	if(e <= 0)		return 0;	/* underflow */	if(e >= MASK){		/* overflow */		if(d < 0)			return Inf(-1);		return Inf(1);	}	x.ms &= ~(MASK << SHIFT);	x.ms |= (long)e << SHIFT;	return x.d;}doublemodf(double d, double *ip){	Cheat x;	int e;	if(d < 1) {		if(d < 0) {			x.d = modf(-d, ip);			*ip = -*ip;			return -x.d;		}		*ip = 0;		return d;	}	x.d = d;	e = ((x.ms >> SHIFT) & MASK) - BIAS;	if(e <= SHIFT+1) {		x.ms &= ~(0x1fffffL >> e);		x.ls = 0;	} else	if(e <= SHIFT+33)		x.ls &= ~(0x7fffffffL >> (e-SHIFT-2));	*ip = x.d;	return d - x.d;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -