Skip to content

Bits of .NET

Daily micro-tips for C#, SQL, performance, and scalable backend engineering.

  • Asp.Net Core
  • C#
  • SQL
  • JavaScript
  • CSS
  • About
  • ErcanOPAK.com
  • No Access
  • Privacy Policy
C#

C#: Use Index and Range Operators for Cleaner Array Slicing

- 13.02.26 - ErcanOPAK

Array slicing with loops or LINQ is verbose. C# 8+ has Python-like syntax.

Old Way:

var numbers = new[] { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };

// Get last element
var last = numbers[numbers.Length - 1];  // 9

// Get last 3 elements
var lastThree = numbers.Skip(numbers.Length - 3).ToArray();  // [7,8,9]

New Way:

var numbers = new[] { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };

// Get last element
var last = numbers[^1];  // 9

// Get last 3 elements
var lastThree = numbers[^3..];  // [7, 8, 9]

// Get first 3 elements
var firstThree = numbers[..3];  // [0, 1, 2]

// Get middle elements (index 3 to 6)
var middle = numbers[3..7];  // [3, 4, 5, 6]

// Everything except first and last
var middle2 = numbers[1..^1];  // [1, 2, 3, 4, 5, 6, 7, 8]

Much cleaner and more readable!

Related posts:

C# “LINQ Select N+1 Disaster” — Why Your Code Makes 500 SQL Calls

C#: Use Null-Coalescing Assignment to Simplify Lazy Initialization

C# “JsonSerializer Ignores Private Setters” — The Missing Attribute

Post Views: 3

Post navigation

C#: Use Null-Coalescing Assignment to Simplify Lazy Initialization
C#: Use init Accessor to Create Immutable Objects Without Constructor Boilerplate

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

March 2026
M T W T F S S
 1
2345678
9101112131415
16171819202122
23242526272829
3031  
« Feb    

Most Viewed Posts

  • Get the User Name and Domain Name from an Email Address in SQL (938)
  • How to add default value for Entity Framework migrations for DateTime and Bool (836)
  • Get the First and Last Word from a String or Sentence in SQL (828)
  • How to select distinct rows in a datatable in C# (801)
  • How to make theater mode the default for Youtube (736)
  • Add Constraint to SQL Table to ensure email contains @ (575)
  • How to enable, disable and check if Service Broker is enabled on a database in SQL Server (554)
  • Average of all values in a column that are not zero in SQL (523)
  • How to use Map Mode for Vertical Scroll Mode in Visual Studio (477)
  • Find numbers with more than two decimal places in SQL (441)

Recent Posts

  • C#: Saving Memory with yield return (Lazy Streams)
  • C#: Why Records are Better Than Classes for Data DTOs
  • C#: Creating Strings Without Memory Pressure with String.Create
  • SQL: Protecting Sensitive Data with Dynamic Data Masking
  • SQL: Writing Readable Queries with Common Table Expressions (CTE)
  • .NET Core: Handling Errors Gracefully with Middleware
  • .NET Core: Mastering Service Lifetimes (A Visual Guide)
  • Git: Surgical Stashing – Don’t Save Everything!
  • Git: Writing Commits That Your Future Self Won’t Hate
  • Ajax: Improving Perceived Speed with Skeleton Screens

Most Viewed Posts

  • Get the User Name and Domain Name from an Email Address in SQL (938)
  • How to add default value for Entity Framework migrations for DateTime and Bool (836)
  • Get the First and Last Word from a String or Sentence in SQL (828)
  • How to select distinct rows in a datatable in C# (801)
  • How to make theater mode the default for Youtube (736)

Recent Posts

  • C#: Saving Memory with yield return (Lazy Streams)
  • C#: Why Records are Better Than Classes for Data DTOs
  • C#: Creating Strings Without Memory Pressure with String.Create
  • SQL: Protecting Sensitive Data with Dynamic Data Masking
  • SQL: Writing Readable Queries with Common Table Expressions (CTE)

Social

  • ErcanOPAK.com
  • GoodReads
  • LetterBoxD
  • Linkedin
  • The Blog
  • Twitter
© 2026 Bits of .NET | Built with Xblog Plus free WordPress theme by wpthemespace.com