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

  • Home
  • SEARCH
  • 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 3450504
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 18, 20262026-05-18T09:03:33+00:00 2026-05-18T09:03:33+00:00

Let me explain my problem together with the background, so it would be easier

  • 0

Let me explain my problem together with the background, so it would be easier to understand why I’m asking for this specific type of thing. I’m developing an instant messenger. Most of the architecture is outlined by my teacher, however implementation detail may vary. There is an “Engine” class, EventManager, which registers clients. To identify them and to easily remove them, I use a map (with client-id’s) or a set with pointers. So far, so good. But then this EventManager uses poll() (or select(), but that’s nowhere as comfortable to use as poll(), as you have to rebuild the array each time, which is slow and not-so-nice, I guess, and I can restrict myself to UNIX environment, if you ask) in its main loop. Which needs an array of struct pollfd. Now every time a new client comes or goes, this array needs to be rebuilt. Either I use a dynamic array by hand and allocate memory every time (baaaaaad), or I use a vector, which would handle new client’s struct pollfd insertion pretty well at the end of the container, or a deque, which would insert and remove anywhere pretty well. Now my two questions are:

  1. If I choose vector, will it automatically shrink and move elements in the middle of itself instead of full reallocation? and
  2. That would anyway copy a lot, if it’s in the beginning, so I’d like to use deque. Does that have an array interface (like you would do with vector – &myVector[0]) or is it strictly non-contiguous?
  • 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-18T09:03:33+00:00Added an answer on May 18, 2026 at 9:03 am
    1. If you remove something from the middle of a vector it will move all the following elements one position towards the beginning. It will not reallocate. You don’t have to consider reallocations at all because they are amortized to give O(1) time per insertion.

    2. deque is not much better than vector. Removing from the beginning or end is efficient. Not from the middle. If you remove from anywhere, then it will hopefully be twice as fast a vector, but not faster. Since it’s a more complicated structure it’ll probably be even slower. deque doesn’t guarantee continuous storage, so although indexing is allowed and done in O(1) time, you still can’t reliably convert it to a pointer.

    Anyway it smells like premature optimization. Use vector. Since the order of clients is not significant, you can speed up the erasure of clients by swapping the element that you want to remove with the last element in the vector and calling pop_back() after that.

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

Sidebar

Related Questions

Let me explain: this is path to this folder: > www.my_site.com/images And images are
This question might not seem programming related at first, but let me explain. I'm
How would you begin improving on a really bad system? Let me explain what
Let me explain the problem: Various pages of my web application contain jQuery UI
Alright let me explain my situation first: I am part of an organization that
First, let me explain what I am doing. I need to take an order,
Title might be a bit confusing, so let me explain. I have a website
Is it possible to wipe strings in Delphi? Let me explain: I am writing
How can I document a member inline in .Net? Let me explain. Most tools
Can PL/SQL procedure in Oracle know it's own name? Let me explain: CREATE OR

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.