
- Groovy Tutorial
- Groovy - Home
- Groovy - Overview
- Groovy - Environment
- Groovy - Basic Syntax
- Groovy - Data Types
- Groovy - Variables
- Groovy - Optionals
- Groovy - Numbers
- Groovy - Strings
- Groovy - Ranges
- Groovy - Lists
- Groovy - Maps
- Groovy - Dates & Times
Groovy Operators
- Groovy - Operators
- Groovy - Arithmetic Operators
- Groovy - Assignment Operators
- Groovy - Relational Operators
- Groovy - Logical Operators
- Groovy - Bitwise Operators
- Groovy - Spaceship Operator
- Groovy - in Operator
- Groovy - Elvis Operator
- Groovy - Safe Navigation Operator
- Groovy Operator Precedence & Associativity
Control Statements
- Groovy - Decision Making
- Groovy - If Else Statement
- Groovy - Switch Statement
- Groovy - Loops
- Groovy - For Loop
- Groovy - For-in Loop
- Groovy - While Loop
- Groovy - Do While Loop
- Groovy - Break Statement
- Groovy - Continue Statement
Groovy File Handling
- Groovy - File I/O
- Java - Create a File
- Java - Write to File
- Java - Append to File
- Java - Read Files
- Java - Delete Files
- Java - File Properties
- Java - File Existence and Type
- Java - File Size
- Java - File Permissions
- Java - Directories
- Java - Listing Directories
- Java - Filtering Files/Directories
- Java - Deleting Directories
- Java - Renaming Files/Directories
Groovy Error & Exceptions
- Groovy - Exception Handling
- Groovy - try-catch Block
- Groovy - try-with-resources
- Groovy - Multi-catch Block
- Groovy - Nested try Block
- Groovy - Finally Block
- Groovy - throw Exception
- Groovy - Exception Propagation
- Groovy - Built-in Exceptions
- Groovy - Custom Exception
Groovy Multithreading
- groovy - Multithreading
- groovy - Thread Life Cycle
- groovy - Creating a Thread
- groovy - Starting a Thread
- groovy - Joining Threads
- groovy - Naming Thread
- groovy - Thread Scheduler
- groovy - Thread Pools
- groovy - Main Thread
- groovy - Thread Priority
- groovy - Daemon Threads
- groovy - Shutdown Hook
Groovy Synchronization
- groovy - Synchronization
- groovy - Block Synchronization
- groovy - Static Synchronization
- groovy - Inter-thread Communication
- groovy - Thread Deadlock
- groovy - Interrupting a Thread
- groovy - Thread Control
- groovy - Reentrant Monitor
- Groovy - Methods
- Groovy - Methods
- Groovy - Optional parenthesis
- Groovy - Named Arguments
- Groovy - Closures as Arguments
- Groovy - Method Overloading
- Groovy - Method Scope and Visibility
- Groovy - isCase Method
- Groovy - Implicit Return
- Groovy - Variable Arguments
- Groovy - Regular Expressions
- Groovy - Regular Expressions
- Groovy - Defining Regular Expressions
- Groovy - Matcher Object
- Groovy - Regex Tasks
- Groovy - XML
- Groovy - XML
- Groovy - Parsing XML
- Groovy - Creating XML
- Groovy - Modifying XML
- Groovy - Querying XML
- Groovy - Simplified Notation
- Groovy - Closure based Querying
- Groovy - Closure based Creation
- Groovy - JSON
- Groovy - JSON
- Groovy - Parsing JSON
- Groovy - Creating JSON using JsonOutput
- Groovy - Creating JSON using JsonBuilder
- Groovy - Modifying JSON
- Groovy - Error Handling
- Groovy - Handling JSON Arrays
- Groovy - JSON Array Operations
- Groovy - JSON Objects
- Groovy - JSON Object Operations
- Groovy - Generics
- Groovy - Generics
- Groovy - Declaring Generic Types
- Groovy - Bound Type Parameters
- Groovy - Wild Cards
- Groovy - Miscellaneous
- Groovy - Object Oriented
- Groovy - Closures
- Groovy - Annotations
- Groovy - JMX
- Groovy - DSLS
- Groovy - Database
- Groovy - Builders
- Groovy - Command Line
- Groovy - Unit Testing
- Groovy - Template Engines
- Groovy - Meta Object Programming
- Groovy Useful Resources
- Groovy - Quick Guide
- Groovy - Useful Resources
- Groovy - Discussion
Groovy - Spaceship Operator
Spaceship operator is used to compare objects and is denoted by <=> operator. Spaceship operator works perfectly for objects which implement Comparable Interface correctly.
Spaceship Operator Functionality
obj1 <=> obj2
Here obj1 and obj2 are compared and spaceship operator returns.
-1 − if obj1 is less than obj2
0 − if obj1 is same as obj2
1 − if obj1 is more than obj2
Usage of Spaceship Operator
We can use spaceship operator to compare numbers, strings, dates and custom objects which implements Comparable interface. Let's compare each type using spaceship operator in below examples.
Example - Compare Numbers
Example.groovy
class Example { static void main(String[] args) { // prints 1 as 5 is greater than 1 println 5 <=> 1 // prints 0 as 3 is equal to 3 println 3 <=> 3 // prints -1 as 2 is less than 7 println 2 <=> 7 } }
Output
When we run the above program, we will get the following result.
1 0 -1
Example - Compare Strings
Example.groovy
class Example { static void main(String[] args) { // prints 1 as apple comes before banana lexicographically println "apple" <=> "banana" // prints 0 as as cat is same as cat println "cat" <=> "cat" // prints -1 as as zebar comes after horse lexicographically println "zebra" <=> "horse" } }
Output
When we run the above program, we will get the following result.
1 0 -1
Example - Compare Dates
Example.groovy
class Example { static void main(String[] args) { def date1 = new Date(125, 0, 1) // January 1, 2025 def date2 = new Date(125, 0, 15) // January 15, 2025 def date3 = new Date(125, 0, 1) // January 1, 2025 // prints -1 as date1 comes before date2 println date1 <=> date2 // prints 0 as as date1 is same as date3 println date1 <=> date3 // prints 1 as as date2 comes after date1 println date2 <=> date1 } }
Output
When we run the above program, we will get the following result.
-1 0 1
Example - Compare Custom Objects
Example.groovy
class Example { static void main(String[] args) { def v101 = new Version(1, 0, 1) def v102 = new Version(1, 0, 2) // prints -1 as v101 comes before v102 println v101 <=> v102 // prints 0 as as v101 is same as new Version(1, 0, 1) println v101 <=> new Version(1, 0, 1) // prints 1 as as v102 comes after v101 println v102 <=> v101 } } class Version implements Comparable<Version> { int major; int minor; int patch; Version(int major, int minor, int patch) { this.major = major; this.minor = minor; this.patch = patch; } @Override int compareTo(Version other) { if (major != other.major) { return major <=> other.major; } if (minor != other.minor) { return minor <=> other.minor; } return patch <=> other.patch; } Version next() { return new Version(major, minor, patch + 1); } String toString() { return "${major}.${minor}.${patch}"; } }
Output
When we run the above program, we will get the following result.
-1 0 1