[表示 : 全て 最新50 1-99 101- 201- 301- 401- 501- 601- 701- 2ch.scのread.cgiへ]
Update time : 12/28 20:22 / Filesize : 177 KB / Number-of Response : 736
[このスレッドの書き込みを削除する]
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧] [類似スレッド一覧]


↑キャッシュ検索、類似スレ動作を修正しました、ご迷惑をお掛けしました

C/C++ゲーム製作総合スレッド Part7



1 名前:名前は開発中のものです。 mailto:sage [2015/01/11(日) 10:19:31.85 ID:RDQlUyF+.net]
ゲーム製作におけるC/C++全般に関するスレです。

元スレ
DXライブラリ 総合スレッド その18
peace.2ch.net/test/read.cgi/gamedev/1399459468/

前スレ
C/C++ゲーム製作総合スレッド Part1
toro.2ch.net/test/read.cgi/gamedev/1337516528/
C/C++ゲーム製作総合スレッド Part2
toro.2ch.net/test/read.cgi/gamedev/1351015269/
C/C++ゲーム製作総合スレッド Part3
toro.2ch.net/test/read.cgi/gamedev/1357899040/
C/C++ゲーム製作総合スレッド Part4
toro.2ch.net/test/read.cgi/gamedev/1376262450/
C/C++ゲーム製作総合スレッド Part5
peace.2ch.net/test/read.cgi/gamedev/1389798031/
C/C++ゲーム製作総合スレッド Part6
peace.2ch.net/test/read.cgi/gamedev/1404815419/

289 名前:名前は開発中のものです。 mailto:sage [2015/02/08(日) 13:58:02.91 ID:uih1DHvo.net]
mallocのメモリ配置はOSで変わるんじゃなくてコンパイラで変わるみたいやね

290 名前:名前は開発中のものです。 mailto:sage [2015/02/08(日) 15:05:56.00 ID:OpMqb989.net]
依存するのはコンパイラじゃ無い
ランタイム依存

291 名前:名前は開発中のものです。 mailto:sage [2015/02/09(月) 20:39:13.54 ID:q5WWprzE.net]
なんにせよ、ポインタはむやみにいじらない方がよさそうね

292 名前:名前は開発中のものです。 mailto:sage [2015/02/10(火) 22:00:30.08 ID:Lg1oqTmd.net]
ポインタは使い勝手がわかると色々出来るが、無くても問題無くなってきてるからなぁ……

293 名前:名前は開発中のものです。 mailto:sage [2015/02/10(火) 23:49:52.25 ID:2hfNPcff.net]
それなりのもの作ろうとしたらアロケーター自作になるゲーム制作はポインタ必須なんじゃないの

294 名前:名前は開発中のものです。 mailto:sage [2015/02/10(火) 23:59:52.09 ID:m/pIKos0.net]
プラットホームによるとは思うが、いまだにカスタムアロケータなんて使うのか?
OSや言語処理系を書いているわけではないだろうに

295 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 00:01:51.67 ID:7TGiUCxx.net]
車輪の再発明が好きなんだろ

296 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 00:26:12.68 ID:IKslX+U4.net]
流石にOSデフォルトのアロケーターは使わないんじゃないの
ライブラリのメモリプール使うにしてもポインタは使うだろうし

297 名前:名前は開発中のものです。 [2015/02/11(水) 00:38:39.31 ID:5bVnp7SH.net]
アロケーターはC言語かSTLのやつのことだろ?
OS自体のメモリ管理はOS自体のソースからビルドしないと変更むりでは。



298 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 00:41:52.28 ID:IKslX+U4.net]
普通にnew、deleteしたらOSのAPIでメモリ確保

299 名前:するんでないの?
STLはどうかわからんけど
[]
[ここ壊れてます]

300 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 00:51:21.24 ID:rJC6nJDr.net]
>>289
mallocの置き換えぐらいリンクするライブラリー変えるだけだよ
tcmallocでググれ

301 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 00:52:08.05 ID:vZk9YDm5.net]
new deleteの動作なんて実装によるとしか言いようがない
STLのstd::allocator<T>の話なら、単にnewとdeleteを呼び出す実装になってる

