Linux下的shell編程(基礎)

来源:https://www.cnblogs.com/si-137/archive/2020/07/02/13226409.html
-Advertisement-
Play Games

一.Shell介紹:shell是一個命令行解釋器,腳本語言,活動在應用程式與內核之間,用於接收應用程式(用戶)命令,調用操作系統內核。 (1)編譯型語言: 程式在執行之前需要個專門的編譯過程,把程式編譯成為機器語言文件,運行時不需要重新翻譯,直接使用編譯的結果就行了。程式執行效率高,依養編譯器,跨平 ...


一.Shell介紹shell是一個命令行解釋器,腳本語言,活動在應用程式與內核之間,用於接收應用程式(用戶)命令,調用操作系統內核。

(1)編譯型語言:

程式在執行之前需要個專門的編譯過程,把程式編譯成為機器語言文件,運行時不需要重新翻譯,直接使用編譯的結果就行了。程式執行效率高,依養編譯器,跨平臺性差些。如C、C++、java

(2)解釋型語言:

程式不需要編譯,程式在運行時由解釋器翻譯成機器語言,每執行一次都要翻譯一次。因此效率比較低。比如Python/javaScript/Shell等都是解釋型語言。


 

二、Shell解析器

(1)Linux提供的Shell解析器有:

 

[root@Linux01 home]#  cat /etc/shells
 /bin/sh    是bash的一個快捷方式 
 /bin/bash   bash是大多數Linux預設的shell,包含的功能幾乎可以涵蓋shell所有的功能
 /sbin/nologin  表示非交互,不能登錄操作系統
 /bin/dash  小巧,高效,功能相比少一些
 /bin/tcsh  具有C語言風格的一種shell,具有許多特性,但是也有一些缺陷
  /bin/csh   是csh的增強版本,完全相容csh

 

(2)bash和sh的關係:

[root@Linux01 bin]#  ll  | grep bash
-rwxr-xr-x. 1 root root 942200 3月 23 2017 bash
lrwxrwxrwx. 1 root root 4 6月 29 19:35 sh -> bash

(3)Centos預設的解析器是bash

[root@Linux01 bin]#  echo $SHELL
/bin/bash


 

三、Shell腳本入門

一句話概括:簡單來說腳本就是將需要執行的命令保存到文本中,按照順序執行(由上往下執行),它是解釋型的,不需要編譯。

1.腳本格式

腳本以#!/bin/bash或者#!/bin/env bash開頭(指定解析器)

腳本中間寫註釋信息內容,單行註釋#  多行註釋 :<<EOF   EOF       註釋內容如下

<<EOF
name:second-shell.sh
desc:創建文件,在文件中添加內容,列印信息
update:2020-07-02
path:/home
EOF

然後寫腳本內容

2.第一個Shell腳本:輸出helloworld

(1)需求:創建一個Shell腳本,輸出helloworld

(2)案例實操:

[jinghang@hadoop101 datas]$ touch helloworld.sh

[jinghang@hadoop101 datas]$ vi helloworld.sh

 在helloworld.sh中輸入如下內容

#!/bin/bash

echo "helloworld"

運行腳本,會輸出 helloWord

  3、腳本的常用執行方式

第一種

採用bash或sh+腳本的相對路徑或絕對路徑(不用賦予腳本+x許可權)

       sh+腳本的相對路徑

[jinghang@hadoop101 datas]$ sh helloworld.sh

Helloworld

       sh+腳本的絕對路徑

[jinghang@hadoop101 datas]$ sh /home/jinghang/datas/helloworld.sh

helloworld

       bash+腳本的相對路徑

[jinghang@hadoop101 datas]$ bash helloworld.sh

Helloworld

       bash+腳本的絕對路徑

[jinghang@hadoop101 datas]$ bash /home/jinghang/datas/helloworld.sh

Helloworld

第二種

採用輸入腳本的絕對路徑或相對路徑執行腳本(必須具有可執行許可權+x,推薦採用這種方式)

(a)首先要賦予helloworld.sh 腳本的+x許可權

[jinghang@hadoop101 datas]$ chmod +x helloworld.sh

(b)執行腳本

相對路徑

