Skip to main content

Higher-Order Functions in Dart

Higher-Order Functions in Dart

Higher-Order Functions in Dart

A Higher-Order Function is a function that either:

  • Takes another function as a parameter.
  • Returns a function.

These functions help make code more concise and reusable.

1. Passing a Function as a Parameter

You can pass a function as an argument to another function.

void greet(String name, Function message) {
  print("Hello, $name!");
  message();
}

void sayGoodMorning() {
  print("Good morning! Have a great day.");
}

void main() {
  greet("Alice", sayGoodMorning);
}
    

Output:

Hello, Alice!
Good morning! Have a great day.
    

2. Returning a Function

A function can also return another function.

Function multiplier(int n) {
  return (int x) => x * n;
}

void main() {
  var doubleIt = multiplier(2);  // Returns a function that multiplies by 2
  print(doubleIt(5)); // Output: 10
}
    

3. Using Anonymous Functions (Lambda)

Dart allows passing anonymous functions instead of named functions.

void main() {
  List numbers = [1, 2, 3, 4, 5];

  numbers.forEach((num) {
    print(num * 2);
  });
}
    

Output:

2
4
6
8
10
    

4. Using map, where, reduce, and fold

Dart provides built-in higher-order functions like map, where, reduce, and fold.

Example: Using map to Transform a List

void main() {
  List numbers = [1, 2, 3, 4];
  var squaredNumbers = numbers.map((n) => n * n).toList();
  print(squaredNumbers); // Output: [1, 4, 9, 16]
}
    

Example: Using where to Filter a List

void main() {
  List numbers = [10, 15, 20, 25, 30];
  var evenNumbers = numbers.where((n) => n % 2 == 0).toList();
  print(evenNumbers); // Output: [10, 20, 30]
}
    

Key Benefits of Higher-Order Functions

  • Code Reusability – Functions can be reused dynamically.
  • Conciseness – Reduces boilerplate code.
  • Flexibility – Enables functional programming techniques.

Higher-order functions make Dart more powerful and expressive! 🚀

Comments

Popular posts from this blog

API Integration in Flutter - A Step-by-Step Guide

API Integration in Flutter - A Step-by-Step Guide API Integration in Flutter - A Step-by-Step Guide Learn how to integrate APIs into your Flutter app with this easy-to-follow tutorial. Step 1: Add Dependencies Start by adding the necessary dependencies for HTTP requests and JSON handling in your pubspec.yaml file. dependencies: flutter: sdk: flutter http: ^0.13.3 Run flutter pub get to install the dependencies. Step 2: Create a Service Class for API Calls Next, create a Dart file (e.g., api_service.dart ) to handle your API logic. Below is an example of a simple GET request function: import 'dart:convert'; import 'package:http/http.dart' as http; class ApiService { final String baseUrl; ApiService({required this.baseUrl...

How, Purpose, and When to Use Google ML Kit in Flutter

How, Purpose, and When to Use Google ML Kit in Flutter How, Purpose, and When to Use Google ML Kit in Flutter Purpose of Google ML Kit in Flutter Google ML Kit simplifies adding AI features to mobile applications. Its primary purposes include: On-Device Machine Learning: Perform AI tasks without requiring an internet connection, ensuring low latency, privacy, and faster processing. Pre-trained Models: Use Google's robust, pre-trained models without needing ML expertise. Versatile AI Features: Enable functionalities like: Text recognition Barcode scanning Image labeling Face detection Pose detection Language identification Translation Entity extraction Smart replies When to Use Google ML Kit You should use Google ML Kit when: You need pre-built AI features withou...

Implementing in-app turn-by-turn navigation in a Flutter application using Google Maps and the Directions API involves several steps

  1. Integrate Google Maps into Your Flutter App a. Add the  google_maps_flutter  Package: Include the  google_maps_flutter  package in your  pubspec.yaml  file to embed Google Maps into your Flutter application. yaml dependencies: google_maps_flutter: latest_version b. Obtain and Configure Your API Key: Generate an API Key:  Create a project in the  Google Cloud Console , enable the  Maps SDK for Android  and  Maps SDK for iOS , and generate an API key. Configure Android:  Add your API key to the  AndroidManifest.xml  file. Configure iOS:  Add your API key in the  AppDelegate.swift  file. c. Display the Map: Use the  GoogleMap  widget to display the map within your application. #dartcode import 'package:google_maps_flutter/google_maps_flutter.dart'; GoogleMap( initialCameraPosition: CameraPosition( target: LatLng(latitude, longitude), zoom: 14.0, ), onMapCreated: (Goo...