302 名前:名前は開発中のものです。 [2015/02/11(水) 00:59:11.50 ID:5bVnp7SH.net]
mallocやnewを置き換えてもOSの命令を使ってたら
OS自体のメモリ管理の制約は受けるわけで。
OSと完全に独立できるものか?
OSが既に管理してるところを横取りしないとならないが。

303 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 01:01:23.93 ID:WPu+kv42.net]
ちょっと前に「ゲームの場合、出現オブジェクトの個数に上限を設けることが多いから
new deleteせず自分でプールを確保する手もある」という話をしなかったっけ。

とりあえずstd::allocator<T>で書いといて、あとでカスタム化してもよいのでは。

304 名前:名前は開発中のものです。 [2015/02/11(水) 01:03:22.28 ID:5bVnp7SH.net]
malloc - Wikipedia

OSのカーネルでもアプリケーションと同様にメモリ確保が必要である。
カーネル内にもmalloc相当の関数はあるが、その実装はCライブラリのものとは大きく異なる。
例えば、DMA用のバッファには特別な制限が課せられることがあるし、割り込み処理でメモリを動的に確保したい場合もある。
このため、カーネルの仮想記憶サブシステムと密に連携した malloc 実装が要求される。

305 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 01:04:29.98 ID:rJC6nJDr.net]
余程特殊な用途でないかぎり既成の物使った方が速いから

306 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 01:06:40.34 ID:IKslX+U4.net]
自作アロケーターは最初に領域確保してその分を切り盛りするでしょ
ていうかそれ以外の作り方を知らない

307 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 01:06:46.81 ID:rJC6nJDr.net]
>>295
スレ違い
お前はゲームをOSから作るんか?



308 名前:288 [2015/02/11(水) 01:16:23.87 ID:5bVnp7SH.net]
>>288に対して、自作アロケータ、マイアロケータってのは
ほとんどのケースで、OSデフォルト、カーネルアロケータに依存してるだろ?って反応なわけで。

309 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 01:32:15.63 ID:rJC6nJDr.net]
そうだな
>>288
が言ってるOSデフォルトってのが悪かった。
アプリケーションが使うメモリアロケーターの殆どの実装はライブラリが行ってる。
OSからシステムコールでブロック単位でメモリを貰いアプリケーション内で分配な。

310 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 01:41:17.25 ID:IKslX+U4.net]
すんませんVC++のメモリ確保がWin32APIの関数呼ぶだけって何かで見たからそういうもんだと思ってました

311 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 01:49:31.11 ID:tga+SBCo.net]
>>297
アプリケーションとしてのゲームはこれで確定だと思ってた
動的と言えば動的だけど都度都度確保はあり得ないって意味でこの手の話はスルーしてたけど、そう言うものでも無いみたいだと知ったわ
取れなかった場合の処理は思い付かないけど

312 名前:名前は開発中のものです。 [2015/02/11(水) 01:55:07.09 ID:5bVnp7SH.net]
ヒープ、動的確保は丸投げに近いが。普通のauto変数とかは最初に確保した領域を使いまわす。



メモリの4 領域
brain.cc.kogakuin.ac.jp/~kanamaru/lecture/MP/final/part06/img6.png
brain.cc.kogakuin.ac.jp/~kanamaru/lecture/MP/final/part06/node8.html

テキスト領域:機械語に翻訳されたプログラムが格納される. この機械語の命令が 1 行づつ実行されることでプログラムが動く。

静的領域:グローバル変数などの静的変数が置かれる。

ヒープ領域:メモリの動的管理 (C 言語の malloc 関数や C++ の new 演算子でメモリを確保すること) で用いられる。

スタック領域:今回の演習で扱ったように CPU のレジスタを一時的に退避させたり、また C 言語の自動変数 (

313 名前:多くのローカル変数) が置かれる。 []
[ここ壊れてます]

