linux|shell编程|shell脚本内的加减乘除运算实现示例

这篇具有很好参考价值的文章主要介绍了linux|shell编程|shell脚本内的加减乘除运算实现示例。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言:

shell脚本内的加减乘除是由于在编写kubernetes巡检脚本的时候,某些部分需要做一点简单的运算,突然发现我其实对这些不太熟悉。

因此,查阅了一些资料,现在就加减乘除运算在shell脚本内如何应用做一个简单的总结,写的不对的地方请各位轻点喷

shell脚本的加减乘除基本实现

首先,我们看一个错误的示范,简单的以+号连接两个整数变量

#!/bin/bash
a=10
b=11

echo $a+$b

输出如下;

[root@EULER2 ~]# bash test.sh 
10+11

可以看到,原样打印出来了,并不是我们想要的结果,这个问题出现在哪里了呢?

原来,shell是把+两边的数据(数值或者变量)当做字符串,把+当做字符串连接符,最终的结果是把两个字符串拼接在一起形成一个新的字符串。

因此,我们可以使用$(())的形式来包裹运算式,但需要注意,该方式是仅支持整数数字运算

#!/bin/bash
a=10
b=11

echo $((a+b))

还一个等价的let命令形式:

#!/bin/bash
a=10
b=11
let c=a+b
echo $c

下面是一个变形的let 运算表达式(多个表达式,用空格分开表达式):

#!/bin/bash
a=10
b=11
let c=a+b d=a*c
echo $c $d

(多个表达式,用逗号分开表达式) ,但此时只输出最后一个表达式

#!/bin/bash
a=10
b=11
echo $((a+b,a*b))

二,

运算表达式中的除法

除法是一个比较特殊的存在,不管是什么编程语言,除法都是一个特殊的存在,因为,被除不能为零,否则会报错的嘛,其次就是是整除还是浮点精度除,也就是说对除法的结果有精度要求。

OK,那么,就先来说一说整除,也就是两数相除,结果只取整

A:

除法的整除,无精度要求

示例1:

####注:注意了,/ 号前后需要有空格

#!/bin/bash
a=18
b=2
c=`expr  $a / $b`
echo $c

####下面这个输出是7,实际计算结果是7.5,给省略了

#!/bin/bash
a=15
b=2
c=`expr  $a / $b`
echo $c

OK ,上精度需要bc了,let和expr都不能处理浮点数运算,并且对不能控制结果的精度,可以使用bc命令来代替,bc一般跟着管道符|一起使用。

####注:bc命令最小化是没有安装的,因此,centos7很可能需要 yum install bc -y  安装

B,

除法的非整除,有精度要求

示例2:

####注,echo 后面接的是双引号,单引号是不行的哦

#!/bin/bash
a=10
b=3
c=`echo "scale=2;$a/$b" | bc`
echo $c

示例3(shell中的求π值):

####原理:

bc 命令加上 -l 参数后,就可以使用sin/cos/atan等数学函数,其中:
a (x) The arctangent of x, arctangent returns radians. # 就是计算 atan() 反正切值。
由于tan(π/4) = 1 ,所以 π = 4*atan(1)

#####注:π值计算可以体现CPU的算力水平,计算机越好,计算的π值位数越多,速度越快,因此,很多超级计算机的算力也是以这个π值计算为依据。

[root@EULER2 ~]# echo "scale=100; a(1)*4" | bc -l
3.141592653589793238462643383279502884197169399375105820974944592307\
8164062862089986280348253421170676

C,

bc命令输入和输出各种进制

bc工具十分的强大,带参数obase和ibase可以进制转化,此功能通过bc可以轻松实现(两个参数默认情况下,都是十进制,也就是我们通常认知的阿拉伯数字)

示例4:

[root@node1 ~]# echo "ibase=10;obase=2; 4*6"|bc
11000
[root@node1 ~]# echo "ibase=10;obase=10; 4*6"|bc
24

#10进制转化成二进制
[root@node1 ~]# echo "ibase=10;obase=2; 22"|bc
10110

#十进制转化成十六进制
[root@node1 ~]# echo "obase=16;15" | bc
F

#十进制转化成八进制
[root@node1 ~]# echo "obase=8;15" | bc
17

