C 論理演算のソースを表示
新しいページはコチラ
移動:
案内
,
検索
※このページではC言語にも存在していたという意味で記事タイトルがC ポインタになっていますが、<br /> [[C PlusPlus|C++]]でも同様です。[[C PlusPlus|C++]]だけの機能がある場合は明記します。<br /> <br /> == '''論理演算''' == 論理演算ってのは、普通の算数とは違う和と積の考え方をする分野の仕組みです。これは電子回路でつくられるON・OFFの考え方を数学的に表現しようとするためのモノだと思えばよいと思います。コンピュータも電子回路で構成されていますし、プログラムもメモリの中のON・OFFによって構成される記号の塊です。いわゆる機械語は電子回路のON・OFFによって表現されます。それが2進数であり、発展したものがニーモニック言語でありアセンブラ、16進数表記の考え方に発展し、それを構成するための高水準言語としてCやC++の言語が作られ、コンパイルやリンクの作業翻訳・解析処理によって機械語を生成しているのです。 上記のような世界観を考えるために生まれた論理演算は論理積・論理和・論理否定・論理排他和を基本的な演算として論理シフト・論理算術シフトといった特殊な操作を含めた演算があります。これによって電気信号のON・OFFの計算結果を表現することで、通常の算数の演算表現や文字表現からマルチメディア(音・音楽・音声・映像・動画・アニメ・外部機器制御)、コンピュータ自身の制御までを網羅しようとする演算手法です。 論理演算は、上記のような幅広い役割に発展することもあり、非常に幅広い学問でもあるため、このWikiの項目では、その論理演算の全てを解説することはありません。ここではプログラムで表現される論理演算の基礎的な表現だけを解説します。その応用方法については、この広大なネットの情報や専門書の解説にゆずりたいと思います。論理演算で数学を表現できるのですが、その数学の表現と論理演算には、より簡素に表現する工夫がなされていたり、論理演算の表現の限界や論理演算独自の特徴を活かすことや、コンピュータの処理速度と論理演算の回数との関係による計算の可用性(うまく利用できる性質)の限界、限界を利用した暗号の仕組みがあるので、論理演算で全てを表現できるかが、コンピュータの可能性をひろめていると考えてよいと思います。わたくしなりの解説でしたが論理演算の世界の奥深さだけは肝に銘じていただけたなら幸いです。 それでは、プログラムで使われる論理演算の基礎的な部分について、実際に記載してみたいと思います。 まずは論理値同士の演算をする論理演算子についてですが、これはBool型同士の演算とも言えるかもしれません。論理値は1(真=true)もしくは0(偽=false)で表すもので、 論理和の演算子は '''||''' です。 {| style="color:black;" class="wikitable_ronriwa" border="1" cellspacing="0" |- ! 値1 !! 値2 !! 結果 |- | 0 || 0 || 0 |- | 0 || 1 || 1 |- | 1 || 0 || 1 |- | 1 || 1 || 1 |} 値1と値2のどちらかが1(真=true)になっていたら結果は1(真=true)になります。したがって、すべてが0(偽=false)のときだけ結果が0(偽=false)になります。値1 || 値2 || 値3 のようにまとめて記述しても良いです。値1と値2の計算結果と値3の論理和を計算するように処理が実行されます。カッコをつけて値1 || (値2 || 値3)のようにすると演算順序優先度はカッコの中が優先されます。これは一般的な算数(数学)の法則と似ているので覚えやすいでしょう。 論理積の演算子は '''&&''' です。 {| class="wikitable_ronriseki" border="1" cellspacing="0" |- ! 値1 !! 値2 !! 結果 |- | 0 || 0 || 0 |- | 0 || 1 || 0 |- | 1 || 0 || 0 |- | 1 || 1 || 1 |} 値1と値2の全てが1(真=true)になっていたら結果は1(真=true)になります。したがって、いずれかが0(偽=false)のときには結果が0(偽=false)になります。 このように論理和を日本語で表現する場合に「あるいは」とか「もしくは」とか「または」という言葉を当てはめることができ、論理積は「かつ」という言葉を当てはめることが多く、「値1 または 値2」や「値1 かつ 値2」のようにも表現します。 論理否定は一つの論理値の手前に ! をとします。 {| class="wikitable_ronriseki" border="1" cellspacing="0" |- ! 値1 !! 結果 |- | 0 || 1 |- | 1 || 0 |} 値1が0(偽=false)になっていたら結果は1(真=true)になります。逆に値1が1(真=true)になっていたら結果は0(偽)になります。 このように論理否定を日本語で表現する場合「の反対」とか「の否定」とか「の逆」という言葉をあてはめることが多く「値1の否定」のようにも表現します。 上記のような論理演算をプログラムで表現する場合には以下のようなものになります。 というように記述します。 値の部分はBool型のようなもの同士が理解しやすいですが、Bool型以外の値同士でも論理演算を行うことは可能です。一般の算数(数学)における0(Zero)という値だけが0(偽=false)として扱われるので、任意の型の変数の実体が0以外のなんらかの値を保有していれば1(真=true)であることになります。この部分はプログラミング言語の処理系によって異なることが多いので混同してしまう多言語プログラマは多いかもしれませんね。
C 論理演算
に戻る。
個人用ツール
3.15.238.90
このIPアドレスのトーク
ログイン
名前空間
ページ
議論
変種
表示
閲覧
ソースを表示
履歴表示
操作
検索
案内
メインページ
コミュニティ・ポータル
最近の出来事
最近の更新
おまかせ表示
ヘルプ
ツールボックス
リンク元
関連ページの更新状況
特別ページ