JS 시프트 연산자의 사용법은 숫자에 대한 변위 연산을 수행하는 것입니다. 시프트 연산자에는 왼쪽 시프트, 오른쪽 시프트 및 부호 없는 오른쪽 시프트의 세 가지 유형이 있습니다. 이들은 숫자에 대한 변위 연산을 수행하고 숫자의 이진 표현을 이동하는 데 사용할 수 있습니다. 또는 지정된 자릿수만큼 오른쪽으로 이동하고 결과를 반환합니다. 시프트 연산자는 계산 최적화 및 비트 마스크 작업과 같은 일부 특정 시나리오에서 특정 용도로 사용되지만 일반적으로 시프트 연산자는 거의 사용되지 않습니다.
JavaScript의 시프트 연산자는 숫자에 대한 비트 시프트 연산을 수행하는 데 사용됩니다. 시프트 연산자에는 왼쪽 시프트(<<), 오른쪽 시프트(>>) 및 부호 없는 오른쪽 시프트(>>>)가 포함됩니다. 이러한 연산자는 숫자의 이진 표현을 지정된 자릿수만큼 왼쪽이나 오른쪽으로 이동하고 결과를 반환합니다.
1. 왼쪽 시프트 연산자(<<):
왼쪽 시프트 연산자는 숫자의 이진 표현을 지정된 자릿수만큼 왼쪽으로 이동합니다. 이동 후 오른쪽의 비어 있는 비트는 0으로 채워집니다. 왼쪽 시프트 연산자의 구문은 다음과 같습니다:
result = number << count;
여기서 number는 시프트할 숫자, count는 이동할 자릿수, result는 시프트 후의 결과입니다.
예:
var number = 5; // 二进制表示为 00000101 var count = 2; // 向左移动2位 var result = number << count; // 结果为 20,二进制表示为 00010100
2. 오른쪽 시프트 연산자(>>):
오른쪽 시프트 연산자는 숫자의 이진 표현을 지정된 자릿수만큼 오른쪽으로 이동합니다. 시프트 후 왼쪽의 비어 있는 비트는 숫자의 부호 비트(양수의 경우 0, 음수의 경우 1)로 채워집니다. 오른쪽 시프트 연산자의 구문은 다음과 같습니다.
result = number >> count;
여기서 number는 이동할 숫자, count는 이동할 자릿수, result는 시프트 후의 결과입니다.
예:
var number = 20; // 二进制表示为 00010100 var count = 2; // 向右移动2位 var result = number >> count; // 结果为 5,二进制表示为 00000101
3. 부호 없는 오른쪽 시프트 연산자(>>>):
부호 없는 오른쪽 시프트 연산자는 숫자의 이진 표현을 지정된 자릿수만큼 오른쪽으로 이동합니다. 시프트 후에는 왼쪽의 비어 있는 비트가 0으로 채워집니다. 부호 없는 오른쪽 시프트 연산자의 구문은 다음과 같습니다:
result = number >>> count;
여기서 number는 이동할 숫자, count는 이동할 자릿수, result는 시프트의 결과입니다.
예:
var number = -5; // 二进制表示为 11111111111111111111111111111011 var count = 2; // 向右移动2位 var result = number >>> count; // 结果为 1073741822,二进制表示为 00111111111111111111111111111110
JavaScript에서 시프트 연산자의 적용 시나리오는 상대적으로 제한되어 있지만 다음과 같은 특정한 특정 상황에서는 여전히 특정 용도로 사용됩니다.
1 최적화 계산: 시프트 연산을 대체에 사용할 수 있습니다. 교대 연산이 곱셈과 나눗셈 연산보다 더 효율적이기 때문입니다. 다수의 곱셈 또는 나눗셈 연산이 필요한 일부 시나리오에서는 최적화를 위해 시프트 연산자 사용을 고려할 수 있습니다.
2. 비트 마스크 연산: 시프트 연산을 사용하여 비트 마스크를 생성하고 연산할 수 있습니다. 비트 마스킹은 바이너리 비트를 표시하고 추출하는 기술로, 비트 조작과 관련된 문제를 처리하는 데 자주 사용됩니다.
shift 연산자는 32비트 부호 있는 정수(JavaScript의 숫자 유형)를 처리하는 데만 사용할 수 있다는 점에 유의하세요. 연산 중인 숫자가 32비트 범위를 초과하는 경우 시프트 연산자의 동작은 정의되지 않습니다. 게다가 시프트 연산자는 원래 숫자의 유형을 변경하지 않으며 결과는 여전히 32비트 부호 있는 정수입니다.
요약하면 JavaScript의 시프트 연산자에는 왼쪽 시프트(<<), 오른쪽 시프트(>>) 및 부호 없는 오른쪽 시프트(>>>)가 포함됩니다. 숫자에 대한 비트 이동 연산을 수행하고 숫자의 이진 표현을 지정된 비트 수만큼 왼쪽이나 오른쪽으로 이동하고 결과를 반환하는 데 사용할 수 있습니다. 시프트 연산자는 최적화 계산 및 비트 마스크 작업과 같은 일부 특정 시나리오에서 특정 용도로 사용됩니다. 그러나 일반적으로 시프트 연산자를 거의 사용하지 않습니다.
위 내용은 js 시프트 연산자 사용법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!