主頁 > 知識庫 > Shell腳本實現C語言代碼行數統計

Shell腳本實現C語言代碼行數統計

熱門標簽:地圖標注輻射圖案 奧維互動地圖標注參數 曲阜400電話辦理 衛(wèi)星地圖標注地名 電銷機器人 劍魚 安裝外呼系統費用 聯通電話機器人怎么接 申請公司400電話要注意什么 寧波智能外呼系統公司

寫了一個比較粗糙的C語言代碼行數統計腳本,目前還有些bug,而且效率也不高。腳本主要就是去除大部分的注釋后統計行數,相當于做了一部分預處理的工作。下面是代碼:

#!/bin/bash 

filename=$1
echo "`whoami`"
if [ $# -lt 1 ];then
 echo "usage : ./scripts filename"
 exit -1
fi

if [ ! -f $filename ];then
 echo "$filename is not a file"
 exit 0;
fi 

user="`whoami`"
if [ "$user" != "root" ];then
 echo "use scripts with root"
 exit 0;
fi

#刪除空行,空行包括:tables + space
sed '/^[[:blank:]]*$/d' $filename > "${filename}_backup"

#刪除 // 所在的行
sed -i '/^[[:blank:]]*\/\//d' "${filename}_backup"

#/*xxxxx*/
#打印/*所有的開始行
grep -n '[[:blank:]]*/[*]' "${filename}_backup" | awk 'BEGIN{FS=":"}{print $1}' > "start.txt"
#打印*/所有的結束行
grep -n '[*]/[[:blank:]]*' "${filename}_backup" | awk 'BEGIN{FS=":"}{print $1}' > "end.txt"

#合并兩個文件,final.txt里面每行就是/*xx....\n....xx*/這種類型注釋的開始行和起始行號
paste "start.txt" "end.txt" > "final.txt"

while read line
do
 #得到起始行
 START=`echo "$line" | awk 'BEGIN{FS="\t"}{print $1}'`
 #得到結束行
 END=`echo "$line" | awk 'BEGIN{FS="\t"}{print $2}'`
 #這里有一個bug,如是/*xxxx*/中的/*和*/在同一行出現,并且有代碼也在同一行
 # printf("hello world\n"); /*打印字符串*/ 
 # /*打印字符串*/
 #上面兩種情況的就沒法判斷,希望大家優(yōu)化
 if [ $START -eq $END ];then
 continue
 fi
 #刪除/*到*/中間所有行
 sed -i "${START},${END}d" "${filename}_backup"
done  "final.txt"

wc -l "${filename}_backup"
rm -f "final.txt" "start.txt" "end.txt"

腳本只能實現大概的代碼行數的統計,不能做到精確統計!
因為沒有做很多的測試,而且也不排除有些比較少見的注釋我沒考慮到,另外腳本的效率也比較差,用了很多tmp文件。
所以希望大家多提提意見!

您可能感興趣的文章:
  • 用shell腳本和c語言將大寫字母轉成小寫的代碼
  • 解析如何在C語言中調用shell命令的實現方法
  • 基于C語言實現shell指令的詳解
  • C語言獲取Shell返回結果的實現方法

標簽:仙桃 三門峽 大慶 安康 遵義 江西 上饒 大興安嶺

巨人網絡通訊聲明:本文標題《Shell腳本實現C語言代碼行數統計》,本文關鍵詞  Shell,腳本,實現,語言,代碼,;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Shell腳本實現C語言代碼行數統計》相關的同類信息!
  • 本頁收集關于Shell腳本實現C語言代碼行數統計的相關信息資訊供網民參考!
  • 推薦文章