314 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 02:24:49.00 ID:COJ2IR9k.net]
いわゆるメモリープールのようなものは既にランタイムに実装されてる場合もあるし
自分で実装する・しないは実行環境によると思う。
最近はこの辺のことは既に当たり前になってるのかどうか知らないけど、
検索してもあまり引っかからないね。とりあえず引っかかったところ
vcpp-ml.ldblog.jp/archives/1169943.html
ではVCのランタイムのソースみればとなってるので
興味ある人は読んでみては。

315 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 02:41:42.58 ID:0cWu/C1d.net]
俺が昔作ったベンチ引っ張り出してきた
10000個確保して解放を1セットで、10回繰り返す

malloc 0.0104349686516726 100
new 0.0170437163409596 163.332702856062
tlsf 0.0327989992535455 314.318138831095

右側がmallocを100とした場合の倍率。意外とtlsfは遅い。
んで下が自作のメモリアロケータでnewとdeleteをオーバーロードしてて
上で使ったnewするソースをそのまま使ってる。

fixpool 0.01086365697986310 104.108189899754
fixpool-ss 0.00270476282206395 25.9201815774541

アルゴリズムは一回使ったものをリストにつなげておいて、newのとき取り出すだけ。
ssは上限が分かっている場合で、先にメモリ確保するのでmallocを上回れる。

まぁ、はっきり言って速度だけを考えると自作アロケータの必要はないかなレベル・・・と思う。
確か、スマートポインタのベンチもどっかにあったはずなんだが、どこだったか・・・

316 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 02:52:05.14 ID:IKslX+U4.net]
>>304
ゲームエンジン&#8226;アーキテクチャ(ソフトバンククリエイティブ)によれば、デフォルトのnewが遅い理由は管理コストとOSのコンテキストスイッチとあるけど
URL先の内容からすると最初に確保された分越えなければコンテキストスイッチは発生しないって事なんかな
ていうか2000年の時点でそういう仕様だったのか

317 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 02:52:16.60 ID:rJC6nJDr.net]
>>305
その自作アロケーターって複数スレッドから呼んでも大丈夫なように作ってんの?
だったらたいしたもの。

今時モバイルですらマルチスレッドが当たり前だからベンチマークも複数スレッドで実行すべき。
スレッド使うライブラリーをリンクしないとシングルスレッド版のmallocとリンクする環境もあるし



318 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 03:06:07.85 ID:rJC6nJDr.net]
>>306
ライブラリが貧弱な環境だと効果はあったんじゃない?
ライブラリが貧弱で有名だったPS3とか。
ゲームエンジン アーキテクチャって本PS専門デベロッパーだった人の著書みたいだし

319 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 03:24:52.81 ID:tga+SBCo.net]
>>307
データ読み込みや通信で「now loading…」、ムービー再生とか以外でマルチスレッドって何に使うの?
いろんな判定でシングルでないと困らない?
俺はコンシューマ長すぎのせいか、マルチスレッド(タイムスライス型)は、そもそもゲームシステムとして実装が思い付かない
どうしてもタスク()で疑似マルチしか作れないや

320 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 03:29:13.74 ID:0cWu/C1d.net]
>>307
ポインタのつなぎ替えの部分に一応クリティカルセクション使ってる。
が、これのベンチがねぇ・・・
複数スレッドで同時に確保しまくって人為的にコリジョン起こしても、
シングルの場合と違って純粋な値が取れないので。

321 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 03:54:41.50 ID:0cWu/C1d.net]
スマポあった。同じく10000を10回。

new 0.00696283003770957 100
sha

322 名前:red_ptr 0.039324851409757 564.782584046715

生ポインタとboostのshared_ptrね。
下が自作のリンク方式とカリカリにチューンした参照カウント方式のスマートポインタ。

link 0.0273835524999122 393.281932082318
count 0.0157994938635595 226.911956460117

これも、安全をとるなら生より多少遅くてもboostで十分と思う。
自作のスマポは労力の割にはねぇ。
[]
[ここ壊れてます]

323 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 04:10:32.63 ID:0cWu/C1d.net]
書き忘れてた。>>305はゲームに近いように
10000まで{ 4, 10, 20, 100, 208, 501 }のサイズを巡回して確保していってる。

