파스칼-연산자
연산자는 컴파일러에게 특정 수학적 또는 논리적 조작을 수행하도록 지시하는 기호입니다. Pascal은 다음 유형의 연산자를 허용합니다.
- 산술 연산자
- 관계 연산자
- 부울 연산자
- 비트 연산자
- 집합 연산자
- 문자열 연산자
산술, 관계형, 부울 및 비트 연산자를 하나씩 살펴 보겠습니다. 집합 연산자와 문자열 연산은 나중에 논의 할 것입니다.
산술 연산자
다음 표는 Pascal에서 지원하는 모든 산술 연산자를 보여줍니다. 변수 가정A 10 개와 가변 B 20 개를 보유하면-
예시보기
운영자 | 기술 | 예 |
---|---|---|
+ | 두 개의 피연산자를 더합니다. | A + B는 30을 줄 것입니다 |
- | 첫 번째에서 두 번째 피연산자를 뺍니다. | A-B는 -10을 줄 것입니다. |
* | 두 피연산자를 곱합니다. | A * B는 200을 줄 것입니다 |
/ | 분자를 분모로 나눕니다. | B / A는 2를 줄 것입니다 |
% | 계수 연산자 및 정수 나누기 후의 나머지 | B % A는 0을 제공합니다. |
관계 연산자
다음 표는 Pascal에서 지원하는 모든 관계 연산자를 보여줍니다. 변수 가정A 10 개와 가변 B 20 개를 보유하면-
예시보기
운영자 | 기술 | 예 |
---|---|---|
= | 두 피연산자의 값이 같은지 확인하고, 그렇다면 조건이 참이됩니다. | (A = B)는 사실이 아닙니다. |
<> | 두 피연산자의 값이 같은지 확인하고, 값이 같지 않으면 조건이 참이됩니다. | (A <> B)는 사실입니다. |
> | 왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 큰지 확인하고, 그렇다면 조건이 참이됩니다. | (A> B)는 사실이 아닙니다. |
< | 왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 작은 지 확인하고, 그렇다면 조건이 참이됩니다. | (A <B)는 사실입니다. |
> = | 왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 크거나 같은지 확인하고, 그렇다면 조건이 참이됩니다. | (A> = B)는 사실이 아닙니다. |
<= | 왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 작거나 같은지 확인하고, 그렇다면 조건이 참이됩니다. | (A <= B)는 참입니다. |
부울 연산자
다음 표는 파스칼 언어에서 지원하는 모든 부울 연산자를 보여줍니다. 이러한 모든 연산자는 부울 피연산자에서 작동하고 부울 결과를 생성합니다. 변수 가정A 진실하고 가변적이다 B 거짓을 유지하면-
예시보기
운영자 | 기술 | 예 |
---|---|---|
과 | 부울 AND 연산자라고합니다. 두 피연산자가 모두 참이면 조건이 참이됩니다. | (A와 B)는 거짓입니다. |
그리고 | AND 연산자와 유사하지만 컴파일러가 논리식을 평가하는 순서를 보장합니다. 왼쪽에서 오른쪽으로 및 오른쪽 피연산자는 필요한 경우에만 평가됩니다. | (A와 B)는 거짓입니다. |
또는 | 부울 OR 연산자라고합니다. 두 피연산자 중 하나가 참이면 조건이 참이됩니다. | (A 또는 B)가 참입니다. |
그렇지 않으면 | 부울 OR과 유사하지만 컴파일러가 논리식을 평가하는 순서를 보장합니다. 왼쪽에서 오른쪽으로 및 오른쪽 피연산자는 필요한 경우에만 평가됩니다. | (A 또는 B)가 참입니다. |
아니 | 부울 NOT 연산자라고합니다. 피연산자의 논리적 상태를 반전하는 데 사용됩니다. 조건이 참이면 논리 NOT 연산자가이를 거짓으로 만듭니다. | (A와 B)는 사실이 아닙니다. |
비트 연산자
비트 연산자는 비트에 대해 작업하고 비트 단위 연산을 수행합니다. 이러한 모든 연산자는 정수 피연산자에서 작동하며 정수 결과를 생성합니다. 비트 및 (&), 비트 또는 (|) 및 비트가 아닌 (~)에 대한 진리표는 다음과 같습니다.
피 | 큐 | p & q | p | 큐 | ~ p | ~ q |
---|---|---|---|---|---|
0 | 0 | 0 | 0 | 1 | 1 |
0 | 1 | 0 | 1 | 1 | 0 |
1 | 1 | 1 | 1 | 0 | 0 |
1 | 0 | 0 | 1 | 0 | 1 |
A = 60이라고 가정합니다. 그리고 B = 13; 이제 바이너리 형식으로 다음과 같습니다.
A = 0011 1100
B = 0000 1101
-----------------
A & B = 0000 1100
A ^ B = 0011 0001
~ A = 1100 0011
Pascal에서 지원하는 Bitwise 연산자는 다음 표에 나열되어 있습니다. 변수 A가 60이고 변수 B가 13이라고 가정하면 다음과 같습니다.
예시보기
운영자 | 기술 | 예 |
---|---|---|
& | 이진 AND 연산자는 두 피연산자에 모두있는 경우 결과에 비트를 복사합니다. | (A & B)는 0000 1100 인 12를 줄 것입니다. |
| | 이진 OR 연산자는 피연산자 중 하나에 있으면 비트를 복사합니다. | (A | B)는 61, 즉 0011 1101을 제공합니다. |
! | 이진 OR 연산자는 피연산자 중 하나에 있으면 비트를 복사합니다. 그것과 동일 | 운영자. | (A! B)는 61, 즉 0011 1101 |
~ | Binary Ones Complement Operator는 단항이며 비트를 '뒤집는'효과가 있습니다. | (~ A)는 부호가있는 이진수로 인해 2의 보수 형식으로 1100 0011 인 -61을 제공합니다. |
<< | 이진 왼쪽 시프트 연산자. 왼쪽 피연산자 값은 오른쪽 피연산자에 지정된 비트 수만큼 왼쪽으로 이동합니다. | << 2는 240, 즉 1111 0000을 제공합니다. |
>> | 이진 오른쪽 시프트 연산자. 왼쪽 피연산자 값은 오른쪽 피연산자에 지정된 비트 수만큼 오른쪽으로 이동합니다. | A >> 2는 15, 즉 0000 1111을 제공합니다. |
Pascal의 다른 구현은 비트 연산자가 다릅니다. 그러나 여기서 사용한 컴파일러 인 Free Pascal은 다음과 같은 비트 연산자를 지원합니다.
연산자 | 운영 |
---|---|
아니 | 비트 NOT |
과 | 비트 AND |
또는 | 비트 OR |
xor | 비트 배타적 OR |
shl | 왼쪽으로 비트 시프트 |
shr | 비트 오른쪽으로 시프트 |
<< | 왼쪽으로 비트 시프트 |
>> | 비트 오른쪽으로 시프트 |
파스칼의 연산자 우선 순위
연산자 우선 순위는 식에서 용어 그룹화를 결정합니다. 이는식이 평가되는 방식에 영향을줍니다. 특정 연산자는 다른 연산자보다 우선 순위가 높습니다. 예를 들어 곱셈 연산자는 더하기 연산자보다 우선 순위가 높습니다.
예를 들어 x = 7 + 3 * 2; 여기서 x는 연산자 *가 +보다 우선 순위가 높기 때문에 20이 아닌 13이 할당됩니다. 따라서 먼저 3 * 2를 곱한 다음 7에 더합니다.
여기에서 우선 순위가 가장 높은 연산자는 테이블 맨 위에 표시되고 가장 낮은 연산자는 맨 아래에 표시됩니다. 식 내에서 우선 순위가 높은 연산자가 먼저 평가됩니다.
예시보기
운영자 | 상위 |
---|---|
~, 아니, | 제일 높은 |
*, /, div, mod 및 & | |
|,!, +,-또는, | |
=, <>, <, <=,>,> =, in | |
아니면 | 최저 |