当前位置:  编程技术>.net/c#/asp.net

C#生成防伪码的思路及源码分享

    来源: 互联网  发布时间:2014-10-30

    本文导语:  摘 要 1. 生成多个防伪码,防伪码的长度和个数由用户指定。 2. 防伪码由"0123456789ABCDEFGHJKLMNPQRSTUVWXYZ"字符组成,生成的防伪码不可以重复,必须是唯一的。 3. 防伪码的生成要具有随机性。 4. 在以上要求达到的基础上,尽可优...

摘 要

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是一个    整型值,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 Hash = new Dictionary(); //哈希表
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 Hash = new Dictionary();      
            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();
        }
    }
}


    
 
 

您可能感兴趣的文章:

  • c#如何生成Excel(.xls和.xlsx)文件
  • C# Guid.NewGuid生成随机数的例子
  • C#生成随机字符串的实例
  • C#随机生成Unicode类型字符串
  • c#生成随机数示例分享
  • C#实现在两个数字之间生成随机数的方法
  • c# 生成随机时间的小例子
  • 生成不重复随机数列表的c#代码
  • C#生成注册码的小例子
  • C#生成MD5的函数代码
  • C#实现动态生成表格的方法
  • C#生成不重复随机数列表实例
  • C#生成设置范围内的Double类型随机数的方法
  • C#生成单页静态页简单实例
  • C#生成加密的16位随机数的代码
  • 一段C#生成随机验证码的代码
  • 基于C#生成随机数示例
  • c#生成缩略图的实现方法
  • c#生成缩略图不失真的简单示例
  • asp.net(c#) 使用Rex正则来生成字符串数组的代码
  • C#随机生成不重复字符串的两个不错方法
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 怎么通过内核源码包生成源码树?
  • PHP源码自动生成插件 PHP Source Plugin
  • 如何在HP-UX 11.11下用cc编译libxml2-2.6.23源码,生成64位的libxml2.a库
  • 纯C语言:贪心Prim算法生成树问题源码分享
  • php密码生成类(附源码)
  • php根据url自动生成缩略图(附源码)
  • linux c下利用srand和rand函数生成随机字符串
  • 用JBuilder能将java程序生成exe可执行文件吗?如何生成?
  • Linux下c基于openssl生成MD5的函数
  • 我想问一下,java生成的.class文件能不能通过某种工具生成.exe文件?
  • linux下利用(cat,strings,head,sed)命令生成随机字符串
  • 高分求jsp中动态生成图片的相关资料、生成svg格式和pdf格式的资料,不够再加分
  • php中session_id()函数详细介绍,会话id生成过程及session id长度
  • 如何使用arm-uclibc-gcc将.c文件编译生成.a,将.c文件编译生成.cgi?
  • linux c 生成随机数srand函数和rand函数介绍及代码示例
  • 如何指定用javac编译生成类的存放路径。(最好不要告诉我再生成之后再把文件流重新到出这种)
  • ORACLE中DBMS_RANDOM随机数生成包
  • QT Designer生成的代码不能生成可执行程序
  • Linux下c/c++开发之程序崩溃(Segment fault)时内核转储文件(core dump)生成设置方法
  • 需要从数据库中动态生成的页面是该在SERVLET输出生成,还是应该在JSP编码实现?
  • java生成字母数字组合的随机数示例 java生成随机数
  • 请问我用程序如何编辑Adobe Acrobat 5.0的pdf文件(生成报表)啊?或者如何才能将已生成的execl报表转换成pdf格式?
  • 请问用POI生成Excel文件时,怎么能生成边框线条等?
  • php生成短网址 仿微博短网址生成代码
  • 在JB自己生成的EJB客户端的测试代码中都会自动生成,象String url = "t3://localhost:7001";这样的,请问:
  • java随机生成字符串(字符随机生成类 生成随机字符组合)
  • 我在SRC目录下写好的源程序,我怎样能写个脚本把写好的源程序放在BIN下呢?另外我想把该程序的输出结果(生成了几个文件),生成到out目录下,


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3