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

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

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

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

Q&A

解決済

2回答

1108閲覧

大きなサイズの配列を確保する際にエラーがでないことと、macOS上でコードの挙動が変わること。

jajaja

総合スコア17

C++

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

0グッド

0クリップ

投稿2020/06/19 16:01

###質問内容
2点ございます。
1点目は、下記のコードに対して下記の入力をした際に、私の環境ですと実行できないのにも関わらずHackerRank上ですと実行できる原因を知りたいです。
該当するHackerRankの問題は https://www.hackerrank.com/challenges/exceptional-server/problemです。

2点目は、1435434255433 5を入力した際に、エラーが返ってこない理由を知りたいです。
この理由として、1435434255433 5の入力に対して、私がデバックモードで追跡をした際、Serverクラス内のvector<int> v(A, 0);で追跡ができなくなりました。
そのため、vector<int> v(A, 0);に問題があると考えたのですが、ここでエラーが返ってこないため質問しました。

該当のソースコード

c++

1#include <iostream> 2#include <exception> 3#include <string> 4#include <stdexcept> 5#include <vector> 6#include <cmath> 7using namespace std; 8 9class Server 10{ 11private: 12 static int load; 13 14public: 15 static int compute(long long A, long long B) 16 { 17 load += 1; 18 if (A < 0) 19 { 20 throw std::invalid_argument("A is negative"); 21 } 22 vector<int> v(A, 0); 23 int real = -1, cmplx = sqrt(-1); 24 if (B == 0) 25 throw 0; 26 real = (A / B) * real; 27 int ans = v.at(B); 28 return real + A - B * ans; 29 } 30 static int getLoad() 31 { 32 return load; 33 } 34}; 35int Server::load = 0; 36 37int main() 38{ 39 int T; 40 cin >> T; 41 while (T--) 42 { 43 long long A, B; 44 cin >> A >> B; 45 46 /* Enter your code here. */ 47 try 48 { 49 auto res = Server::compute(A, B); 50 cout << res << endl; 51 } 52 catch (const std::bad_alloc &e) 53 { 54 puts("Not enough memory"); 55 } 56 catch (const std::exception &e) 57 { 58 printf("Exception: %s\n", e.what()); 59 } 60 catch (...) 61 { 62 puts("Other Exception"); 63 } 64 } 65 cout << Server::getLoad() << endl; 66 return 0; 67}

入力

2 -8 5 1435434255433 5

補足情報(FW/ツールのバージョンなど)

visual stdio code 1.46.0
Mac OS 10.15.4
clang:Apple clang version 11.0.3 (clang-1103.0.32.29)

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

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

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

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

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

guest

回答2

0

「オーバーコミット」だと思います。 実際に空いているよりも多くのメモリを OS に対して要求してもエラーを出さないことがあります。 メモリ空間と物理メモリの割り当てを実際にメモリを使うときまで遅らせる仕組みがあり、メモリにアクセスするときまで物理メモリを占有しません。

そのかわり、実行時に本当に物理メモリが足らなくてどうにもならないときは OOM Killer と呼ばれるサービスが実行中のプログラムを強制的に停止するという処理をします。

投稿2020/06/19 19:20

SaitoAtsushi

総合スコア5675

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

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

jajaja

2020/06/20 06:45

回答ありがとうございます。 オーバーコミットというワードを初めて耳にしました。 勉強になりました、ありがとうございます。
guest

0

ベストアンサー

2点目は、1435434255433 5を入力した際に、エラーが返ってこない理由を知りたいです。

MacのXcode(clang)で動かしてみましたが、vector<int> v(A, 0);で5347GBのメモリを確保しようと頑張っているようですね。
Xcode上やアクティビティモニタでみているとメモリ使用量がどんどん増えていきます。


64GBを超えたあたりでkillされました。
bad_alloc例外じゃないのか…

% ./test 1 1435434255433 5 zsh: killed ./test

Windows上のg++やVisualC++では即bad_allocが投げられました。


Wandboxでclangを選んで動かすとbad_allocが投げられていますね…

投稿2020/06/19 18:08

編集2020/06/19 19:08
SHOMI

総合スコア4079

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

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

jajaja

2020/06/20 06:43

他の環境での挙動についても調べていただきありがとうございます。 macだと、bad_allocが投げられるわけではなくkillされるのですね。 勉強になりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問