c# decimal 四舍五入

当:decimal sum = 123456.784M;

sum = decimal.Round(sum, 2 , MidpointRounding.AwayFromZero); 

sum 的值为:123456.78

当:decimal sum = 123456.785M;

sum = decimal.Round(sum, 2 , MidpointRounding.AwayFromZero); 

sum 的值为:123456.79

 

 

在C#的数字运算过程中,有时候针对十进制decimal类型的计算需要保留2位有效小数,针对decimal变量保留2位有效小数有多种方法,可以使用Math.Round方法以及ToString先转换为字符串等操作来实现。

(1)方法一:使用C#中的数字计算类Math类中的方法Math.Round方法。

Math.Round方法是用于计算四舍五入的方法,其中一个方法签名为decimal Round(decimal d, int decimals),d代表要进行计算的decimal变量,decimals代表保留的小数位数。

例如有个decimal类型变量numDecimal=34.3471,需要对之保留2位有效数字可使用下列语句:

 decimal numDecimal = 34.3471M;
 numDecimal = Math.Round(numDecimal, 2);

计算结果为:34.35,Math.Round方法进行了四舍五入操作。

(2)方法二:先使用ToString转换为字符串,再转换回decimal类型。

使用该办法的时候,调用ToString方法也会进行四舍五入操作。

继续方法一中的例子,如果使用ToString方法,可使用下列程序语句:

 decimal numDecimal = 34.3471M;
string numDecimalStr = numDecimal.ToString("#0.00");
numDecimal = decimal.Parse(numDecimalStr);

计算结果为:34.35,ToString("#0.00")对计算结果转换为字符串进行了四舍五入操作。

(3)方法三:先使用String.Format方法格式化decimal类型为字符串,而后在转换为decimal类型。

使用该办法的时候,同样会像上面2个方法一样,对计算结果进行四舍五入。

继续方法一中的例子,如果使用String.Format方法,可使用下列程序语句:

decimal numDecimal = 34.3471M;
string numDecimalStr = String.Format("{0:N}", numDecimal);
numDecimal = decimal.Parse(numDecimalStr);

### SQLi-Labs 第14解决方案 #### 背景理解 在SQLi-Labs第14中,存在一个登录验证页面,其查询语句如下所示: ```sql Select login_name, password from users where id=('our input here') ``` 此查询用于验证用户输入的身份信息。 #### 布尔盲注基础理论 当页面回显区不显示任何内容时,表明逻辑与运算被执行并返回`false`的结果。这是因为条件 `id='input' AND 1=2` 导致整个表达式的求值为假[^2]。因此,在这种情况下可以利用布尔盲注技术逐步推断出数据库中的敏感信息。 #### 使用IF函数实现字符匹配判断 为了实施布尔型SQL注入攻击,可借助MySQL内置的`IF()`函数来进行条件测试。具体来说就是构造带有猜测性质的数据包发送给服务器端口,并观察响应差异以确认假设是否成立。例如: ```sql AND IF(ASCII(SUBSTRING((SELECT column FROM table LIMIT 1),position,1))>value,true_part,false_part) ``` 这段代码会基于指定位置上的单个字符与其预期值之间的比较结果决定后续操作路径的选择。 #### 实际应用案例解析 对于本题目而言,则可以通过不断调整payload参数来逐位获取目标字段的内容直至完全还原为止。下面给出了一组可能有效的载荷模板供参考: ```sql ?id=admin' AND ASCII(SUBSTRING(password,1,1))>97 -- ``` 这条命令的意思是在已知用户名为admin的前提下尝试确定密码首字母位于ASCII码表中的相对大小系;如果推测正确则继续深入探索下一个字节直到遍历完成全部字符串长度范围内的每一个组成部分。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值