Java 연산자
컴퓨터의 가장 기본적인 용도 중 하나는 수학 연산을 수행하는 것입니다. 컴퓨터 언어로서 Java는 변수를 조작할 수 있는 풍부한 연산자 세트도 제공합니다. 연산자를 다음 그룹으로 나눌 수 있습니다:
산술 연산자
관계 연산자
-
비트 연산자
논리 연산자
대입 연산자
-
기타 연산자
산술 연산자
산술 연산자는 수학 표현식에 사용되며 수학에서와 동일한 방식으로 작동합니다. 다음 표에는 모든 산술 연산자가 나열되어 있습니다.
표의 예에서는 정수 변수 A의 값이 10이고 변수 B의 값이 20이라고 가정합니다.
연산자 | 설명 | 예 |
---|---|---|
+ | 추가 - 단계 더하기 연산자의 양쪽 값 | A + B는 30과 같습니다 |
- | 뺄셈 - 왼쪽 피연산자에서 오른쪽 피연산자 빼기 피연산자 | A – B는 -10과 같습니다 |
* | 곱셈 - 곱셈 연산자의 양쪽 값 | A * B는 200과 같습니다 |
/ | 나누기 - 왼쪽 피연산자를 오른쪽 피연산자로 나눈 값 | B/A는 2입니다 |
% | 모듈로 - 왼쪽 피연산자의 나머지를 오른쪽 피연산자로 나눈 값 | B%A는 0 |
++ | 자동 증가: 피연산자의 값이 1씩 증가합니다 | B++ 또는 ++B는 21과 같습니다(아래 차이점 참조) |
-- | 감소: 피연산자의 값이 1만큼 감소합니다. | B-- 또는 --B는 19와 같습니다(아래 차이점 참조) |
예제
다음 Java 프로그램을 복사하여 붙여넣고 Test.java 파일로 저장한 후 프로그램을 컴파일하고 실행합니다.
public class Test { public static void main(String args[]) { int a = 10; int b = 20; int c = 25; int d = 25; System.out.println("a + b = " + (a + b) ); System.out.println("a - b = " + (a - b) ); System.out.println("a * b = " + (a * b) ); System.out.println("b / a = " + (b / a) ); System.out.println("b % a = " + (b % a) ); System.out.println("c % a = " + (c % a) ); System.out.println("a++ = " + (a++) ); System.out.println("a-- = " + (a--) ); // 查看 d++ 与 ++d 的不同 System.out.println("d++ = " + (d++) ); System.out.println("++d = " + (++d) ); } }
증가 및 감소 연산자
1. 증가(++) 및 감소(--) 연산자는 특별합니다. 연산을 수행하는 데 두 개의 피연산자가 필요한 산술 연산자인 반면, 증가 및 감소 연산자에는 하나의 피연산자가 필요합니다.
public class selfAddMinus{ public static void main(String[] args){ int a = 3;//定义一个变量; int b = ++a;//自增运算 int c = 3; int d = --c;//自减运算 System.out.println("进行自增运算后的值等于"+b); System.out.println("进行自减运算后的值等于"+d); } }
실행 결과:
进行自增运算后的值等于4进行自减运算后的值等于2
분석:
int b = ++a; 拆分运算过程为: a=a+1=4; b=a=4, 最后结果为b=4,a=4 int d = --c; 拆分运算过程为: c=c-1=2; d=c=2, 最后结果为d=2,c=2
2. 접두사 자동 증가 및 자동 빼기 방법(++a,--a): 먼저 자체 증가 또는 자체 감소 연산을 수행한 후 표현식 연산을 수행합니다.
3. 접미사 자동 증가 및 자동 빼기 방법(a++,a--): 먼저 표현식 연산을 수행한 후 수행합니다. 자동 증가 또는 자동 감소 연산의 예:
public class selfAddMinus{ public static void main(String[] args){ int a = 5;//定义一个变量; int b = 5; int x = 2*++a; int y = 2*b++; System.out.println("自增运算符前缀运算后a="+a+",x="+x); System.out.println("自增运算符后缀运算后b="+b+",y="+y); } }
연산 결과는 다음과 같습니다.
自增运算符前缀运算后a=6,x=12自增运算符后缀运算后b=6,y=10
관계 연산자
다음 표는 에서 지원하는 관계 연산자를 보여줍니다. Java
표의 예제 정수 변수 A의 값은 10이고 변수 B의 값은 20입니다.
연산자 | 설명 | 예 |
---|---|---|
== | 여부 확인 두 피연산자의 값이 같고, 그렇다면 조건은 참입니다. | (A == B)는 거짓(사실이 아님)입니다. |
!= | 두 피연산자의 값이 같은지 확인하고, 값이 같지 않으면 조건이 true입니다. | (A != B)는 사실입니다. |
> | 왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 큰지 확인하면 조건이 true입니다. | (A>B)는 사실이 아닙니다. |
왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 작은지 확인하고, 그렇다면 조건이 true입니다. | (A | |
> = | 왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 크거나 같은지 확인하고, 그렇다면 조건이 true입니다. | (A> = B)는 거짓입니다. |
왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 작거나 같은지 확인하고, 그렇다면 조건이 true입니다. | (A |
实例
下面的简单示例程序演示了关系运算符。复制并粘贴下面的Java程序并保存为Test.java文件,然后编译并运行这个程序:
public class Test { public static void main(String args[]) { int a = 10; int b = 20; System.out.println("a == b = " + (a == b) ); System.out.println("a != b = " + (a != b) ); System.out.println("a > b = " + (a > b) ); System.out.println("a < b = " + (a < b) ); System.out.println("b >= a = " + (b >= a) ); System.out.println("b <= a = " + (b <= a) ); } }
以上实例编译运行结果如下:
a == b = falsea != b = truea > b = falsea < b = trueb >= a = trueb <= a = false
位运算符
Java定义了位运算符,应用于整数类型(int),长整型(long),短整型(short),字符型(char),和字节型(byte)等类型。
位运算符作用在所有的位上,并且按位运算。假设a = 60,b = 13;它们的二进制格式表示将如下:
A = 0011 1100 B = 0000 1101 ----------------- A&b = 0000 1100 A | B = 0011 1101 A ^ B = 0011 0001 ~A= 1100 0011
下表列出了位运算符的基本运算,假设整数变量A的值为60和变量B的值为13:
연산자 | 설명 | 예 |
---|---|---|
& | 해당하는 경우 비트는 모두 1이고 결과는 1이고, 그렇지 않으면 0 | (A&B)이고 12를 얻습니다. 즉, 0000 1100 |
| | 해당 비트가 모두 0이면 결과는 0이고, 그렇지 않으면 1입니다 | (A | B)하여 61, 즉 0011 1101 |
^ | 해당 비트 값이 같으면 결과는 0, 그렇지 않으면 1 | (A^B)은 49, 즉 0011 0001 |
~ | 비트 보수 연산자는 피연산자의 각 비트를 뒤집습니다. 즉, 0은 1이 되고 1은 0이 됩니다. | (~A)는 -61을 얻습니다. 이는 1100 0011 |
비트 왼쪽 시프트 연산자입니다. 왼쪽 피연산자는 오른쪽 피연산자가 지정한 비트 수만큼 왼쪽으로 이동합니다. | ||
>> | 비트 오른쪽 이동 연산자입니다. 왼쪽 피연산자는 오른쪽 피연산자가 지정한 비트 수만큼 오른쪽으로 비트 단위로 이동합니다. | A >> 2는 1111인 15를 얻습니다. |
>>> | 비트 오른쪽 시프트 제로 패딩 연산자입니다. 왼쪽 피연산자의 값은 오른쪽 피연산자가 지정한 비트 수만큼 오른쪽으로 이동하고 결과 빈자리는 0으로 채워집니다. | A>>>2는 15를 얻어 0000 1111입니다. |
实例
复制并粘贴下面的Java程序并保存为TestA.java文件,然后编译并运行这个程序:
public class TestA { public static void main(String args[]) { int a = 60; /* 60 = 0011 1100 */ int b = 13; /* 13 = 0000 1101 */ int c = 0; c = a & b; /* 12 = 0000 1100 */ System.out.println("a & b = " + c ); c = a | b; /* 61 = 0011 1101 */ System.out.println("a | b = " + c ); c = a ^ b; /* 49 = 0011 0001 */ System.out.println("a ^ b = " + c ); c = ~a; /*-61 = 1100 0011 */ System.out.println("~a = " + c ); c = a << 2; /* 240 = 1111 0000 */ System.out.println("a << 2 = " + c ); c = a >> 2; /* 15 = 1111 */ System.out.println("a >> 2 = " + c ); c = a >>> 2; /* 15 = 0000 1111 */ System.out.println("a >>> 2 = " + c ); } }
以上实例编译运行结果如下:
a & b = 12a | b = 61a ^ b = 49~a = -61a << 2 = 240a >> 15a >>> 15
逻辑运算符
下表列出了逻辑运算符的基本运算,假设布尔变量A为真,变量B为假
操作符 | 描述 | 例子 |
---|---|---|
&& | 称为逻辑与运算符。当且仅当两个操作数都为真,条件才为真。 | (A && B)为假。 |
| | | 称为逻辑或操作符。如果任何两个操作数任何一个为真,条件为真。 | (A | | B)为真。 |
! | 称为逻辑非运算符。用来反转操作数的逻辑状态。如果条件为true,则逻辑非运算符将得到false。 | !(A && B)为真。 |
实例
复制并粘贴下面的Java程序并保存为TestA.java文件,然后编译并运行这个程序:
public class TestA { public static void main(String args[]) { boolean a = true; boolean b = false; System.out.println("a && b = " + (a&&b)); System.out.println("a || b = " + (a||b) ); System.out.println("!(a && b) = " + !(a && b)); } }
以上实例编译运行结果如下:
a && b = falsea || b = true!(a && b) = true
短路逻辑运算符
当使用与逻辑运算符时,在两个操作数都为true时,结果才为true,但是当得到第一个操作为false时,其结果就必定是false,这时候就不会再判断第二个操作了。
public class LuoJi{ public static void main(String[] args){ int a = 5;//定义一个变量; boolean b = (a<4)&&(a++<10); System.out.println("使用短路逻辑运算符的结果为"+b); System.out.println("a的结果为"+a); } }
运行结果为:
使用短路逻辑运算符的结果为falsea的结果为5
解析: 该程序使用到了短路逻辑运算符(&&),首先判断 a
赋值运算符
下面是Java语言支持的赋值运算符:
연산자 | 설명 | 예 |
---|---|---|
= | 간단 할당 연산자, 오른쪽 피연산자의 값을 왼쪽 피연산자에 할당 | C = A + B는 A + B에서 얻은 값을 C |
+ = | 에 할당합니다.왼쪽 피연산자와 오른쪽 피연산자를 더하고 왼쪽 피연산자에 값을 할당하는 추가 할당 연산자 | C + = A는 C = C + A와 동일합니다 |
- = | 왼쪽 피연산자와 오른쪽 피연산자를 빼고 이를 왼쪽 피연산자에 할당하는 빼기 및 대입 연산자 | C - = A 등 C = C의 가격 - A |
* = | 왼쪽 피연산자와 오른쪽 피연산자를 곱하여 왼쪽 피연산자에 대입하는 곱셈 및 대입 연산자 | C * = A는 C = C * A |
/ = | 나누기 및 할당 연산자와 같습니다. 왼쪽 피연산자와 오른쪽 피연산자를 나누어 왼쪽에 할당합니다. 피연산자 | C / = A는 C = C / A |
(%) = | 모듈로 및 할당 연산자와 동일하며, 왼쪽 모듈로 피연산자와 오른쪽 피연산자를 결합하여 왼쪽 피연산자에 할당합니다. | C% = A는 C = C%A |
왼쪽 시프트 할당 연산자 | C | |
오른쪽 시프트 할당 연산자 | C >> = 2는 C = C >> 2 | |
비트 AND 대입 연산자 | C&= 2는 C = C&2 | |
비트 XOR 대입 연산자 | C ^ = 2는 C = C ^ 2과 같습니다. | |
| = | 비트별 OR 할당 연산자 | C | = 2는 C = C | 2 |
범주 | 연산자 | 연관 |
---|---|---|
접미사 | () [] .(점 연산자) | 왼쪽에서 오른쪽으로 |
1달러 | + + - !~ | 오른쪽에서 왼쪽으로 |
곱셈 | * /% | 왼쪽에서 오른쪽으로 |
덧셈 | + - | 왼쪽에서 오른쪽으로 |
Shift | >> 왼쪽에서 오른쪽으로 | |
== != | 왼쪽에서 오른쪽으로 | |
& | 왼쪽에서 오른쪽으로 누르기 | |
^ | 왼쪽 오른쪽으로 | |
비트 OR | | | 왼쪽에서 오른쪽으로 |
논리 AND | && | 왼쪽에서 오른쪽으로 |
논리 OR | | | 왼쪽에서 오른쪽으로 |
조건부 | ? : | 오른쪽에서 왼쪽으로 |
과제 | = + = - = * = / =%= >> &= ^ = | = | 오른쪽에서 왼쪽으로 |
쉼표 | , | 왼쪽에서 오른쪽으로 |
위 내용은 JAVA 입문 튜토리얼 | Chapter 5 Operation Conformity Set 내용입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 참고해주세요!

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于结构化数据处理开源库SPL的相关问题,下面就一起来看一下java下理想的结构化数据处理类库,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于PriorityQueue优先级队列的相关知识,Java集合框架中提供了PriorityQueue和PriorityBlockingQueue两种类型的优先级队列,PriorityQueue是线程不安全的,PriorityBlockingQueue是线程安全的,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于java锁的相关问题,包括了独占锁、悲观锁、乐观锁、共享锁等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于多线程的相关问题,包括了线程安装、线程加锁与线程不安全的原因、线程安全的标准类等等内容,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于枚举的相关问题,包括了枚举的基本操作、集合类对枚举的支持等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于Java的相关知识,其中主要介绍了关于关键字中this和super的相关问题,以及他们的一些区别,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于平衡二叉树(AVL树)的相关知识,AVL树本质上是带了平衡功能的二叉查找树,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于Java的相关知识,其中主要整理了Stream流的概念和使用的相关问题,包括了Stream流的概念、Stream流的获取、Stream流的常用方法等等内容,下面一起来看一下,希望对大家有帮助。


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

드림위버 CS6
시각적 웹 개발 도구

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

뜨거운 주제



