Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 4249610
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 21, 20262026-05-21T04:25:11+00:00 2026-05-21T04:25:11+00:00

Lets say I have an array of structs and I want to delete an

  • 0

Lets say I have an array of structs and I want to delete an entry that has a struct with an entry matching some criteria.

This array is dynamically allocated with malloc, I keep the element count in a separate variable.

How do I go about deleting the entry?

I’m thinking of

for (i = pos; i < arr_len; i++) {
  arr[i] = arr[i+1];
}
arr_len--;

But this leaves the same amount of memory for the array while I actually need less and an orphan (sort of) last entry.

Is issuing a realloc in such situation an accepted practice? Would realloc do memcpy in this case? (shortening the allocated memory by one block).

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-21T04:25:12+00:00Added an answer on May 21, 2026 at 4:25 am

    realloc is ok … but keep reading 🙂

    realloc will not move parts of the memory; it may move the whole block. So you need to copy the data before changing the allocated size.

    To move the data, memmove (not memcpy) is a good option: it works for memory areas that belong to the same object. Pay attention to not go over your array limits, though; like you do in your code.

    for (i = pos; i < arr_len; i++) {
      arr[i] = arr[i+1];
    }
    

    The arr[i] = arr[i + 1]; will try to access one past the allowed size. You need

    for (i = pos + 1; i < arr_len; i++) {
      arr[i - 1] = arr[i];
    }
    

    There is somewhat of an overhead when calling realloc. If your structs are not large and/or they live only for a short while, consider keeping both an element count and allocated count and only realloc to enlarge (when (element_count + 1) > (allocated_count)).


    If the struct is large, also consider a different data structure (linked list perhaps).

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

What I want to do is following. Lets say we have array like that
So lets say I have an array that I want to organize by the
Lets say I have an array numbers that contains the following values: int numbers
Lets say I have an array of length n and I want to pick
Lets say I have an array with a structure like this: $arr= Array( array(
Ok so lets say I have an array that can be 0 - X
Lets say I have a simple 1D array with 10-20 entries. Some will be
Lets say that i have the following array : float QuadVertices[4 * 2]; float
Lets say I have an array like int arr[10][10]; Now i want to initialize
Lets say I have an array X that contains [A,B,C,D,nil]; and I have a

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.