ホームページ バックエンド開発 PHPチュートリアル PHPシフト操作・シフト操作学習メモ_PHPチュートリアル

PHPシフト操作・シフト操作学習メモ_PHPチュートリアル

Jul 13, 2016 am 10:50 AM
php について 勉強 操作する はい 使用 ノート 手術

以下は、PHP のシフト操作とシフト操作に関する一般的に使用される学習メモです。この記事がすべての学生にとって有益であることを願っています。

ビット演算アプリケーションのヒント

ビットをクリアするには、AND を使用します。特定の位置が使用可能であるか、または

否定して交換したい場合は、XORを使用すると簡単です

シフト操作

ポイント1 どちらも二項演算子で、演算部品は両方とも整数で、結果も整数になります。

2「<<」 左シフト:右側の空いているビットを0で埋めると、左側のビットが単語の先頭から絞り出され、その値は2倍に相当します。

3 ">>"右シフト: 右側のビットが絞り出されます。左から繰り出された空きビットは、正の数の場合は 0 で埋められます。負の数の場合は、使用するコンピュータ システムに応じて 0 または 1 で埋められます。

4 ">>>" 演算子では、右側のビットが絞り出され、左側にシフトされた空いた部分はすべて 0 で埋められます。

ビット演算子の適用 (ソースオペランドのマスクマスク)

(1) ビット単位の AND-- &

1 特定のビットをクリアします (マスク内の特定のビットは 0、他のビットは 1、s=s&mask)

2 特定の数値内の指定されたビットを取得します (マスク内の特定の位置は 1、他のビットは 0、s=s&mask)

(2) ビット単位の OR-- |

ソース オペランドの特定のビットを 1 に設定し、他のビットは変更しないままにするためによく使用されます。 (マスク内の特定の位置は 1、他のビットは 0 s=s|mask)

(3) ビット XOR-- ^

1 は特定のビットの値を反転します (マスク内の特定の位置は 1、他のビットは 0 s=s^mask)

2 3番目の変数を導入せず、2つの変数の値を交換します(a=a1,b=b1と仮定します)

運用後の目標運用状況

a=a1^b1 a=a^b a=a1^b1,b=b1

b=a1^b1^b1 b=a^b a=a1^b1,b=a1

a=b1^a1^a1 a=a^b a=b1,b=a1

2の補数の算術公式:

-x = ~x + 1 = ~(x-1)

~x = -x-1

-(~x) = x+1

~(-x) = x-1

x+y = x - ~y - 1 = (x|y)+(x&y)

x-y = x + ~y + 1 = (x|~y)-(~x&y)

x^y = (x|y)-(x&y)

x|y = (x&~y)+y

x&y = (~x|y)-~x

x==y: ~(x-y|y-x)

x!=y: x-y|y-x

x

x

x< y: (~x&y)|((~x|y)&(x-y))//符号なし x,y 比較

x<=y: (~x|y)&((x^y)|~(y-x))//符号なし x,y 比較

応用例

(1) int型変数aが奇数か偶数かを判定します

a&1 = 0 偶数

a&1 = 1 の奇数

(2) int型変数aのk番目のビット(k=0,1,2...sizeof(int))、つまりa>>k&1を取り出します

