Kotlin Language Features Related to Null Handling

Any software engineer with a Java background would find the null handling features in the Kotlin language interesting. Let's summarize this topic with some examples. Nullable types: In Kotlin, types are non-nullable by default. If you want a variable to be able to hold a null value, you need to explicitly declare its type as nullable using the Type? syntax. For example, String? denotes a nullable string, while String represents a non-nullable string. Safe calls (?.): Kotlin introduces the safe call operator (?.) for handling nullable types. It allows you to safely invoke a method or access a property on a nullable object. If the object is null, the expression returns null instead of throwing a NullPointerException. Example: data class Person(val name: String, val age: Int, val address: String?) fun main() {     // Create a person with a nullable address     val person1 = Person("John Doe", 25, "123 Main Street")     val person2 = Person("Jane Doe", 30,...

Java 8 ile gelen Lambda Expressions özelliğine merhaba diyelim

Lambda ifadeleri C# dilinde yıllardır vardı ve sonunda Java diline de bu özellik eklendi. Peki bu lambda expression özelliği hangi amaçla kullanılıyor?
Amacımız şu: Belli bir işi yapma biçimini (fonksiyonaliteyi), bir metoda parametre olarak geçmek istiyoruz. Başka bir deyişle, kodu sanki veriymiş gibi parametre olarak geçmek istiyoruz. Peki eskiden bunu yapamıyormuyduk Java ile? Yapabiliyorduk ama Anonymous class yöntemi ile yapabiliyorduk. Aşağıda vereceğim basit örnekte aradaki farkı görebileceğiz:

public class Program {

    public static class Person {
        private int age;
        private String name;

        Person(String name, int age) {
            this.age = age;
            this.name = name;
        }

        public int getAge() {
            return age;
        }

        public String getName() {
            return name;
        }
    }

    public interface GreetingMethod {
        int howManyTimes(Program.Person p);
    }

    public static void main(String[] args) {

        Person bahadir = new Person("Bahadir", 32);
        Person bilge = new Person("Bilge", 2);

        Person anonymous = new Person("Anon", 18);

        // Lambda expression ile:
        new Program().greet(bahadir, p -> p.getAge() > 30 ? 2 : 1);
        new Program().greet(bilge, p -> p.getAge() > 20 ? 2 : 1);

        // Anonymous class ile pek de sade bir görünüm yok gibi:
        new Program().greet(anonymous, new GreetingMethod() {
            @Override
            public int howManyTimes(Person p) {
                if (p.getAge() > 10)
                    return 2;

                return 0;
            }
        });

    }

    public void greet(Person person, GreetingMethod greetingMethod) {

        for (int i = 0; i < greetingMethod.howManyTimes(person); ++i) {
            System.out.println("Hello " + person.getName() + "!");
        }

    }
}

Lambda ifadeleri, tek metotlu arayüzleri daha sade bir biçimde parametre olarak geçmemize olanak tanıyor.
Geçen gün izlediğim bir sunumda, konuşmacı lamda ifadesi içeren bir örnek verecekti ama önce Java programcılarını korkmamaları için uyarmıştı. Artık böyle bir uyarıya gerek kalmayacak.

Comments

Popular posts from this blog

Trie Data Structure and Finding Patterns in a Collection of Words

Virtual Memory

NOTES ON COMPUTER ARCHITECTURE: Some important concepts in computer architecture