[jinghang@hadoop101 datas]$ ./helloworld.sh

Helloworld

絕對路徑

[jinghang@hadoop101 datas]$ /home/jinghang/datas/helloworld.sh

Helloworld

註意:第一種執行方法,本質是bash解析器幫你執行腳本,所以腳本本身不需要執行許可權。第二種執行方法,本質是腳本需要自己執行,所以需要執行許可權

4、查看腳本的執行流程(一般使用這個命令來查看腳本執行的步驟)

[jinghang@hadoop101 datas]$ bash -x  batch.sh

5、查看腳本的語法(一般使用這個命令來檢查腳本語法錯誤)

[jinghang@hadoop101 datas]$ bash -n  batch.sh


 

4、shell變數:變數是用來臨時保存數據的,該數據是可以變化的數據

  1. 讀取Shell中所有變數命令:set    讀取環境變數:env
  2. 系統變數
    a)$HOME、$PWD、$SHELL、$USER
    b)讀取變數:echo $變數名

  3. 自定義變數
    a)用戶變數
        作用域(只在當前會話的當前用戶下有效)
        定義變數:
            變數名=值
            變數名=`執行命令`
            變數名=$(執行命令)
        讀取變數:echo $變數名
              echo ${A:2:3}  (切片,讀取變數幾位,索引從0開始,第一個冒號後面代表索引開始位置,第二個冒號後面代表讀取幾位)
              echo ${A}
              echo $A
        撤銷變數:unset 變數名
        靜態變數(一旦創建,只可讀,不能unset): readonly 變數名=值
        定義有類型的變數
            目的:給變數做一些限制,固定變數的類型
            語法:declare 選項 變數名=變數值
            常用選項
                -i 將變數看作整數
                -r 創建只讀變數
    b)全局環境變數
        作用域(針對於當前會話下的所有用戶有效)
        關鍵字:export
        定義變數:export 變數名=值
        撤銷和讀取同上
    c)系統環境變數
        作用域(針對於所有會話下的所有用戶都有效)
        編輯配置文件:vim /etc/profile
            例如添加系統環境變數 MYNAME=jinghang
                #系統環境變數
                export MYNAME=jinghang
       變數生效:source /etc/profile
           
       經驗技巧:
        (1)變數名稱可以由字母、數字和下劃線組成,但是不能以數字開頭,環境變數名建議大寫。
        (2)等號兩側不能有空格
        (3)在bash中,變數預設類型都是字元串類型,無法直接進行數值運算。
        (4)變數的值如果有空格,需要使用雙引號或單引號括起來。

  4. 特殊變數

             a)$n
    語法:$n (功能描述:n為數字,$0代表該腳本名稱,$1-$9代表第一到第九個參數,十以上的參數,十以上的參數需要用大括弧包含,如${10})
     b)$#
    語法:$# (功能描述:獲取所有輸入參數個數,常用於迴圈)
     c)$*
    語法:$* (功能描述:這個變數代表命令行中所有的參數,$*把所有的參數看成一個整體)
     d)$@
    語法:$@ (功能描述:這個變數也代表命令行中所有的參數,不過$@把每個參數區分對待)
     e)$?
    語法:$? (功能描述:最後一次執行命令的返回狀態。如果值為0,命令正確執行;如果值為非0(具體是哪個數,由命令自己來決定),則命令執行不正確)


