エスケープシーケンスやWin32APIなどの環境依存なものもOK
そのような質問は必ず環境を書きましょう
半角空白やタブでのインデントはスレに貼ると無くなります
コードを貼れる所
http://codepad.org/
https://ideone.com/
前スレ
【初心者歓迎】C/C++室 Ver.102【環境依存OK】
http://mevius.5ch.net/test/read.cgi/tech/1509780815/
探検
【初心者歓迎】C/C++室 Ver.103【環境依存OK】
■ このスレッドは過去ログ倉庫に格納されています
2018/07/01(日) 03:44:53.53ID:4MMF8cDN
2デフォルトの名無しさん
2018/07/01(日) 05:02:07.56ID:FOGWQSv4 こんばんは。質問です。
Win32APIで現在OSが再生中の音声の値を取得する方法を教えてください。
その瞬間の値をLR各1個取れればいいですが、ある程度連続的に配列に取り込めるほうがベターです。
スペクトラムアナライザを作ろうと思います。
Windows10/Visual Studio 2017/ C or C++です。
Win32APIで現在OSが再生中の音声の値を取得する方法を教えてください。
その瞬間の値をLR各1個取れればいいですが、ある程度連続的に配列に取り込めるほうがベターです。
スペクトラムアナライザを作ろうと思います。
Windows10/Visual Studio 2017/ C or C++です。
2018/07/01(日) 18:40:59.30ID:pYjHbPeQ
sqrt(2.0);
sqrt((double)2);
後者の俺はおかしいですか
sqrt((double)2);
後者の俺はおかしいですか
2018/07/01(日) 21:50:22.05ID:mDZv4OK3
うん
それ以前に定数にsqrt()なんて使う時点で
それ以前に定数にsqrt()なんて使う時点で
2018/07/01(日) 21:54:36.84ID:Z8xp56Jv
もしかして、実行時刻や国によって計算結果が異なるのかも知れない
あるいは、希に発生する宇宙線の影響を検出したいという意図が有るのかもしれない
あるいは実行環境のバグを検出しその後の処理を切り替えたいとか
あるいは、希に発生する宇宙線の影響を検出したいという意図が有るのかもしれない
あるいは実行環境のバグを検出しその後の処理を切り替えたいとか
2018/07/01(日) 23:13:23.96ID:/Pcja9c+
正確に√2とか√3を定数で持つにはどうしたらいい?
2018/07/01(日) 23:32:19.32ID:lS5AQxvk
>>6
そもそも浮動小数点数で無理数を正確に表すこと自体が不可能だけど、どこまでの精度を求めてるの?
そもそも浮動小数点数で無理数を正確に表すこと自体が不可能だけど、どこまでの精度を求めてるの?
2018/07/02(月) 00:05:20.60ID:Y9X1m4Hz
有理数を使えば良いじゃね?
2018/07/02(月) 00:31:58.87ID:TNHgdEjE
>>7
sqrt呼ぶのと同精度でいいよ
sqrt呼ぶのと同精度でいいよ
2018/07/02(月) 01:18:41.69ID:3LeesGvV
√2と√2をかけ合わせたらちょうど2を返す無理数クラスなら作れそう
すでにありそう
素因数分解が必要そうだから結構面倒になるかな?
すでにありそう
素因数分解が必要そうだから結構面倒になるかな?
2018/07/02(月) 07:01:13.71ID:tvgYkj/r
無理数というか、冪の底と指数をそれぞれ有理数で持つ、
という形式ならいけそうだな。
有理数クラスの約分に相当する処理を自動的にやらせる感じ。
という形式ならいけそうだな。
有理数クラスの約分に相当する処理を自動的にやらせる感じ。
2018/07/02(月) 09:17:09.45ID:yNy9eqPr
2018/07/02(月) 20:49:02.70ID:T8iPgZJX
#define SQRT2 1.414213...(必要な桁)
で充分だよ
で充分だよ
2018/07/02(月) 22:00:31.27ID:ZEcRd/bU
そこはせめて
static const double SQRT2 = 1.414213...(必要な桁)
にしようよ…
static const double SQRT2 = 1.414213...(必要な桁)
にしようよ…
15デフォルトの名無しさん
2018/07/04(水) 21:59:31.57ID:gFgZc5FG 18Z
2018/07/05(木) 12:54:37.46ID:u9CJaon8
vcのcl.exeでc書いてるんだが、20億バイトのmallocがnull返します。
何とかなりませんか?
何とかなりませんか?
2018/07/05(木) 13:05:53.34ID:I27lRIcu
>>16
64bitでコンパイルされたし
64bitでコンパイルされたし
18はちみつ餃子 ◆8X2XSCHEME
2018/07/05(木) 14:58:16.26ID:l9X7uzb+ 実メモリが載ってなきゃ意味ないぽよ。 とマジレス。
まあ今どきはそういうデスクトップマシンも無くはないけど……。
まあ今どきはそういうデスクトップマシンも無くはないけど……。
2018/07/05(木) 15:06:00.77ID:ppxwAApK
(vc ってあるから Windows 前提で)
malloc のアロケーターの実装とセットになって
OS がよきに計らってくれないものなのかな
malloc のアロケーターの実装とセットになって
OS がよきに計らってくれないものなのかな
2018/07/05(木) 15:43:13.14ID:I5nj7cYg
20億バイトって約2GB、31bitで表せる範囲ではあるのか。
プロセスあたりメモリ2GBの制限に引っかかってるのかな。
この20億バイトのmallocの他にもメモリを使っててトータル不足とか。
プロセスで使えるメモリを3GBにする設定とかあるんだっけ。
あとはOSを64bitにするか。
プロセスあたりメモリ2GBの制限に引っかかってるのかな。
この20億バイトのmallocの他にもメモリを使っててトータル不足とか。
プロセスで使えるメモリを3GBにする設定とかあるんだっけ。
あとはOSを64bitにするか。
21はちみつ餃子 ◆8X2XSCHEME
2018/07/05(木) 18:08:24.53ID:l9X7uzb+ あ、 20 億ってたったの 2GB か。
でもまあメモリ空間が足りないとどうしようもないよな。
でもまあメモリ空間が足りないとどうしようもないよな。
2018/07/05(木) 18:41:17.96ID:HIMx+eV5
そらプロセス起動してんだから
mallocでプラス2GBとか普通は32bitじゃ無理
mallocでプラス2GBとか普通は32bitじゃ無理
2018/07/05(木) 19:23:00.99ID:I5nj7cYg
実際にやったわけじゃないけど、軽く調べたところ、
32bitのWindows上のプロセスで2GBより大きなメモリを使うためには…
・OSの動作モードを「カーネルで1GB, プロセスで3GB」のメモリ配分に変更
・リンク時にオプション /LARGEADDRESSAWARE を指定
…という具合に、動作環境と実行ファイルの両方での対処が必要みたい。
さらに加えると、Win32APIの HeapAlloc() を使わないとダメかも。
これはライブラリの malloc() がどう実装されてるかによるが。
32bitのWindows上のプロセスで2GBより大きなメモリを使うためには…
・OSの動作モードを「カーネルで1GB, プロセスで3GB」のメモリ配分に変更
・リンク時にオプション /LARGEADDRESSAWARE を指定
…という具合に、動作環境と実行ファイルの両方での対処が必要みたい。
さらに加えると、Win32APIの HeapAlloc() を使わないとダメかも。
これはライブラリの malloc() がどう実装されてるかによるが。
2018/07/05(木) 21:08:35.41ID:IGtLSuPP
64bitでコンパイルしたらいけますた。
2018/07/06(金) 18:04:52.14ID:zA1tf/7d
2018/07/06(金) 18:42:29.85
for( a : コンテナ)ってしたときのアクセスは内部的にどうなってるんですか?
@コンテナのat(size_t)を呼び出している
Aコンテナにイテレータがあればイテレータ
Bコンテナにイテレータがなくat(size_t)があればat
@コンテナのat(size_t)を呼び出している
Aコンテナにイテレータがあればイテレータ
Bコンテナにイテレータがなくat(size_t)があればat
2018/07/06(金) 19:28:48.49ID:cmD7yKAf
生配列の場合は*<配列のポインタ>、
コンテナ.begin()が定義されていれば*<コンテナ.begin()が返却するもの>、
そうでなければ*<std::begin(コンテナ)が返却するもの>
で要素アクセスする。
at()はオーバーヘッドがあるので、forに限らず、将来的にもコンパイラが知らぬうちに呼びだすことはないと思うよ。
コンテナ.begin()が定義されていれば*<コンテナ.begin()が返却するもの>、
そうでなければ*<std::begin(コンテナ)が返却するもの>
で要素アクセスする。
at()はオーバーヘッドがあるので、forに限らず、将来的にもコンパイラが知らぬうちに呼びだすことはないと思うよ。
2018/07/06(金) 19:39:02.31
atしかなかった場合は!?
2018/07/06(金) 20:28:34.00ID:cmD7yKAf
コンパイルしてみろ。答えは3秒で分かる。
30はちみつ餃子 ◆8X2XSCHEME
2018/07/06(金) 21:43:33.68ID:G+eTHi8Q >>26
begin 関数と end 関数で帰ってくるイテレータで繰り返すようになってる。
標準ライブラリにあるコンテナの場合は std::begin と std::end が適用されて、
これは基本的にはそれぞれのコンテナのメンバ関数 begin と end をそのまま呼び出すが、
配列などのために特殊化した版が用意されている。
自分が独自に作ったコンテナを range based for に対応させたい場合は、
メンバ関数として begin と end を持っておけば std::begin と std::end 経由でそれが呼び出されるし、
非メンバ関数としてそのコンテナの型を受け取れる begin 関数と end 関数を用意してもよい。
どの名前空間にある begin 関数と end 関数が呼び出されるかは ADL で解決されるんだが、
このあたりの理屈は面倒なんで ADL をキーワードにしてググって。
独自に用意したコンテナについて、やりたければ at を呼び出すように作ることはもちろん出来るよ。
既存のコンテナについても、 std::begin と std::end を特殊化すれば、現実には挙動を変えられたりもするが、
std 名前空間にある関数をオーバーロードすることは禁止されていて、
std 名前空間内のテンプレート関数の特殊化も (全面的に禁止ではないが) 制約があるので、
規格の範囲内ではカスタマイズすることは出来ないと考えて良い。
begin 関数と end 関数で帰ってくるイテレータで繰り返すようになってる。
標準ライブラリにあるコンテナの場合は std::begin と std::end が適用されて、
これは基本的にはそれぞれのコンテナのメンバ関数 begin と end をそのまま呼び出すが、
配列などのために特殊化した版が用意されている。
自分が独自に作ったコンテナを range based for に対応させたい場合は、
メンバ関数として begin と end を持っておけば std::begin と std::end 経由でそれが呼び出されるし、
非メンバ関数としてそのコンテナの型を受け取れる begin 関数と end 関数を用意してもよい。
どの名前空間にある begin 関数と end 関数が呼び出されるかは ADL で解決されるんだが、
このあたりの理屈は面倒なんで ADL をキーワードにしてググって。
独自に用意したコンテナについて、やりたければ at を呼び出すように作ることはもちろん出来るよ。
既存のコンテナについても、 std::begin と std::end を特殊化すれば、現実には挙動を変えられたりもするが、
std 名前空間にある関数をオーバーロードすることは禁止されていて、
std 名前空間内のテンプレート関数の特殊化も (全面的に禁止ではないが) 制約があるので、
規格の範囲内ではカスタマイズすることは出来ないと考えて良い。
2018/07/06(金) 22:06:07.41
>>30
詳しい情報サンクス
詳しい情報サンクス
2018/07/06(金) 23:15:55.05ID:4kvIcx8n
>>28
あっと驚く
あっと驚く
33デフォルトの名無しさん
2018/07/07(土) 14:03:43.69ID:0Eyv8LqD ストラウストラップのプログラミング言語C++を読んでいるのですが、
auto を使えとか、
int a = 1;
よりも
int a {1};
のほうがいいだとか、書いてありますが、本当にこれにしたがったほうがいいのでしょうか?
他の本とスタイルが違うように思います。
auto を使えとか、
int a = 1;
よりも
int a {1};
のほうがいいだとか、書いてありますが、本当にこれにしたがったほうがいいのでしょうか?
他の本とスタイルが違うように思います。
2018/07/07(土) 14:47:52.08ID:cKmJS2is
いいよ。問題ない。
c++11以降はそっちが推奨。
ただ会社で使うと周りがついてこれないから直せと言われるかもしれない。
c++11以降はそっちが推奨。
ただ会社で使うと周りがついてこれないから直せと言われるかもしれない。
35デフォルトの名無しさん
2018/07/07(土) 14:59:47.53ID:0Eyv8LqD >>34
ありがとうございました。
ありがとうございました。
36デフォルトの名無しさん
2018/07/07(土) 15:18:56.50ID:kLxolQc6 ITドカタになりたいなら
現場のコーディング規約に従いなさい
ドカタになりたいのにドカタのオキテに従わないのよくない
ドカタにしばかれるぞ
現場のコーディング規約に従いなさい
ドカタになりたいのにドカタのオキテに従わないのよくない
ドカタにしばかれるぞ
2018/07/07(土) 17:06:51.18ID:n3/QBjsU
土方になりたいやつはJSやれ
2018/07/07(土) 18:24:29.21ID:ZyYEp/bp
整数の宣言時の初期化はどう書くのがオヌヌメなん?
int a = 100;
int b(200);
int c{300};
俺は昔はaで統一してて最近はbに統一してるけど、なんとなく
int a = 100;
int b(200);
int c{300};
俺は昔はaで統一してて最近はbに統一してるけど、なんとなく
2018/07/07(土) 19:03:20.75
三行目から初期化という強い意志を感じる
2018/07/07(土) 19:16:59.45ID:jTEKSr/V
2018/07/07(土) 20:05:35.82ID:ZyYEp/bp
2018/07/07(土) 20:06:57.40ID:ZyYEp/bp
2018/07/08(日) 05:39:41.64ID:eeyKvEjW
てす
2018/07/13(金) 19:58:04.79ID:Tk69mgcl
ASCIIコードのエスケープ文字列を変換してくれる標準関数ってなかったっけ?
2文字の "\n" を 1文字の 0x0a に変換してくれるような
2文字の "\n" を 1文字の 0x0a に変換してくれるような
2018/07/13(金) 20:32:11.29ID:xmTV0Hfm
寝言は寝てから言え
2018/07/13(金) 22:01:52.96ID:gLGTmgps
\nは1文字だぞ、と何故教えてやらないのか
2018/07/13(金) 22:11:34.91ID:Da3sJv8m
ソース中の \n はプリプロセッサが変換してくれるけど
標準入力とかの外部入力から \ n (0x5c 0x6e) を渡して
それが 0x0d になって欲しいんじゃないの?
標準入力とかの外部入力から \ n (0x5c 0x6e) を渡して
それが 0x0d になって欲しいんじゃないの?
2018/07/13(金) 22:16:42.49ID:Tk69mgcl
2018/07/13(金) 22:18:40.10ID:7IjJ2GkE
>>44
sprintfに渡したらいかんのか?
sprintfに渡したらいかんのか?
2018/07/13(金) 22:20:13.96ID:Da3sJv8m
あうち 0x0a だった
いずれにしろ標準関数にはないね
いずれにしろ標準関数にはないね
2018/07/13(金) 22:20:23.02ID:7IjJ2GkE
ごめん、その変換はコンパイラの仕事か。
53デフォルトの名無しさん
2018/07/20(金) 11:04:37.70ID:o8SFlR7J ロベールの本を読んでいます。
メンバ関数ポインタについて質問です。
int (*Calculator::mfp)();
int (Calculator::*mfp)();
のどちらが正しいかという話が書いてあります。
「
あとは「どこに」つけ足すかですが、これは簡単に考えると2種類考えられます。
int (*Calculator::mfp)();
int (Calculator::*mfp)();
しかし、静的メンバ変数として普通の関数ポインタを作った場合を考えると、前者
では問題があることが分かります。
typedef を使わず静的メンバ変数として普通の関数ポインタを作ると次のようになります。
class Calculator {
public:
static int (*mfp)();
};
int (*Calculator::mfp)();
静的メンバ変数の実態を定義する時には変数名の前に Calculator:: をつける必要があります。
しかし、もし前者の宣言法が正しいのであれば、この静的メンバ変数の実体定義と区別
がつきません。これでは困りますね。
ということで、後者の宣言法が正しいと推測されます。
」
メンバ関数ポインタについて質問です。
int (*Calculator::mfp)();
int (Calculator::*mfp)();
のどちらが正しいかという話が書いてあります。
「
あとは「どこに」つけ足すかですが、これは簡単に考えると2種類考えられます。
int (*Calculator::mfp)();
int (Calculator::*mfp)();
しかし、静的メンバ変数として普通の関数ポインタを作った場合を考えると、前者
では問題があることが分かります。
typedef を使わず静的メンバ変数として普通の関数ポインタを作ると次のようになります。
class Calculator {
public:
static int (*mfp)();
};
int (*Calculator::mfp)();
静的メンバ変数の実態を定義する時には変数名の前に Calculator:: をつける必要があります。
しかし、もし前者の宣言法が正しいのであれば、この静的メンバ変数の実体定義と区別
がつきません。これでは困りますね。
ということで、後者の宣言法が正しいと推測されます。
」
2018/07/20(金) 11:05:07.69ID:o8SFlR7J
何が言いたいのか分かりません。
■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 「こども2万円給付」は“ずるい”?「子持ちだけ優遇されてる」「来年から独身税もあるのに」…子育て世帯への支援は“不公平”なのか [♪♪♪★]
- 「PC買うなら急げ」は本当だった。マウスが一部販売停止&1月値上げを発表 [♪♪♪★]
- 【東京】赤坂サウナ火事2人死亡 サウナ室のドアノブ外れ閉じ込められた可能性 ★5 [nita★]
- 【速報】 ロシア潜水艦が攻撃されて巨大水柱 [お断り★]
- 【赤坂サウナ店火事】死亡男女は川崎市在住の夫婦 ドアノブ内側も外側も外れ、閉じ込められたか [ぐれ★]
- “つり目”騒動の中…駐日フィンランド大使館が声明「人種差別と闘う」「数多くの意見や質問が」 [少考さん★]
- 東京都「お願いパンダレンタルさせて!!!😭」中国「🥴」 [817260143]
- 【悲報】ワイ、一蘭で外人に怒鳴られるwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwww [455031798]
- おまいらボーナスで何買った? or 好きな寿司(´・ω・`) [399259198]
- 3時のおやつ🧁はふなキャンディー🍬🏡
- フィフィ「中国に頭下げてまで日本でパンダが見たいか?」「見たい人は中国行けば?」高市正論 [153490809]
- 【高市悲報】記者「中国は別の方法でも通告したと言ってるが?」小泉の進さん「…問題の本質はそこじゃない😤」 [359965264]