>>311は同じオブジェクトをずーっと生成してる。
こうするとnewがなぜか結構速いんだけど、その状態で対決してみたかったので。

324 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 08:00:15.92 ID:JqfHYvpf.net]
んーなんか車輪の再発明がどんどん無駄になってくのな
必要な機能が既存のコードにあるなら、わざわざ作る必要は無い、みたいな

325 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 08:08:59.24 ID:JqfHYvpf.net]
自分は今は自作コンパクションを使ってるけど、これも誰かの作ったコードを流用した方が早い時代が来るのかな?

326 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 08:40:48.37 ID:45+5SbHz.net]
>>309
MTフレームワークの例
www.4gamer.net/specials/3de/lost_planet/lost_planet_04.shtml

327 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 13:02:10.23 ID:tga+SBCo.net]
>>315
これの詳細を知ってるが、レンダリングはPCだとGPU処理だから、マルチスレッドとは別で非同期でしょ?
それ以外は先程書いた通り
因みにこのフレームワークは自動変数(スタック)以外はメモリは静的に持ってるよ



328 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 13:10:49.29 ID:vZk9YDm5.net]
ガチな将棋AIとか作ることになったらやっぱりCPUスレッド数のスレッド作って読みを分散するんじゃなかろうか

329 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 13:40:34.62 ID:sOoti607.net]
どうせなら複数マシンに分散させるべき

330 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 14:57:37.67 ID:/JcbXeo3.net]
そもそもメモリ管理なんて個人でやるものじゃないよ
せいぜいオブジェクトプールのように局所的なところで使ったほうがいい
自作アロケータを使ってみたい気持ちはわかるんだけどねぇ

331 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 15:06:24.20 ID:rJC6nJDr.net]
>>309
シングルスレッドでパフォーマンス十分なら要らないんじゃない?
その場合アロケーター自作しようとする理由すら解らなくなるけど。

レンダリングスレッドを分けるってのは比較的簡単だからよく使われてる方法だね。
グラフィックスのAPIが全て非同期という訳でもないし、呼ぶ事自体比較的コストが高いものもあるドローコールとか
あとGPUが全てやってくれるわけでもない。
影とかモデルの持ってるマテリアルによってはマルチパスレンダリングが必要になるしね
それら含めて一つの独立したスレッドでレンダリングを行うって事
どこまでやるかはそれぞれのゲームエンジンの実装次第だけど

332 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 20:31:12.70 ID:IKslX+U4.net]
PS3なんかはは汎用コアが貧弱でマルチスレッド使わないとまともに動かないらしいけど
PCはターボブーストなんかもあるし処理分割しなくてもそれなりに動くのかね
ゲームで重い処理って言ったらAIとか物理演算とか?
それらやらなきゃコア使い切る事もなさそう

333 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 22:28:39.42 ID:o3rdwdSA.net]
自分の場合、(作ったのはC#とXNAだったけど)

・更新
非同期・4体のキャラの思考ルーチンをマルチスレッドで(他のキャラの状態は前フレームのものを利用)。
同期・同時に行う必要のある判定類。
非同期・4体のキャラのアニメーション演算(*)

・描画(スキップされることがある)
非同期・キャラの描画コマンド発行(ただし、4体それぞれに(*)を同期)。(**)
同期
非同期・背景などの描画。

・更新
※未了のタスクがあればいったん待機して、最初と同じ。

ということはやっていた。じつはXNAは(**)が異様に重くなるというハンデ持ちで、
(*)はC++だろうと当然重いはずだから、パフォーマンス上がると思うよ。

334 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 22:33:55.73 ID:o3rdwdSA.net]
連投悪い。

というか、マルチコアのCPUなのにシングルで動作させてるって、同人ならともかく
商用ゲームだとハードを全然使いこなせていないんじゃないの。

仮にPS3相当かそれ以上のハードで、シングルで楽々動くゲームがあるとしたら、
それは「CPUスゲー!」じゃなくて「CPUを遊ばせている未熟なプログラム」
もしくは「絵的にボリューム不足」「敢えてシンプル路線のゲームにしただけ」だと思う。