(3) int型変数aのkビット目を0、つまりa=a&~(1

(4) int型変数aのk番目の位置を1、つまりa=a|(1

(5) int型変数を左にk回循環シフト、つまりa=a16-k(sizeof(int)=16と仮定)

(6) int型変数aをk回右に巡回シフトする、つまりa=a>>k|a

(7)整数の平均

2 つの整数 x と y について、(x+y)/2 を使用して平均を計算すると、x+y が INT_MAX より大きい可能性があるため、オーバーフローが発生しますが、それらの平均は絶対にオーバーフローしないことがわかっています。次のアルゴリズム:

int Average(int x, int y) //X、Yの平均を返します

{

return (x&y)+((x^y)>>1);

}

(8) 整数が 2 のべき乗であるかどうかを判断します。数値 x >= 0 の場合、それが 2 のべき乗であるかどうかを判断します

ブール値 power2(int x)

{

リターン ((x&(x-1))==0)&&(x!=0);

}

(9) 温度なしで 2 つの整数を交換します

void swap(int x , int y)

{

x ^= y;

y ^= x;

x ^= y;

}

(10)絶対値を計算する

int abs(int x)

{

いや;

y = x > 31 ;

return (x^y)-y ; //または: (x+y)^y

}

(11) モジュロ演算をビット演算に変換(オーバーフローなし)

% (2^n) は & (2^n - 1) と同等です

(12) 乗算演算はビット演算に変換されます(オーバーフローなし)

a * (2^n) は a

(13) 除算演算をビット演算に変換します(オーバーフローなし)

a / (2^n) は a>> n と同等です

(14) a % 2 は a & 1 と同等です

(15) if (x == a) x= b;

else x= a;

x= a ^ b ^ x;

と同等

(16) xの反対は(~x+1)と表されます

最後にバイナリシフト演算に関する情報を追加します

PHP は主にテキスト演算を目的として設計されており、実際には数学演算には適しておらず、効率も高くありません。しかし、このプロジェクトではバイナリ ディスプレイスメント演算を使用する必要があるため、PHP でいくつかの問題が発生しました。

PHP には 32 ビットの符号付き整数しかなく、64 ビットの長整数や符号なし整数は存在しないためです。整数型の範囲は -231-1 ~ 231 です。この範囲外の値は浮動小数点数として解釈されます。したがって、0xFFFFFFFF を直接出力すると、4294967295 と 232 が表示されます:

>>0xFFFFFFFF
4294967295
>> タイプを取得(0xFFFFFFFF)
「ダブル」

32 ビットの符号付き整数では、0xFFFFFFFF は -1 を表す必要があります:

>> (int)0xFFFFFFFFFF
-1

PHP は浮動小数点数の 2 進シフト演算をサポートしていません。これを実行する場合は、最初に整数に変換され、最終結果も整数として返されます。

>> 1 -2147483648
>> 1 1073741824
>> 1 1
>>>>> 1
; -1

同時に、PHP の右シフト演算は上位ビットの符号ビットを埋めますが、PHP は 0 を強制的に埋めるための Java のような >>> を提供しません。

>> 1 << 1
>>>>> 1

; -1

>>>>> 2
; -1
>>>>>3
; -1
>>>>>31
-1


この問題を解決するには、BCMath 数学関数ライブラリを使用して、文字列や GMP/BigInt 拡張などで表される整数を直接処理することを検討しました。しかし、文字列を使用しているので、文字列をより徹底的に扱い、数値を 32 個のバイナリ文字列に変換し、手動で 0 を埋め、最後にそれらを元に戻すことができると思います。

もっと良い方法があるかわからないので教えてください。


コードは次のとおりです:

コードを直接ダウンロードします:shift.php

(さらに、コードは実際には任意のバイナリ ビット シフト演算に拡張できますが、ここでは実行しませんでした)

PHP

コードは次のとおりです コードをコピー
/**
* 符号なし 32 ビット右シフト
* @parammixed $x 演算対象の数値。文字列の場合は 10 進数形式でなければなりません
* @param string $bits 右シフト数値
* @return 混合結果、整数の範囲を超える場合は浮動小数点数を返します
​*/
関数 shr32($x, $bits){
//変位が範囲を超える 2 つの状況
If($bits $x を返します;
}
If($bits >= 32){
0 を返す;
}
//2進数を表す文字列に変換します
$bin = decbin($x);
$l = strlen($bin);
//文字列の長さが超える場合は下位32ビットが切り取られ、長さが足りない場合は上位ビットが0~32ビットで埋められます
If($l > 32){
$bin = substr($bin, $l - 32, 32);
}elseif($l $bin = str_pad($bin, 32, '0', STR_PAD_LEFT);
}
// 移動する桁数を取得し、左側に 0
を埋め込みます 戻り値bindec(str_pad(substr($bin, 0, 32 - $bits), 32, '0', STR_PAD_LEFT));
}
/**
* 符号なし 32 ビット左シフト
* @parammixed $x 演算対象の数値。文字列の場合は 10 進数形式でなければなりません
* @param string $bits 左シフト数値
* @return 混合結果、整数の範囲を超える場合は浮動小数点数を返します
​*/
関数 shl32 ($x, $bits){
//変位が範囲を超える 2 つの状況
If($bits $x を返します。 }
If($bits >= 32){
0 を返します。 }
//2進数を表す文字列に変換します
$bin = decbin($x);
$l = strlen($bin);
//文字列の長さが超える場合は下位32ビットが切り取られ、長さが足りない場合は上位ビットが0~32ビットで埋められます
If($l > 32){
$bin = substr($bin, $l - 32, 32);
}elseif($l $bin = str_pad($bin, 32, '0', STR_PAD_LEFT);
}
//移動する桁数を取得し、右側に0
を入力します 戻り値bindec(str_pad(substr($bin, $bits), 32, '0', STR_PAD_RIGHT));
}

http://www.bkjia.com/PHPjc/632618.html

tru​​ehttp://www.bkjia.com/PHPjc/632618.html技術記事以下は、PHP のシフト操作とシフト操作についてよく使用される学習メモです。この記事がすべての学生にとって有益であることを願っています。 ビット演算を適用するためのヒント。ビットをクリアするには、特定の位置が使用可能であるか...
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホット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衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Dec 24, 2024 pm 04:42 PM

PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

CakePHP の日付と時刻 CakePHP の日付と時刻 Sep 10, 2024 pm 05:27 PM

Cakephp4 で日付と時刻を操作するには、利用可能な FrozenTime クラスを利用します。

CakePHP について話し合う CakePHP について話し合う Sep 10, 2024 pm 05:28 PM

CakePHP は、PHP 用のオープンソース フレームワークです。これは、アプリケーションの開発、展開、保守をより簡単にすることを目的としています。 CakePHP は、強力かつ理解しやすい MVC のようなアーキテクチャに基づいています。モデル、ビュー、コントローラー

CakePHP ファイルのアップロード CakePHP ファイルのアップロード Sep 10, 2024 pm 05:27 PM

ファイルのアップロードを行うには、フォーム ヘルパーを使用します。ここではファイルアップロードの例を示します。

CakePHP バリデータの作成 CakePHP バリデータの作成 Sep 10, 2024 pm 05:26 PM

Validator は、コントローラーに次の 2 行を追加することで作成できます。

PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 Dec 20, 2024 am 11:31 AM

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

CakePHP クイックガイド CakePHP クイックガイド Sep 10, 2024 pm 05:27 PM

CakePHP はオープンソースの MVC フレームワークです。これにより、アプリケーションの開発、展開、保守がはるかに簡単になります。 CakePHP には、最も一般的なタスクの過負荷を軽減するためのライブラリが多数あります。

PHPでHTML/XMLを解析および処理するにはどうすればよいですか? PHPでHTML/XMLを解析および処理するにはどうすればよいですか? Feb 07, 2025 am 11:57 AM

このチュートリアルでは、PHPを使用してXMLドキュメントを効率的に処理する方法を示しています。 XML(拡張可能なマークアップ言語)は、人間の読みやすさとマシン解析の両方に合わせて設計された多用途のテキストベースのマークアップ言語です。一般的にデータストレージに使用されます

See all articles