亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

C#生成防偽碼的思路及源碼分享

2020-01-24 02:40:25
字體:
來源:轉載
供稿:網友

摘 要

1. 生成多個防偽碼,防偽碼的長度和個數由用戶指定。

2. 防偽碼由"0123456789ABCDEFGHJKLMNPQRSTUVWXYZ"字符組成,生成的防偽碼不可以重復,必須是唯一的。

3. 防偽碼的生成要具有隨機性。

4. 在以上要求達到的基礎上,盡可優化程序的速度。

設計思路:

整體的設計思路:根據用戶指定的防偽碼的長度和個數,生成相應的防偽碼,每次生成一個防偽碼時便將防偽碼存儲進哈希表,成功存儲后計數器加1,表示存儲成功,循環執行,當計數器等于用戶指定的防偽碼的個數時,循環停止,輸出防偽碼個數和執行的時間。

防偽碼生成思路:將組成防偽碼的字符用一個字符串存儲,隨機生成0-(字符串長度-1)的一個數,然后取出字符串中該數所在位置的字符,重復執行n次,由這n個字符所組成的新字符串即所求的長度為n的防偽碼。

隨機數的生成:隨機數的生成主要是種子的選擇問題,可用默認的、GUID、RNGCryptoServiceProvider等作為隨機數種子。C#里面常用的是Random類,它是以時間作為默認的隨機種子。GUID則是用來產生32位的唯一隨機數,多用于一些唯一性的標記,由于這個實驗的速度上要求盡可能的快速,而且并不要求產生的隨機數要唯一,所以在實驗中并沒有選擇它來產生隨機數。一開始用的是最常用的Random類來產生一個隨機數,它很方便也很高效,它用的隨機種子是系統的當前時間,由于系統的當前時間是不斷的變化的,所以它產生的偽隨機數也具有很高的隨機性。實驗的過程中,也嘗試了用RNGCryptoServiceProvider來產生隨機數,雖然它的隨機性很好,但是它產生的隨機數有正數和負數,而實驗要求產生的隨機數必須大于0,因此要對產生的隨機數進行判斷和轉化,這大大影響了程序的執行效率(用Random執行時為3秒,用RNGCryptoServiceProvider則為20多秒),最后經過比較和分析,還是改用Random來產生隨機數。

數據的存儲和唯一性的判別:可以用哈希表來存儲產生的防偽碼,主要有以下2個原因:

         a).哈希表是線性存儲,存儲時間非常快。

         b).哈希表可以很快的判定要存儲的元素是否已經存在。

   這里的哈希表選擇的是泛型集合里面的Dictionary<K,T>,其中K是字符類型即防偽碼,T是一個    整型值,Dictionary不允許K的值相同,當有兩個相同的字符串存儲進哈希表時,會出現異常,通過catch出現的異常可以跳過該值的存儲,這就使得生成的防偽碼都是不相同的,該算法的時    間復雜度為常數,即O(1)。由于用的是泛型集合,所以這里不會出現裝箱拆箱操作,所以也大大優化了速度。

 5.速度的優化:速度的優化主要可以從以下幾個方面去考慮:

    a).隨機數的產生,上面已經分析了,當用Random時,效果是最好的。

    b).數據的存儲與查找,用哈希表是存儲數據和查找數據里都是接近線性,當存儲與查找的數        據很大時(接近1000000)依舊可以實現線性,即時間復雜度為O(1),沒有其它數據結構的 性能比它更好了,所以這里用哈希表已接近最優。

    c).字符串的增長和賦值操作,這里重點說一下StringBuilder類型在實驗中的運用。由于實驗       中的防偽碼是由隨機生成的一個個字符組合而成的,所以實驗中出現大量將字符串拼接起來的操作,剛開始的時候用的是String類型,對字符串的拼接操作可以用String str+=char等       簡單操作,但由于String類型的字符串是引用類型,且不可改變,對它進行拼接時內存要花時間生成新的引用,所以在處理這種大量拼接操作的時候效率并不高。后來將String類型         用StringBuilder類型替換,因為StringBuilder類型在處理字符串的拼接時不用生成新的引       用,所以效率大大提高了(用String類型需要7秒跑完,用StringBuilder只需要3秒)。

