如何序列化GMP mpf类型?

似乎GMP只提供了mpf(浮点)类型的字符串序列化:

mpf_get_str()mpf_class::get_str()

mpz(整数)类型具有原始字节的附加接口: mpz_out_raw()

http://gmplib.org/manual/Function-Index.html

我错过了什么吗? 有谁知道可以序列化GMP浮标的另一个库? 有谁知道另一个提供强大序列化的bignum lib?

编辑:我很高兴序列化MPFR的mpfr_t,同样似乎只提供字符串输出: http ://www.mpfr.org/mpfr-current/mpfr.html#Function-Index

这是很久以前的事了,但我做了这样的事情:

 int mpf_out_raw (FILE *f, mpf_t X) { int expt; mpz_t Z; size_t nz; expt = X->_mp_exp; fwrite(&expt, sizeof(int), 1, f); nz = X->_mp_size; Z->_mp_alloc = nz; Z->_mp_size = nz; Z->_mp_d = X->_mp_d; return (mpz_out_raw(f, Z) + sizeof(int)); } void mpf_inp_raw (FILE *f, mpf_t X) { int expt; mpz_t Z; size_t nz; mpz_init (Z); fread(&expt, sizeof(int), 1, f); mpz_inp_raw (Z, f); mpf_set_z (X, Z); X->_mp_exp = expt; mpz_clear (Z); } 

您可以在GMP浮点数中输入和输出字节。 Floats I / O上的手册页列出了以下function:

 size_t mpf_out_str (FILE *stream, int base, size_t n_digits, mpf_t op) size_t mpf_inp_str (mpf_t rop, FILE *stream, int base) 

关于手册的令人困惑的部分是它列出了不同部分中不同类型的I / O例程。

编辑:我完全错了! 这些函数正在进行字符串转换,而不是输出原始字节。