Deutsch English Français Italiano |
<v5bv37$vejk$1@raubtier-asyl.eternal-september.org> View for Bookmarking (what is this?) Look up another Usenet article |
Path: ...!weretis.net!feeder8.news.weretis.net!eternal-september.org!feeder3.eternal-september.org!news.eternal-september.org!raubtier-asyl.eternal-september.org!.POSTED!not-for-mail From: Bonita Montero <Bonita.Montero@gmail.com> Newsgroups: comp.lang.c Subject: Re: realloc() - frequency, conditions, or experiences about relocation? Date: Mon, 24 Jun 2024 16:16:07 +0200 Organization: A noiseless patient Spider Lines: 18 Message-ID: <v5bv37$vejk$1@raubtier-asyl.eternal-september.org> References: <v4ojs8$gvji$1@dont-email.me> <v4ov8h$j2q2$1@raubtier-asyl.eternal-september.org> <v52270$2nli8$1@dont-email.me> <v54jac$3a4p2$1@raubtier-asyl.eternal-september.org> <v5bbd3$rhao$2@dont-email.me> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit Injection-Date: Mon, 24 Jun 2024 16:16:07 +0200 (CEST) Injection-Info: raubtier-asyl.eternal-september.org; posting-host="25e5eda89458a83976f4ab5b7ad682c9"; logging-data="1030772"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX19F6+Pp4/qLdNBTYD6cT4nU1oZfo7oGVkM=" User-Agent: Mozilla Thunderbird Cancel-Lock: sha1:PHfZoQZ7MtSXM8DpMEiqWMfdaf8= Content-Language: de-DE In-Reply-To: <v5bbd3$rhao$2@dont-email.me> Bytes: 2222 Am 24.06.2024 um 10:40 schrieb Lawrence D'Oliveiro: > On Fri, 21 Jun 2024 21:12:12 +0200, Bonita Montero wrote: >> Usually you don't resize the block with a few bytes ... > The usual way I use realloc is to maintain separate counts of the number > of array elements I have allocated, and the number I am actually using. A > realloc call is only needed when the latter hits the former. Every time I > call realloc, I will extend by some minimum number of array elements (e.g. > 128), roughly comparable to the sort of array size I typically end up > with. > And then when the structure is complete, I do a final realloc call to > shrink it down so the size is actually that used. Is it safe to assume > such a call will never fail? Hmm ... In C++ you dont't have to think about that. Do an emplace_back and the capacity() doubles with libstdc++ and libc++ if the vevtor becomes full.