產生隨機數核心代碼:

復制代碼 代碼如下:

StringBuilder result = new StringBuilder();
Dictionary<String, int> Hash = new Dictionary<String, int>(); //哈希表
string strTableChar = "0123456789ABCDEFGHJKLMNPQRSTUVWXYZ";
int strTableCharLength = strTableChar.Length;
Random random = new Random();
            for (int j = 0; j < count; j++){               //偽碼的個數
                for (int i = 0; i < length; i++){          //偽碼的長度
                    a = random.Next(strTableCharLength);   //產生隨機數
                    result.Append(strTableChar[a]);        //拼接生成防偽碼
                }
                try {
                      Hash.Add(result.ToString(), j);     //將字符串存儲進哈希表
                      result.Clear();                     //清除字符串
                     }
                catch {
                      j--;                                //若字符串相同,則不計數
                      result.Clear();                     //清除字符串
                      }
            }

程序運行效果圖

1.輸入的參數為 10 10000,輸出的結果如下:

程序生成了長度為10個字符的防偽碼10000個,

用時10.0843毫秒。

2.輸入的參數為 20 1000000,輸出的結果如下:

程序生成了長度為20個字符的防偽碼1000000個,

用時1327.3601毫秒。

3.輸入的參數為 50 1000000,輸出的結果如下:

程序生成了長度為50個字符的防偽碼1000000個,

用時2619.9278毫秒。

程序代碼:

復制代碼 代碼如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Diagnostics;       //計時
using System.Collections;       //集合

