質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

GitHub

GitHubは、Gitバージョン管理システムを利用したソフトウェア開発向けの共有ウェブサービスです。GitHub商用プランおよびオープンソースプロジェクト向けの無料アカウントを提供しています。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

解決済

1回答

1846閲覧

動的配列(ベクター)をもっと高速にしたい

katahiromz

総合スコア186

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

GitHub

GitHubは、Gitバージョン管理システムを利用したソフトウェア開発向けの共有ウェブサービスです。GitHub商用プランおよびオープンソースプロジェクト向けの無料アカウントを提供しています。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

2クリップ

投稿2015/07/27 06:03

趣味でC言語の動的配列を作っています。
コンセプトとしては、C++のstd::vectorと同じように使えることを目指しています。

vec (vector for C language)
https://github.com/katahiromz/vec
https://github.com/katahiromz/vec/blob/master/vec.c
https://github.com/katahiromz/vec/blob/master/vec.h

なるべく高速にしたいので、遅いところの修正方法をご指摘下さい。
バグなどもありましたら、ついでにご報告下さい。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

KoichiSugiyama

2015/07/29 01:06

何と比べてどう遅いのか、とか、どういう条件で遅くなるのか、どの機能が遅いのか、という情報を具体的に書いてもらわないと、アドバイスのしようがないと思います。実際に動かした場合に処理が停滞するほど遅いのでしょうか?
guest

回答1

0

ベストアンサー

気になった点が2点。

1点目、複製(copy)時、無条件でメモリの解放、再確保を行っていますが、
コピー先の容量が十分にある場合には、単純コピー&状態設定のほうが速いです。
再設定(assign)の場合も同様。

2点目、予約(reserve)時、拡張後の領域を0で初期化しているが、予約の時点では
領域にアクセスすることはないのだから、不要。拡縮(resize)等で実際に使用する
時点になったときに、はじめて上書き、初期化等をすればよい。

3点目、そもそも動的配列を使用していること(笑)。

非常に分かりやすいコードで、リファクタリングがやりやすかったです。
ぜひこれからもいいコードを書き続けてください。

投稿2015/07/30 07:52

majiponi

総合スコア1720

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

katahiromz

2015/07/31 04:18 編集

レビューありがとうございます。参考にします。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問