modf.c

来自「这是一个同样来自贝尔实验室的和UNIX有着渊源的操作系统, 其简洁的设计和实现易」· C语言 代码 · 共 54 行

C
54
字号
#include <math.h>#include <errno.h>/* modf suitable for IEEE double-precision */#define	MASK	0x7ffL#define SIGN	0x80000000#define	SHIFT	20#define	BIAS	1022Ltypedef	union{	double	d;	struct	{		long	ms;		long	ls;	} i;} Cheat;doublemodf(double d, double *ip){	Cheat x;	int e;	if(-1 < d && d < 1) {		*ip = 0;		return d;	}	x.d = d;	x.i.ms &= ~SIGN;	e = (x.i.ms >> SHIFT) & MASK;	if(e == MASK || e == 0){		errno = EDOM;		*ip = (d > 0)? HUGE_VAL : -HUGE_VAL;		return 0;	}	e -= BIAS;	if(e <= SHIFT+1) {		x.i.ms &= ~(0x1fffffL >> e);		x.i.ls = 0;	} else	if(e <= SHIFT+33)		x.i.ls &= ~(0x7fffffffL >> (e-SHIFT-2));	if(d > 0){		*ip = x.d;		return d - x.d;	}else{		*ip = -x.d;		return d + x.d;	}}

⌨️ 快捷键说明

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