検索

PHP 乱数 C 拡張乱数

May 07, 2016 pm 02:34 PM
php乱数

この記事では、php乱数とc拡張乱数について紹介します。一定の参考値があるので、困っている友達が参考になれば幸いです。

PHP 乱数 C 拡張乱数

固定長のランダム文字列が使用されるためです。

最初は 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);

PHP 乱数 C 拡張乱数

180000 個のランダムな文字列を生成します。画像は、基本的に繰り返しがあることがわかります。しかし、それは理想でもあります。

c 言語のスキルを向上させたかったので、ランダムに生成された文字列を c で書き直しました。

乱数関数 srand() と rand() が使用されます。

しかし、1 ~ 2 時間苦労しても、乱数に関する問題がまだ残ります。同時アクセス時はほぼ同時の時刻となる場合があるため、srandで与えられるシード時刻は同一とみなしてよい。これにより、生成される乱数は同じになります。結果として得られるランダムな文字列は同じです。ほぼすべて同じ、ランダムな文字列をループアウトします。

後で、ukey のことを思いつきました。この拡張機能は一意の id を実装できます。そうすると、アクセスするたびに一意の id が生成されます。この id をシード時間として使用できますか?答えは「はい」です。

PHP 乱数 C 拡張乱数

上の図は生成されたランダムな文字列で、長さはカスタマイズできます。数値のみの文字列を出力することも可能です。 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('%ld',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] = '1' + rand() % 5;  
				break;  
			case 1:  
				string[i] = '2' + rand() % 7;  
				break;  
			case 2:  
				string[i] = '0' + rand() % 10;  
				break;  
			default:  
				string[i] = '9';  
				break;  
		} 
		
		
         
    }  
    string[length - 1] = '\0';  
    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('%ld',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] = 'A' + rand() % 26;  
				break;  
			case 1:  
				string[i] = 'a' + rand() % 26;  
				break;  
			case 2:  
				string[i] = '0' + rand() % 10;  
				break;  
			default:  
				string[i] = 'x';  
				break;  
		} 
		
		
         
    }  
    string[length - 1] = '\0';  
    RETURN_STRINGL(string,length,0);
}

PHP 乱数 C 拡張乱数

上の図は、php が 18w のランダム文字列を生成するのにかかる時間です。

PHP 乱数 C 拡張乱数

上の図は18w を生成するための c 拡張機能 ランダムな文字列の生成にかかる時間

使用されるサーバーは、1g メモリとデュアル コアを備えた alibaba cloud サーバーです。

上記のコードを ukey に追加する限り、ランダムな文字列とランダムな長さのデジタル文字列を生成できます。

ukey のアドレス http://www.oschina.net/p/ukey

推奨学習: 「php ビデオ チュートリアル

声明
この記事はCSDNで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。
PHPセッションファイルはデフォルトで保存されていますか?PHPセッションファイルはデフォルトで保存されていますか?May 01, 2025 am 12:15 AM

phpsessionFilesToredInthededirectoryspecifiedBysession.save_path、通常/tmponunix-likesystemsorc:\ windows \ temponwindows.tocustomizethis:1)uesession_save_path()tosetaCustomdirectory、ensuringit'swritadistradistradistradistradistra

PHPセッションからデータをどのように取得しますか?PHPセッションからデータをどのように取得しますか?May 01, 2025 am 12:11 AM

toretrievedatafrompsession、Startthessession withsession_start()andAccessvariablesshe $ _SessionArray.forexample:1)Startthessession:session_start()

セッションを使用してショッピングカートを実装するにはどうすればよいですか?セッションを使用してショッピングカートを実装するにはどうすればよいですか?May 01, 2025 am 12:10 AM

セッションを使用して効率的なショッピングカートシステムを構築する手順には、次のものがあります。1)セッションの定義と機能を理解します。セッションは、リクエスト全体でユーザーのステータスを維持するために使用されるサーバー側のストレージメカニズムです。 2)ショッピングカートに製品を追加するなど、基本的なセッション管理を実装します。 3)製品の量管理と削除をサポートし、高度な使用状況に拡大します。 4)セッションデータを持続し、安全なセッション識別子を使用することにより、パフォーマンスとセキュリティを最適化します。

PHPでインターフェイスをどのように作成して使用しますか?PHPでインターフェイスをどのように作成して使用しますか?Apr 30, 2025 pm 03:40 PM

この記事では、PHPでインターフェイスを作成、実装、および使用する方法について説明し、コード組織と保守性の利点に焦点を当てています。

crypt()とpassword_hash()の違いは何ですか?crypt()とpassword_hash()の違いは何ですか?Apr 30, 2025 pm 03:39 PM

この記事では、PHPのCrypt()とpassword_hash()の違いについて、パスワードハッシュの違いについて説明し、最新のWebアプリケーションの実装、セキュリティ、および適合性に焦点を当てています。

PHPのクロスサイトスクリプト(XSS)をどのように防ぐことができますか?PHPのクロスサイトスクリプト(XSS)をどのように防ぐことができますか?Apr 30, 2025 pm 03:38 PM

記事では、入力検証、出力エンコード、およびOWASP ESAPIやHTML浄化器などのツールを使用して、PHPのクロスサイトスクリプト(XSS)を防止します。

PHPの自動装置は何ですか?PHPの自動装置は何ですか?Apr 30, 2025 pm 03:37 PM

PHPでのオートローディングは、必要に応じてクラスファイルを自動的にロードし、メモリの使用を削減し、コード組織を強化することでパフォーマンスを向上させます。ベストプラクティスには、PSR-4の使用とコードを効果的に整理することが含まれます。

PHPストリームとは何ですか?PHPストリームとは何ですか?Apr 30, 2025 pm 03:36 PM

PHPストリームは、一貫したAPIを介したファイル、ネットワークソケット、圧縮形式などのリソースの処理を統合し、複雑さを抽象化し、コードの柔軟性と効率を高めます。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境