我是 mpfr 的初学者,我写了这个程序来进行特定的计算并像你看到的那样得到它,但我不知道为什么会出现这个错误,这是我最重要的代码:
mpfr_t myfct(int n)
{
/......./
return mpfr_get(result,MPFR_RNDN);
}
int main(void)
{
mpfr_t U;
mpfr_set_default_prec (53);
mpfr_set_emin (-1073);
mpfr_set_emax (1024);
n=10;
mpfr_init2(U,24);
mpfr_get(U,my_fct(n),MPFR_RNDN);
mpfr_printf ("result: %.40Rg\n", U);
mpfr_clear(U);
return 0;
}
怎么了??
最佳答案
如 GMP 类型,mpfr_t
是一个大小为 1 的数组(元素是一个结构,但您实际上不需要知道这一点)。如果您决定编写一个返回 MPFR 数字的函数,您有 2 种可能性(以及其他):
- 调用者分配并初始化
mpfr_t
具有一定的精度。在这种情况下,mpfr_t
应该作为函数的参数,this 是指向实际传递的这个数组的指针(根据 C 语言的规则)。基本上,这可以看作是传递变量by reference。 . MPFR 函数使用此方法。 - 调用者不分配任何东西。函数的原型(prototype)应该是函数返回一个指针
mpfr_ptr
。到结构。所以,这个函数将分配mpfr_t
通常与malloc
(以便函数返回时不会释放内存),然后用mpfr_init2
初始化结构.精度可以由此函数选择或作为参数传递。
注意:你的程序有各种错别字,但我想这不是这个问题的重点。
关于c - 错误 : declared as function returning an array in c (mpfr libary),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40136973/