335 名前:名前は開発中のものです。 mailto:sage [2015/02/11(水) 23:00:37.92 ID:DLujIAOi.net]
妖精左「マルチスレッド!!」
妖精右「マルチタスク!!」
俺「じっそうできればいいから・・・」
部長「ま だ か は や く し ろ 。」

336 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 00:02:20.82 ID:ebWGGwik.net]
>>323
C#なんて全然ハード生かせないだろC++で作れよ

337 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 00:29:15.74 ID:DJBGtoR8.net]
C++至上主義の時代はもう終わった



338 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 00:32:29.34 ID:UV0J6V6h.net]
まだだ!まだ終わらんよ!

339 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 02:23:42.32 ID:U9NT4imE.net]
さっき始まったばかりですよ

340 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 02:30:04.64 ID:rNOcVIpi.net]
>>323
たしかにC#だと、ネイティヴDirectX呼び出す時点でカーネル切替が発生し、ボトルネックになる
(ただ一方、GCはちょっと工夫すればシーン切替時以外は抑制できる)。

まあC++が最強という事実は揺るがないし、だからここを覗きに来てるんだけど
今まで作った資産をそっくり移植するのは全部1人開発だと工数的に厳し過ぎるんよ。
自分はあくまでゲームを完成させるのが主眼なもんで。

341 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 02:30:45.99 ID:rNOcVIpi.net]
>>325だった。

342 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 09:37:50.92 ID:ebWGGwik.net]
>>329
> 仮にPS3相当かそれ以上のハードで、シングルで楽々動くゲームがあるとしたら、
> それは「CPUスゲー!」じゃなくて「CPUを遊ばせている未熟なプログラム」
> もしくは「絵的にボリューム不足」「敢えてシンプル路線のゲームにしただけ」だと思う。

こんなこと言う人間が

> 自分はあくまでゲームを完成させるのが主眼なもんで。

なんてよく言えるな

343 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 09:58:41.94 ID:DJBGtoR8.net]
Unityの台頭とC++erの更なる没落

344 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 10:00:56.62 ID:K+V6X3Ce.net]
社員さん、ステマ乙

345 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 10:16:24.93 ID:xZrWsSkn.net]
世界は使いやすい道具の前にひれ伏す
これが分からない奴は一生地を這う

346 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 10:44:14.01 ID:K+V6X3Ce.net]
Unityあつかいづらいから自分でライブラリ作ったわwww

347 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 12:11:18.44 ID:ZP/aF8VN.net]
アホか。

みなが同じ道具を使ったら、それを売って儲ける奴の小作農になるだけ。
これが分からない人こそ

>一生地を這う



348 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 12:13:54.04 ID:ZP/aF8VN.net]
>>331
>>323はあくまで>>321に対する客観的な指摘。
それと「自分はあくまでゲームを完成させるのが主眼なもんで」は別問題だよ。

349 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 13:25:06.24 ID:0nYHwL7l.net]
実際PS3の初期タイトルは酷いの結構あったな
アイデアファクトリーとか

350 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 15:23:29.14 ID:gRG035Lb.net]
作るものに応じて道具を選べない人が一生地を這うのでは

各処理をどんだけ細切れにしても結局全部処理しないと次には進めず、
しかも実は単一の処理は積み重ねても大して時間はかかっておらず、
単なるスレッドの立て損にしかなっていないんならマルチスレッドなんか不要
商業だからだのなんだのと適当な言い訳をしても、
実際は目に付くよさそうに見えるものに振り回されているキョロ充
まずは作りやすい方法で実装してテストして、ダメだったら作り直せばいいじゃん

351 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 17:28:07.56 ID:K+V6X3Ce.net]
Unityの社員ってステマのノルマがあるみたい

352 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 17:41:44.09 ID:3BvTygsz.net]
スレッドのが実装しやすい処理もあると思うの

353 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 19:41:03.02 ID:gRG035Lb.net]
うにちゃんは次期主力ゲームエンジンの座を狙っているからね、仕方ないね