5、shell數組

  • 定義:

        Shell 數組用括弧來表示,元素用"空格"符號分割開,如果元素中包含空格,則該元素使用雙引號引起來,例如"hello word"

  • 語法:

        往數組裡添加值,數組的長度自增,元素索引從0開始
          數組名=(value1 value2 value3)

  • 賦值:

        創建時添加 數組名=(A B "C B" D)
          創建後添加 數組名[4]=E

  • 修改:

        局部:根據索引修改數組   例如:數組名[0]=F
          整體:可以直接給數組變數重新賦值

  • 讀取:

        獲取數組中所有的元素:echo ${數組名[*]} 或者 echo ${數組名[@]}
          根據索引讀取數組元素:echo ${數組名[索引值]}
          獲取數組的長度:echo ${#數組名[*]} 或者 echo ${#數組名[@]}

  • 刪除:

        unset 關鍵字來刪除數組元素,格式如下:
            unset  數組名[index]
          不寫下標,刪除整個數組,格式如下:
            unset 數組名


 

6、Shell中的運算符

  • 整數運算語法(預設):

    (1)$(( 運算式 ))   或  $[運算式] 
     (2)運算符   + , - , *, /, %   加,減,乘,除,取餘

     (3)運算式要與小擴號之間有空格,中括弧的話不用加空格

  (4)expr + , - , \*, /, % 加,減,乘,除,取餘   註意:expr表達式運算符間要有空格   例如 expr $A  +  $B

  • 小數運算:

       bc:Linux下的一個計算器程式,可以處理整數和小數。Shell 本身只支持整數運算,想計算小數就得使用 bc 這個外部的計算器
        在 Shell 腳本中,藉助管道或者輸入重定向來使用 bc 計算器。
        語法:echo "scale=要保留的小數位數 ; 計算式" | bc
            expression就是希望計算的數學表達式
        案例1:計算3*8/7 結果保留4位小數
            echo "scale=4; 3*8/7" | bc
        案例2:計算3*8/7 ,再乘5,結果保留3位小數
            echo "scale=3; 3*8/7*5" | bc
        案例4:計算4/9,保留2位,結果賦值給ret變數
            ret=$(echo "scale=2;4/9" | bc)


 

7、Shell條件判斷

  • 語法:

        註意:條件非空即為true,[ 判斷式 ]返回true,[判斷式] 返回false。[ 判斷式 ](註意判斷式前後要有空格)

  • 常用條件判斷

    (1)兩個整數之間比較
            -lt 小於(less than)
            -le 小於等於(less equal)
            -eq 等於(equal)
            -gt 大於(greater than)
            -ge 大於等於(greater equal)
    -ne 不等於(Not equal)
    (2)按照文件許可權進行判斷
      -r 有讀的許可權(read)
        -w 有寫的許可權(write)
        -x 有執行的許可權(execute)
    (3)按照文件類型進行判斷
      -f 文件存在並且是一個常規的文件(file)
        -e 文件存在(existence)
        -d 文件存在並是一個目錄(判斷目錄)(directory

  • 案例:

        多條件判斷(&& 表示前一條命令執行成功時,才執行後一條命令,|| 表示上一條命令執行失敗後,才執行下一條命令)
            [jinghang@hadoop101 ~]$ [ condition ] && echo OK || echo NOTOK
            OK
            [jinghang@hadoop101 ~]$ [ condition ] && [ ] || echo NOTOK
            NOTOK

 


8、Shell流程式控制制 

  • if 判斷語句

        註意事項:
        (1)[ 條件判斷式 ],中括弧和條件判斷式之間必須有空格
        (2)if後要有空格

        語法1:
            if [ 條件判斷式 ]
            then
                主體代碼
            fi
        語法2:
            if [ 條件判斷式 ]
            then
                主體代碼
            else
                主體代碼
            fi
        語法3:
            if [ 條件判斷式 ]
            then
                主體代碼
            elif [條件判斷式]
            then
                主體代碼
            else
                主體代碼
            fi

  • case 判斷語句

        基本語法:
            case $變數名 in
                    "值1")
                    如果變數的值等於值1,則執行程式1
                    ;;
                    "值2")
       如果變數的值等於值2,則執行程式2
          ;;
          …省略其他分支…
                    *)
                    如果變數的值都不是以上的值,則執行此程式
                     ;;
              esac
        註意事項:
             1)case行尾必須為單詞“in”,每一個模式匹配必須以右括弧“)”結束。
        2)雙分號“;;”表示命令序列結束,相當於java中的break。
        3)最後的“*)”表示預設模式,相當於java中的default。

  • for 迴圈語句

        基本語法:
      語法一
          for  (( 初始值;迴圈控制條件;變數變化 ))
     do
                  邏輯代碼
          done
      語法二
                $* : 讀取傳入腳本中的全部參數,把參數看作一個整體
                $@ : 讀取傳入腳本中的全部參數,把參數區分對待

 

                    for 變數 in "$*或者$@"
                    do
                         邏輯代碼
                    done

      註意:for 與 ( 號之間要有空格

  • while 迴圈語句

        基本語法
      while [ 條件判斷式 ]
      do
          邏輯代碼
      done
  註意:While 與 [ 號之間要有空格


9、read讀取控制台輸入

  • 基本語法:read 【選項】【參數】

      選項
          -p 指定讀取值時的提示符;
          -t 指定讀取值時等待的時間(秒);
         參數:指定讀取值的變數名

  • 案例

      1、請在3秒內輸入用戶名 

      [root@Linux01 home]# read -p "請在3秒內輸入用戶名:" -t 3 name
      請在3秒內輸入用戶名:zhangsan

  2、通過read定製菜單欄

      cat <<-EOF

     1:代表對數據進行倒序排列
      2:代表對數據進行正序排列
     
EOF

      read -p "請在20秒內輸入數字:" -t  20 num


 

10、Shell函數  

  •  系統函數

      basename
          basename 命令會刪掉所有的首碼包括最後一個(‘/’)字元,然後將字元串顯示出來(去掉路徑,只顯示最後的文件名)
          例如:[root@Linux01 home]# basename /home/test/ccc.txt
          ccc.txt

      dirname
          從給定的包含絕對路徑的文件名中去除文件名,然後返回剩下的路徑(去掉文件名,只顯示文件名之前的絕對路徑)
          例如:[root@Linux01 home]# dirname /home/test/ccc.txt
           /home/test

  •  自定義函數

        語法:
      function 函數名()
      {
     方法體
          [return int;]
      }

        編寫完腳本之後,執行腳本,就能調用函數了,直接輸函數名就可以(在外部調用);在腳本內部調用函數直接函數名就可以。
  經驗技巧
        (1)必須在調用函數地方之前,先聲明函數,shell腳本逐行運行。不會先編譯。
           (2)函數返回值,只能通過$?系統變數獲得,可以顯示加:return返回,如果不加,將以最後一條命令運行結果,作為返回值。return後跟數值n(0-255)
      創建用戶函數(只能當前用戶調用)

    1.在用戶的家目錄中(/home/用戶名)找到隱藏文件.bashrc進行編寫函數

         2.source  .bashrc

         3.現在就能直接調用函數了

   創建系統函數(所有用戶和會話可調用,重啟後仍可調用)

    1.root用戶在/etc/bashrc文件下編寫函數

       2、source  /etc/bashrc

          3.所有用戶都可直接調用

 


 

11、 shell文本處理工具

  •  cut(查看)

      功能描述:cut的工作就是“剪”,具體的說就是在文件中負責剪切數據用的,cut指令用於顯示行中的指定部分,刪除文件中的指定欄位。
        語法:cut 【選項】【文件】
        選項 
            -b <起始位元組位置-結束位元組位置> 僅顯示行中指定位元組範圍的內容。例如,“-b 2-10”將顯示第2~10個位元組位置的內容,當只有一個數字時,則僅顯示指定字元位置的內容.
            -f <起始列位置-結束列位置> 顯示指定列的欄位內容
            -d <分隔符> 指定欄位的分隔符,預設的欄位分隔符為“TAB”
            -c <起始字元位置-結束字元位置> 僅顯示行中指定範圍的字元。例如,“b2-10” 將顯示第2~10個字元位置的內容。當只有一個數字時,則僅顯示指定字元位置的內容
   案例:
    切割ifconfig 後列印的IP地址,顯示ip地址前3位
      ifconfig eth0 | grep "inet addr" | cut -d : -f 2 | cut -d " " -f 1 | cut -c 1-3

  • sort(查看)

   功能描述:它將文件進行排序,並將排序結果標準輸出
  語法:sort 【選項】【參數】
      選項
          -n 依照數值的大小排序
          -r 以相反的順序來排序
          -t 設置排序時所用的分隔字元
          -k 指定需要排序的列
      參數:是指待排序的文件
  案例:
    將用戶列表按照主ID進行倒序排列

    [mayun@Linux01 home]$  sort -t : -nrk 4 /etc/passwd

 

  • 正則表達式

   概述:正則表達式,又稱規則表達式。(英語:Regular Expression,在代碼中常簡寫為regex、regexp或RE)。正則表達式通常被用來檢索、替換那些符合某個模式(規則)的文本
  單字元匹配
    \d 匹配一個數字字元。等價於[0-9]
    \D 匹配一個非數字字元。等價於[^0-9]
    \w 匹配包括下劃線的任何單詞字元。類似但不等價於[A-Za-z0-9_]
    \W 匹配任何非單詞字元。等價於 [^A-Za-z0-9_]
    \s 匹配空白字元,包括空格、製表符、換頁符等等,等價於[ \f\n\r\t\v]
    \S 匹配任何可見字元。等價於[^ \f\n\r\t\v]
    .點 匹配除“\n”和"\r"之外的任何單個字元
    [a-z] 字元範圍,匹配a~z之間的任意字元
    [^a-z] 匹配除了a~z之間的其他字元
    \n 匹配換行符
  多字元匹配
    + 匹配前面的子表達式一次或多次(大於等於1次)
    * 匹配前面的子表達式任意次
    ? 匹配前面的子表達式零次或一次
    {n} n是一個非負整數。匹配確定的n次
    {n,m} m和n均為非負整數,其中n<=m。最少匹配n次且最多匹配m次
  其他
    ^ 匹配輸入字行首
    $ 匹配輸入行尾
    | 將兩個匹配條件進行邏輯“或”(or)運算
      x|y 匹配x或y

  貪婪模式:貪婪模式在整個表達式匹配成功的前提下,儘可能多的匹配   例如: [a-b]*表達式去匹配字元串ababababababbaba,就會全部匹配上

  非貪婪模式:在整個表達式匹配成功的前提下,儘可能少的匹配      例如:[a-b]*?表達式去匹配字元串ababababababbaba,就只會匹配ab

  •  sed

      功能描述:sed是一種單行文本流式編輯器,它一次處理一行內容。處理時,把當前處理的行存儲在臨時緩衝區中,稱為“模式空間”,接著用sed命令處理緩衝區中的內容,處理完成後,把緩衝區的內容送往屏幕。接著處理下一行,這樣不斷重覆,直到文件結束。文件內容並沒有改變,除非你使用重定向存儲輸出。
  語法:sed [選項]  ’命令‘    文件名
  選項 功能
    -e 直接在指令列模式上進行sed的動作編輯(一次執行多個操作時)。
    -i 直接編輯文件(修改源文件)
  命令 功能
    p 列印一般 -n 配合使用
    a 新增,在指定的行之後插入內容
    i 新增,在指定的行之前插入內容
    d 刪除
    s 查找並替換 (註意:如果進行全局的查找替換 sed  -e  's/查找條件/替換字元串/g' )
  案例:
  數據準備
  (1)將“mei nv”這個單詞插入到sed.txt第二行下
    sed  -e '2a mei nv' sed.txt
  (2)刪除sed.txt文件所有以wo開頭的行
    sed  -e '/^wo/d' sed.txt
  (3)將sed.txt文件中wo替換為ni
    sed  -e  's/wo/ni/g'  sed.txt
    註意:‘g’表示global,全部替換
  (4)將sed.txt文件中的第二行刪除並將wo替換為ni
    sed -e '2d'  -e  's/wo/ni/g'  sed.txt
  (5)打開文件註釋單行註釋的行(刪掉第一個#號)
    sed -e  's/^#//g'  sed.txt
   (6) 給文件的前5行內容添加註釋
    sed  -e  '1,5s/^/#/g' sed.txt

  •  awk

   功能描述:是一門編程語言,也是一個強大的文本分析工具,逐行掃描文件,預設從第一行到最後一行,尋找匹配特定模式的行,併在這些行上進行你想要的操作。
  語法:awk 選項 'pattern1{action1} pattern2{action2}...' 文件名
  pattern:表示AWK在數據中查找的內容,就是匹配模式,正則表達式
  action:在找到匹配內容時所執行的一系列命令
  選項 功能
    -F 指定輸入文件折分隔符
    -v 賦值一個用戶定義變數
  案例:
    (1)搜索passwd文件以root關鍵字開頭的所有行,並輸出該行的第7列。
        awk -F : '/^root/{print $7}' passwd
    (2)搜索passwd文件以root關鍵字開頭的所有行,並輸出該行的第1列和第7列,中間以“,”號分割。
        awk -F : '/^root/{print $1","$7}' passwd
        註意:只有匹配了pattern的行才會執行action
    (3)只顯示/etc/passwd的第一列和第七列,以逗號分割,且在所有行前面添加列名user,shell在最後一行添加"總用戶數:用戶數量"。
        awk -F : 'BEGIN{sum=0;print "user, shell"} {sum=sum+1;print $1","$7} END{print "總用戶為:"sum}' passwd

        或者awk -v  sum=0  -F : 'BEGIN{print "user, shell"} {sum=sum+1;print $1","$7} END{print "總用戶為:"sum}' passwd
        註意:BEGIN 在所有數據讀取行之前執行;END 在所有數據執行之後執行。
    (4)將passwd文件中的用戶id增加數值1並輸出計算後的用戶id和用戶名
        awk -v i=1 -F : '{print $1 "," $3+i}' passwd
  awk的內置變數
    變數 說明
      FILENAME 文件名
      NR 已讀的記錄數
      NF 瀏覽記錄的域的個數(切割後,列的個數)
    案例:
    (1)統計passwd文件名,每行的行號,每行的列數
        awk -F: '{print "filename:" FILENAME ", linenumber:" NR ",columns:" NF}' passwd
    (2)切割IP
        ifconfig eth0 | grep "inet addr" | awk -F: '{print $2}' | awk -F " " '{print $1}'
    (3)查詢sed.txt中空行所在的行號
        awk '/^$/{print NR}' sed.txt

 

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 今天就來教大家這個套路: 如何使用 Python 來做出來這樣有點浪漫,又有點極客的“內涵”圖。 當然,能不能靠它得到心儀對象的青睞,就要靠你(命)了。(๑•́₃ •̀๑) 那麼要怎麼做呢? 我們先找一張女神的高清圖片(儘量解析度高點的吧,效果會好點)。這裡以一張原圖是這樣的(解析度是:3840*2 ...
  • # 利用雙指針,一次遍歷,求出結果class Solution: def isPalindrome(self, s: str) -> bool: # 定義變數,接收字元串的長度 length = len(s) # 長度小於等於1直接返回真 if length <= 1:return True # 定 ...
  • string 字元串 tring 類型是二進位安全的,即 string 中可以包含任何數據。 Redis 中的普通 string 採用 raw encoding 即原始編碼方式,該編碼方式會動態擴容,並通過提前預分配冗餘空間,來減少記憶體頻繁分配的開銷。 在字元串長度小於 1MB 時,按所需長度的 2 ...
  • 在 .NET 平臺上,我們有多種方式可以將一段 HTML 文本轉換為一張圖片:HTML Renderer、SelectPdf 、Aspose.Html 等。 在 WinForm 程式中,每一個 System.Windows.Forms.Control 的派生類型均包含一個名為 DrawToBitma ...
  • 為mqtt連接添加用戶名密碼預設沒有用戶名密碼修改配置文件添加用戶名密碼 添加完效果重啟mqtt未添加用戶名連接測試添加用戶名連接測試連接成功 ...
  • 1、Spring Security介紹 Spring security,是一個強大的和高度可定製的身份驗證和訪問控制框架。它是確保基於Spring的應用程式的標準 ——來自官方參考手冊 Spring security 和 shiro 一樣,具有認證、授權、加密等用於許可權管理的功能。和 shiro 不 ...
  • Docker全系列總結如下,後期不定期更新。歡迎基於學習、交流目的的轉載和分享,禁止任何商業盜用,同時希望能帶上原文出處,尊重ITer的成果,也是尊重知識。若發現任何錯誤或紕漏,留言反饋或右側添加本人反饋。正篇001.Docker簡介概述002.Docker安裝部署003.Docker容器管理004 ...
  • 1 安裝yum -y install dnsmasq開放udp tcp 53 埠2,修改配置文件 dnsmasq.conf# grep -Ev "^$|^[#;]" /etc/dnsmasq.conf 查看文件中未註釋的內容信息# vi /etc/dnsmasq.conf #指定上游dns伺服器 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:在C#中,++i和i++都是自增運算符,其中++i先增加值再返回,而i++先返回值再增加。應用場景根據需求選擇,首碼適合先增後用,尾碼適合先用後增。詳細示例提供清晰的代碼演示這兩者的操作時機和實際應用。 在C#中,++i 和 i++ 都是自增運算符,但它們在操作上有細微的差異,主要體現在操作的 ...
  • 上次發佈了:Taurus.MVC 性能壓力測試(ap 壓測 和 linux 下wrk 壓測):.NET Core 版本,今天計劃準備壓測一下 .NET 版本,來測試並記錄一下 Taurus.MVC 框架在 .NET 版本的性能,以便後續持續優化改進。 為了方便對比,本文章的電腦環境和測試思路,儘量和... ...
  • .NET WebAPI作為一種構建RESTful服務的強大工具,為開發者提供了便捷的方式來定義、處理HTTP請求並返迴響應。在設計API介面時,正確地接收和解析客戶端發送的數據至關重要。.NET WebAPI提供了一系列特性,如[FromRoute]、[FromQuery]和[FromBody],用 ...
  • 原因:我之所以想做這個項目,是因為在之前查找關於C#/WPF相關資料時,我發現講解圖像濾鏡的資源非常稀缺。此外,我註意到許多現有的開源庫主要基於CPU進行圖像渲染。這種方式在處理大量圖像時,會導致CPU的渲染負擔過重。因此,我將在下文中介紹如何通過GPU渲染來有效實現圖像的各種濾鏡效果。 生成的效果 ...
  • 引言 上一章我們介紹了在xUnit單元測試中用xUnit.DependencyInject來使用依賴註入,上一章我們的Sample.Repository倉儲層有一個批量註入的介面沒有做單元測試,今天用這個示例來演示一下如何用Bogus創建模擬數據 ,和 EFCore 的種子數據生成 Bogus 的優 ...
  • 一、前言 在自己的項目中,涉及到實時心率曲線的繪製,項目上的曲線繪製,一般很難找到能直接用的第三方庫,而且有些還是定製化的功能,所以還是自己繪製比較方便。很多人一聽到自己畫就害怕,感覺很難,今天就分享一個完整的實時心率數據繪製心率曲線圖的例子;之前的博客也分享給DrawingVisual繪製曲線的方 ...
  • 如果你在自定義的 Main 方法中直接使用 App 類並啟動應用程式,但發現 App.xaml 中定義的資源沒有被正確載入,那麼問題可能在於如何正確配置 App.xaml 與你的 App 類的交互。 確保 App.xaml 文件中的 x:Class 屬性正確指向你的 App 類。這樣,當你創建 Ap ...
  • 一:背景 1. 講故事 上個月有個朋友在微信上找到我,說他們的軟體在客戶那邊隔幾天就要崩潰一次,一直都沒有找到原因,讓我幫忙看下怎麼回事,確實工控類的軟體環境複雜難搞,朋友手上有一個崩潰的dump,剛好丟給我來分析一下。 二:WinDbg分析 1. 程式為什麼會崩潰 windbg 有一個厲害之處在於 ...
  • 前言 .NET生態中有許多依賴註入容器。在大多數情況下,微軟提供的內置容器在易用性和性能方面都非常優秀。外加ASP.NET Core預設使用內置容器,使用很方便。 但是筆者在使用中一直有一個頭疼的問題:服務工廠無法提供請求的服務類型相關的信息。這在一般情況下並沒有影響,但是內置容器支持註冊開放泛型服 ...
  • 一、前言 在項目開發過程中,DataGrid是經常使用到的一個數據展示控制項,而通常表格的最後一列是作為操作列存在,比如會有編輯、刪除等功能按鈕。但WPF的原始DataGrid中,預設只支持固定左側列,這跟大家習慣性操作列放最後不符,今天就來介紹一種簡單的方式實現固定右側列。(這裡的實現方式參考的大佬 ...