#十进制转化成二进制
[root@node1 ~]# echo "obase=2;15" | bc
1111


#二进制转化成10进制
[root@node1 ~]# echo "ibase=2;1111" | bc
15

D,

平方根计算

###注,关键字sqrt,这个没什么好解释的哈文章来源地址https://www.toymoban.com/news/detail-583208.html

[root@node1 ~]# echo "scale=6; sqrt(2)" | bc
1.414213
[root@node1 ~]# echo "scale=6; sqrt(4)" | bc
2.000000

到了这里,关于linux|shell编程|shell脚本内的加减乘除运算实现示例的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 不用加减乘除做加法

    写一个函数,求两个整数之和,要求在函数体内不得使用+、-、*、/四则运算符号,本题OJ链接 数据范围:两个数都满足 −10≤n≤1000 进阶:空间复杂度 O(1),时间复杂度 O(1) 分析 :本题要求不能使用+、-、*、/,所以我们应该从二进制的角度去考虑,因为二进制的加法可以通

    2024年02月10日
    浏览(29)
  • 图像四则运算(加减乘除)

    实验目的: 1.了解图像的算术运算在数字图像处理中的初步应用。 2.体会图像算术运算处理的过程和处理前后图像的变化。 3.能够实现简单的图像处理 实验原理: 图像的代数运算包括加,减,乘,除,这些运算的主要对象是图像数据块中的数据。这四种代数运算可以由如

    2024年02月08日
    浏览(37)
  • C语言加减乘除运算

    加减乘除是常见的数学运算,C语言当然支持,不过,C语言中的运算符号与数学中的略有不同,请见下表。 加法 减法 乘法 除法 求余数(取余) 数学 + - × ÷ 无 C语言 + - * / % C语言中的加号、减号与数学中的一样,乘号、除号不同;另外C语言还多了一个求余数的运算符,就是

    2024年02月06日
    浏览(29)
  • 只使用位运算实现加减乘除

    在线OJ: LeetCode 29. 两数相除 原题目的要求是不能使用乘法, 除法和取余运算符实现除法. 在本篇博客中把题目要求提高一点, 这里只使用位运算来实现, 顺便的也就把只使用位运算实现加减乘除实现了. 首先我们需要知道两数之和可以是两个数位相加和不进位相加之和, 而两数进

    2024年02月06日
    浏览(36)
  • Rust 复数运算,重载加减乘除运算

    复数定义 由实数部分和虚数部分所组成的数,形如a+bi 。 其中a、b为实数,i 为“虚数单位”,i² = -1,即虚数单位的平方等于-1。 a、b分别叫做复数a+bi的实部和虚部。 当b=0时,a+bi=a 为实数; 当b≠0时,a+bi 又称虚数; 当b≠0、a=0时,bi 称为纯虚数。 实数和虚数都是复

    2024年02月13日
    浏览(27)
  • Python Opencv实践 - 图像的加减乘除

               

    2024年02月13日
    浏览(25)
  • Pytorch入门:Tensor加减乘除矩阵运算

    若张量维数大于2,则对最后两维进行matmul。进行此运算的要求是张量a与b除最后两维外的其他维必须一致:

    2024年02月12日
    浏览(30)
  • Java进行数字计算 BigDecimal计算(加减乘除)

    Double只能处理16位有效数精度,在某些情况下精度对其需求是不够的,所以就有了BigDecimal。因为BigDecimal的精度范围的范围大,所以在问我们的开发业务中对精度要求高的属性,就需要BigDecimal来进行存储计算,防止精度丢失。这里我主要介绍一下BigDecimal的加,减,乘,除。四

    2023年04月08日
    浏览(27)
  • 用Vue的三种方法实现加减乘除运算

    js插件:vue.js 教程: 首先在工具内引入vue.js 然后在body里面创建一个div并设置id,我这里给id命名为\\\"app\\\" 在id命名为\\\"app\\\"的div内使用input标签和select标签来设置运算框 然后用 methods方法 computed方法 watch(侦听器)方法 做出3种不同的加减乘除运算 第一种computed方法: 接下来我们在

    2024年02月09日
    浏览(85)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包