何が悲しくてわざわざ柔軟な使い方のできる言語投げ捨ててゲームエンジンなんぞに…
PHPやらJAVAやらに行った方がマシ

354 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 20:21:56.36 ID:K+V6X3Ce.net]
そんなに自信があるのなら、自分たちでゲーム機を出せばいいのに
彼らの夢は、所詮は砂上の楼閣なんかね

355 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 20:26:40.79 ID:EbJGy+Ll.net]
このスレってレベル低いよな

356 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 20:29:07.88 ID:EbJGy+Ll.net]
>>339
出来ることは並列でやった方が早く終わるよね。

357 名前:名前は開発中のものです。 [2015/02/12(木) 20:35:29.18 ID:wNE8sYSh.net]
>>343
それは無理。彼らの夢は、ゲーム業界に巣喰う寄生虫になる事だから。



358 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 20:42:55.10 ID:K+V6X3Ce.net]
>>345
その前にアルゴリズムを考えた方が早いかもね

359 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 21:16:05.40 ID:SEu5lClB.net]
シングルスレッドで足りるならシングルスレッドで作ればいいと思う
後からマルチスレッドにしようとか考えたら地獄みるけど
ムダに作り込んで時間かけても仕方ないしね

360 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 21:57:58.62 ID:5lpYcWcf.net]
スレッドの話で盛り上がってるけど、みんなpromiseとかatomicとかcasとかちゃんと理解できてる?
俺は半分も理解してない

361 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 22:02:24.65 ID:BY0ie4C4.net]
C++を書いているとJavaやC#にだんだん似てくるし
C++で便利コードを書いても既存のライブラリには適わないし
C++でゲーム用ライブラリを書いていると既存のエンジンに似てきたから
既存のエンジン使うことにした。困ったらエンジン改造すればいい。

362 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 23:13:41.81 ID:X8c9QSvd.net]
おーい、誰かクマが釣り針見つめてるAA持ってない?

>>349
promiseはFutureパターンのSTL実装かな。
casは不勉強だったわ。いちいちロックしなくても非同期でノード更新できるってことかな。

363 名前:名前は開発中のものです。 mailto:sage [2015/02/12(木) 23:54:36.97 ID:yCMGD6Md.net]
casって言われてもメモリのclしか思いつかないです
これの事でいいの
ja.m.wikipedia.org/wiki/コンペア・アンド・スワップ

364 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 00:16:59.27 ID:6pLn2rnq.net]
visual c++2010です
コードを書いていると、未定義エラーなどのエラーが起こっている部分を波線で表示する機能がありますが
それをすばやく表示したい(エラーを確認する間隔を早めたい)時はどうすればいいのでしょうか?
オプションでそれらしき項目を探しているのですが、見つけられず困っています…

365 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 00:28:10.25 ID:FqU8O5pj.net]
今表示されてる速度が最速だよ
文句があるならもっと早いCPUに代えろ
もしくはVSのバージョン上げたら改善される可能製はある

366 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 00:38:48.23 ID:PNw/R4Nn.net]
何が原因かわからんが仮にnullpoって変数なり型名なりがあるとしてpoにだけ下線とエラー表示が出る謎現象なんかが困る
nullpoの間にスペース入れた後に消すなりコンパイルするなりして文字解析をやり直させると普通に通る

367 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 00:38:56.82 ID:6pLn2rnq.net]




368 名前:ありがとうございました []
[ここ壊れてます]

369 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 02:11:39.11 ID:E1xWFoJ9.net]
コードを書いてるといきなり妙な場所に波線
面食らいつつ原因を探るべくコードを見直しているといつの間にか消える
他にも指摘されて修正した部分の波線がなかなか消えず、
あれ?修正間違ったかなと書き直そうとすると消えたりする

VSに不信感を抱きそう

370 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 03:15:03.66 ID:Jw6U7GOH.net]
VS2010より2012, 2013はずっと賢いから変えたほうがいい
あとVSの謎の挙動はコードが悪いせいなのできちんと書くように心がけましょう

