cari
Rumahphp教程PHP开发PHP 随机数 C扩展随机数

PHP 随机数 C扩展随机数

Nov 23, 2016 pm 02:34 PM
php

由于要用到固定长度的随机字符串。

首先是一段PHP代码

        $str_md5=md5(uniqid());
	$rand = mt_rand(1, 28);
	$str1=substr($str_md5,$rand,6);
	$rand = mt_rand(1, 28);
	$str2=substr($str_md5,$rand,6);
	$rand = mt_rand(1, 28);
	$str3=substr($str_md5,$rand,6);
	$code=substr($str1.$str2.$str3,0,8);

154420_BzEY_1450051.png

生成180000个随机字符串,图中是按照重复数量倒序排列,可以看到基本都有重复的。不过也是比较理想的。

由于想提升一下自己的C语言能力,所以用C重新写了一下随机生成字符串。

其中用到了随机数函数srand(),rand();

不过折腾一两个小时,随机数还是有问题。并发访问时时间可能几乎为同时,那么srand给的种子时间可以视为相同的。这样就导致了,产生的随机数也是一样的。从而产生的随机字符串也是一样的。循环输出随机字符串,几乎都是一模一样的。

后来想到了ukey,这个扩展可以实现唯一的ID,那么访问都产生唯一的ID,是不是可以将这个ID作为种子时间。答案是肯定的。

p360043701.jpg

上图是产生的随机字符串,可以自定义长度。也同样可以输出只有数字的字符串。相较PHP所产生的随机字符串重复率更低且速度更快。

PHP_FUNCTION(get_random__num_str)
{
     int length=8;
	 
     if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "l", &length) == FAILURE) 
     {
		length=8;
		
     }
	 length++;
    int flag, i;  
    char* string;  	__uint64_t timestamp = realtime();
    __uint64_t retval;
    int len;
    char buf[128];

    if (timestamp == 0ULL) {
        RETURN_FALSE;
    }

    spin_lock(lock, pid);

    if (context->last_timestamp == timestamp) {
        context->sequence = (context->sequence + 1) & context->sequence_mask;
        if (context->sequence == 0) {
            timestamp = skip_next_millis();
        }

    } else {
        context->sequence = 0; /* Back to zero */    }

    context->last_timestamp = timestamp;

    retval = ((timestamp - context->twepoch) << context->timestamp_left_shift)
           | (context->datacenter_id << context->datacenter_id_shift)
           | (worker_id << context->worker_id_shift)
           | context->sequence;

    spin_unlock(lock, pid);	//printf(&#39;%ld&#39;,retval);
	srand((unsigned)retval);
    //srand((unsigned) time(NULL ));      if ((string = (char*) emalloc(length)) == NULL )  
    {  
        //myLog("Malloc failed!flag:14\n");          RETURN_NULL() ;  
    }  
  
    for (i = 0; i < length - 1; i++)  
    {  
        flag = rand() % 3;  		
		switch (flag)  
		{  			case 0:  				string[i] = &#39;1&#39; + rand() % 5;  				break;  			case 1:  				string[i] = &#39;2&#39; + rand() % 7;  				break;  			case 2:  				string[i] = &#39;0&#39; + rand() % 10;  				break;  			default:  				string[i] = &#39;9&#39;;  				break;  
		} 
		
		
         
    }  
    string[length - 1] = &#39;\0&#39;;  
    RETURN_STRINGL(string,length,0);
}
 PHP_FUNCTION(get_random_str)
{
     int length=8;
	 
     if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "l", &length) == FAILURE) 
     {
		length=8;
		
     }
	 length++;
    int flag, i;  
    char* string;  	__uint64_t timestamp = realtime();
    __uint64_t retval;
    int len;
    char buf[128];

    if (timestamp == 0ULL) {
        RETURN_FALSE;
    }

    spin_lock(lock, pid);

    if (context->last_timestamp == timestamp) {
        context->sequence = (context->sequence + 1) & context->sequence_mask;
        if (context->sequence == 0) {
            timestamp = skip_next_millis();
        }

    } else {
        context->sequence = 0; /* Back to zero */    }

    context->last_timestamp = timestamp;

    retval = ((timestamp - context->twepoch) << context->timestamp_left_shift)
           | (context->datacenter_id << context->datacenter_id_shift)
           | (worker_id << context->worker_id_shift)
           | context->sequence;

    spin_unlock(lock, pid);	//printf(&#39;%ld&#39;,retval);
	srand((unsigned)retval);
    //srand((unsigned) time(NULL ));      if ((string = (char*) emalloc(length)) == NULL )  
    {  
        //myLog("Malloc failed!flag:14\n");          RETURN_NULL() ;  
    }  
  
    for (i = 0; i < length - 1; i++)  
    {  
        flag = rand() % 3;  		
		switch (flag)  
		{  			case 0:  				string[i] = &#39;A&#39; + rand() % 26;  				break;  			case 1:  				string[i] = &#39;a&#39; + rand() % 26;  				break;  			case 2:  				string[i] = &#39;0&#39; + rand() % 10;  				break;  			default:  				string[i] = &#39;x&#39;;  				break;  
		} 
		
		
         
    }  
    string[length - 1] = &#39;\0&#39;;  
    RETURN_STRINGL(string,length,0);
}

p360043701.jpg

上图是PHP生成18W随机字符串所用的时间

p360043701.jpg

上图是C扩展生成18W随机字符串所用的时间


所用的服务器都是1G内存 双核的阿里云服务器。

只要在ukey中加入上如代码就可以生产随机字符串和随机长度数字字符串

ukey的地址http://www.oschina.net/p/ukey


Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

EditPlus versi Cina retak

EditPlus versi Cina retak

Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

VSCode Windows 64-bit Muat Turun

VSCode Windows 64-bit Muat Turun

Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

MinGW - GNU Minimalis untuk Windows

MinGW - GNU Minimalis untuk Windows

Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

SublimeText3 Linux versi baharu

SublimeText3 Linux versi baharu

SublimeText3 Linux versi terkini

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini