How do I remove objects from an array in Java?

前端 未结 20 1415
Happy的楠姐
Happy的楠姐 2020-11-22 01:20

Given an array of n Objects, let\'s say it is an array of strings, and it has the following values:

foo[0] = \"a\";
foo[1]          


        
20条回答
  •  再見小時候
    2020-11-22 01:47

    There are a lot of answers here--the problem as I see it is that you didn't say WHY you are using an array instead of a collection, so let me suggest a couple reasons and which solutions would apply (Most of the solutions have already been answered in other questions here, so I won't go into too much detail):

    reason: You didn't know the collection package existed or didn't trust it

    solution: Use a collection.

    If you plan on adding/deleting from the middle, use a LinkedList. If you are really worried about size or often index right into the middle of the collection use an ArrayList. Both of these should have delete operations.

    reason: You are concerned about size or want control over memory allocation

    solution: Use an ArrayList with a specific initial size.

    An ArrayList is simply an array that can expand itself, but it doesn't always need to do so. It will be very smart about adding/removing items, but again if you are inserting/removing a LOT from the middle, use a LinkedList.

    reason: You have an array coming in and an array going out--so you want to operate on an array

    solution: Convert it to an ArrayList, delete the item and convert it back

    reason: You think you can write better code if you do it yourself

    solution: you can't, use an Array or Linked list.

    reason: this is a class assignment and you are not allowed or you do not have access to the collection apis for some reason

    assumption: You need the new array to be the correct "size"

    solution: Scan the array for matching items and count them. Create a new array of the correct size (original size - number of matches). use System.arraycopy repeatedly to copy each group of items you wish to retain into your new Array. If this is a class assignment and you can't use System.arraycopy, just copy them one at a time by hand in a loop but don't ever do this in production code because it's much slower. (These solutions are both detailed in other answers)

    reason: you need to run bare metal

    assumption: you MUST not allocate space unnecessarily or take too long

    assumption: You are tracking the size used in the array (length) separately because otherwise you'd have to reallocate your array for deletes/inserts.

    An example of why you might want to do this: a single array of primitives (Let's say int values) is taking a significant chunk of your ram--like 50%! An ArrayList would force these into a list of pointers to Integer objects which would use a few times that amount of memory.

    solution: Iterate over your array and whenever you find an element to remove (let's call it element n), use System.arraycopy to copy the tail of the array over the "deleted" element (Source and Destination are same array)--it is smart enough to do the copy in the correct direction so the memory doesn't overwrite itself:

     System.arraycopy(ary, n+1, ary, n, length-n) 
     length--;
    

    You'll probably want to be smarter than this if you are deleting more than one element at a time. You would only move the area between one "match" and the next rather than the entire tail and as always, avoid moving any chunk twice.

    In this last case, you absolutely must do the work yourself, and using System.arraycopy is really the only way to do it since it's going to choose the best possibly way to move memory for your computer architecture--it should be many times faster than any code you could reasonably write yourself.

提交回复
热议问题