371 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 03:17:28.00 ID:Jw6U7GOH.net]
いつもコードが悪いせいではないな
一括置換とかファイル名変更とか,変なことをやるとVSたんはたまにアホになる

372 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 03:36:37.36 ID:PNw/R4Nn.net]
というわけでついっさっきVS2013導入したった
C++で打ってる時2010だとショートカットキー(Alt→派)でしかインテリセンス出なかったのが改善されてるのが今のところ一番嬉しい

373 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 04:37:35.15 ID:diYHW0ok.net]
外部エディタを使っている自分に隙はなかった

374 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 09:12:51.03 ID:PRy9EczC.net]
どんなスペックのPC使ってんの

375 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 10:50:31.89 ID:WvS4Hu4Q.net]
JavaやC#ならわかる
だが負の遺産であるクソ構文抱えたC++で
実用的な速度であれだけのことが出来ることそのものが信じられん
動いたらラッキーくらいの謙虚な気持ちで使うべき

376 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 11:23:05.70 ID:/fWsfy1c.net]
C++とC#ってそんなにちがうか??
C++って多少手間暇かかる部分はあるが、自前で組めばどうにでもなる事でね?

まあ、プログラムはソースの書き方だけで作る時間に10倍以上の差が出るし、
モジュールやオブジェクト指向を理解してるかどうかで100倍以上の差が出るから、
その辺りの違いだろうけどな。

377 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 11:25:59.01 ID:NjULDeHN.net]
MSがBC++を買っとけば世界が平和になってたんですよ…



378 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 12:17:28.61 ID:oAXnXeHu.net]
学習コストの高い言語はもう流行んないでしょ
ゲームもコア部分以外はスクリプトで書くのが主流になるだろうし
C++プログラマはゲームエンジン書けるレベルの人しか生き残れないな

379 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 13:34:54.76 ID:/fWsfy1c.net]
パソコン自体がもうほとんど進化しなくなったのに、遅い言語を勧められてもな

380 名前:名前は開発中のものです。 [2015/02/13(金) 14:00:42.22 ID:wCixqXPj.net]
状況次第ではJavaScriptの方が速いなんて事もあるのに
まだそんな事を言っているのか

arewefastyet.com/#machine=28&view=breakdown&suite=asmjs-ubench

381 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 14:07:45.39 ID:/fWsfy1c.net]
まずは、JavaとJavaScriptの違いから勉強しようね?

382 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 14:07:50.74 ID:ozS65/+Z.net]
と言うかC/C++のスレでいい加減スレチw

383 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 14:18:22.58 ID:diYHW0ok.net]
いや、C/C++の存在意義を知る上で重要な議論だよ。

384 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 14:20:03.86 ID:s8SeVfmU.net]
しかも、asm-jsってClangで中間コードにしたものをJavascriptに変換するものであって人間が書いてネイティブコードより速くなるもんじゃねえよ

385 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 14:58:19.33 ID:wCixqXPj.net]
他の言語は実行がVMだから遅い、C++はネイティブコードだから(常に)VMより速いと言う幻想を>>367は持っているようなので
ぶち壊してやった

386 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 15:06:44.71 ID:/fWsfy1c.net]
で、JavaやC#がC++と等速になったとかいうデータはマダー??

387 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 15:23:17. ]
[ここ壊れてます]



388 名前:57 ID:fRUihGLp.net mailto: >>372
>>373 は多分あなたの言っていることが全く理解できていないだろうな。

たぶん初〜中級者に「VMやJSは思ったほど遅くない」という幻想を抱かせるのが目的。
[]
[ここ壊れてます]

389 名前:名前は開発中のものです。 mailto:sage [2015/02/13(金) 15:25:16.23 ID:diYHW0ok.net]
いったい、何のためにそんなことを・・・






[ 続きを読む ] / [ 携帯版 ]

前100 次100 最新50 [ このスレをブックマーク! 携帯に送る ] 2chのread.cgiへ
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧]( ´∀`)<177KB

read.cgi ver5.27 [feat.BBS2 +1.6] / e.0.2 (02/09/03) / eucaly.net products.
担当:undef