namespace ConsoleApplication3
{
    class Program
    {
        static void Main(string[] args)
        {
            Stopwatch timer1 = new Stopwatch();           //計時器類
            timer1.Start();                               //開始計時
            int a;
            int length = Convert.ToInt32(args[0]);        //偽碼的長度
            int count = Convert.ToInt32(args[1]);         //偽碼的個數
            StringBuilder result = new StringBuilder();
            Dictionary<String,int> Hash = new Dictionary<String,int >();      
            string strTableChar = "0123456789ABCDEFGHJKLMNPQRSTUVWXYZ";
            int strTableCharLength = strTableChar.Length;
            Random random = new Random();


            for (int j = 0; j < count; j++)               //偽碼的個數
            {
                for (int i = 0; i < length; i++)          //偽碼的長度
                {

                    a = random.Next(strTableCharLength);
                    result.Append(strTableChar[a]);
                }

                try {
                      Hash.Add(result.ToString(),j);
                      result.Clear();
                     }
                catch {
                    j--;                                  //若字符串相同,則不計數
                      result.Clear();
                      }

            }
            count = Hash.Count;                           //哈希表元素的個數
            timer1.Stop();                                //停止計時
            double dMilliseconds = timer1.Elapsed.TotalMilliseconds;
            Console.WriteLine("生成個數為:{0},運行時間為:{1}", count, dMilliseconds);
            Console.ReadKey();
        }
    }
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久久久久久久av| 91精品啪在线观看麻豆免费| 久久久久国产精品免费| 久久人人爽人人爽人人片亚洲| 国产人妖伪娘一区91| 日本一区二三区好的精华液| 欧美精品一区二区免费| 国产精品视频中文字幕91| 欧美亚洲国产日本| 欧美日韩国产精品专区| 欧美一级片一区| 精品久久久久久| 日韩av电影手机在线观看| 91精品国产精品| 精品久久久久久久久久久| 久久天天躁狠狠躁夜夜爽蜜月| 久久99热精品| 日韩电影视频免费| 久久激情五月丁香伊人| 精品国产拍在线观看| 欧美大尺度电影在线观看| 中文字幕一区日韩电影| 欧美日韩在线视频一区二区| 亚洲精品一区二三区不卡| 久久久久久九九九| 97国产精品久久| 亚洲欧美成人精品| www.欧美精品| 日韩在线中文视频| 亚洲成在人线av| 中文字幕日韩在线观看| 欧美精品免费在线| 日韩中文在线观看| 57pao成人永久免费视频| 国产亚洲激情在线| 国产亚洲综合久久| 亚洲欧美日韩国产中文| 4444欧美成人kkkk| 国产精品亚洲美女av网站| www国产精品视频| 中文日韩在线观看| 91精品久久久久久综合乱菊| 亚洲精品国产精品国自产观看浪潮| 亚洲人成电影在线播放| 国产精品18久久久久久麻辣| 欧美日韩精品中文字幕| 日韩在线播放视频| 欧美伊久线香蕉线新在线| 国产精品偷伦免费视频观看的| 国产性色av一区二区| 成人av电影天堂| 最近2019免费中文字幕视频三| 91在线免费观看网站| 成人xxxx视频| 97免费中文视频在线观看| 日韩一区视频在线| 97国产真实伦对白精彩视频8| 国产日韩欧美在线观看| 日韩影视在线观看| 成人黄在线观看| 欧洲成人午夜免费大片| 久久夜色撩人精品| 欧美电影第一页| 精品久久久久人成| 久久精品国产96久久久香蕉| 日韩资源在线观看| 欧美激情精品久久久久久| 琪琪亚洲精品午夜在线| 国产成人精品在线视频| www.久久草.com| 欧美激情一区二区久久久| 国产精品免费一区| 精品视频久久久久久久| 亚洲色图五月天| 亚洲国产黄色片| 在线成人一区二区| 成人国产精品一区| 国产精自产拍久久久久久蜜| 国模私拍一区二区三区| 欧美日韩在线观看视频| 91精品综合视频| 伊人伊成久久人综合网小说| 精品国产乱码久久久久久虫虫漫画| 久久免费国产视频| 国产成人拍精品视频午夜网站| 日韩大胆人体377p| 国产精品夜色7777狼人| 午夜精品久久17c| 久久成人这里只有精品| 伦伦影院午夜日韩欧美限制| 97免费在线视频| 91免费国产网站| 国产精品99久久久久久人| 欧美小视频在线观看| 亚洲国产欧美日韩精品| 精品视频在线播放| 一本色道久久88综合日韩精品| 最近2019中文免费高清视频观看www99| 欧美另类极品videosbestfree| 色婷婷**av毛片一区| 欧美成人三级视频网站| 久久精品在线视频| 免费99精品国产自在在线| 欧美日韩国产精品一区| 中文字幕亚洲无线码a| 国产精品一区二区久久| 欧美激情一级欧美精品| 91网站免费观看| 亚洲石原莉奈一区二区在线观看| 精品欧美国产一区二区三区| 亚洲第一在线视频| 成人激情春色网| 欧美日韩国产中文精品字幕自在自线| 欧美在线一级va免费观看| 国产精品入口免费视频一| 国产精品极品尤物在线观看| 欧洲成人午夜免费大片| 久久99亚洲精品| 欧美性猛交xxxx黑人| 亚洲一区二区中文字幕| 国语自产精品视频在线看抢先版图片| 国产日本欧美一区二区三区在线| 亚洲欧美中文另类| 国产性色av一区二区| 亚洲视频欧洲视频| 中文字幕在线成人| 午夜精品久久久99热福利| 日韩在线视频免费观看| 国产精自产拍久久久久久蜜| 亚洲国产精品久久久久秋霞蜜臀| 久久久久久久久爱| 亚洲欧美在线播放| 人体精品一二三区| 国产精品第2页| 欧美精品999| 欧美国产在线电影| 精品久久久久久久久中文字幕| 91在线网站视频| 欧美韩国理论所午夜片917电影| www.欧美精品一二三区| 国产成人精品网站| 91精品在线观| 中文字幕日韩欧美| 亚洲电影成人av99爱色| 国产精品毛片a∨一区二区三区|国| 亚洲成人av片在线观看| 国产精品久久色| 国产精品69久久| 国产精品一久久香蕉国产线看观看| 亚洲嫩模很污视频| 欧美裸体视频网站| 91在线免费看网站| 精品高清美女精品国产区| 精品国产乱码久久久久久天美| 国产一区二区三区在线播放免费观看| 韩剧1988在线观看免费完整版| 精品国产乱码久久久久久天美| 国内精品免费午夜毛片| 久久视频在线播放| 懂色aⅴ精品一区二区三区蜜月| 久久免费视频网| 91在线网站视频| 爱福利视频一区| 性欧美xxxx视频在线观看|