ceiling的用法C语言,c# – Math.Ceiling方法

我在实际的Math.Ceiling函数中得到了强调,该函数背后的算法是如何在.net框架中实现的.

我在mscorlib.dll中使用反编译器检查了函数Math.Ceiling,但它似乎是由本机代码实现的:

jHc1A.png

我怎样才能知道Ceiling函数使用的算法是什么样的?

解决方法:

对于双数字是的,它实际上是external code:

[System.Security.SecuritySafeCritical] // auto-generated

[MethodImplAttribute(MethodImplOptions.InternalCall)]

public static extern double Ceiling(double a);

这意味着该方法实际上是在CLR中实现的,用C语言编写.查找表位于clr/src/vm/ecalllist.h.与Math.Ceiling()相关的部分如下所示:

FCFuncStart(gMathFuncs)

...

FCFuncElement("Log10", COMDouble::Log10)

FCFuncElement("Ceiling", COMDouble::Ceil)

FCFuncElement("SplitFractionDouble", COMDouble::ModFDouble)

...

CLR实现调用本机函数:

FCIMPL1_V(double, COMDouble::Ceil, double d)

WRAPPER_CONTRACT;

STATIC_CONTRACT_SO_TOLERANT;

return (double) ceil(d);

FCIMPLEND

Here is< cmath>的实施:

#include

#include

#pragma STDC FENV_ACCESS ON

double ceil(double x)

{

double result;

int save_round = std::fegetround();

std::fesetround(FE_UPWARD);

result = std::rint(x); // or std::nearbyint

std::fesetround(save_round);

return result;

}

有关详细信息,另请参见Hans answer.

标签:c,algorithm,math,ceiling

来源: https://codeday.me/bug/20190623/1270562.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值