C/C++ゲーム製作総合スレッド Part4
■ このスレッドは過去ログ倉庫に格納されています
0001名前は開発中のものです。
2013/08/12(月) NY:AN:NY.ANID:RPqvnGkC元スレ
DXライブラリ 総合スレッド その12
http://toro.2ch.net/test/read.cgi/gamedev/1330000532/
前スレ
C/C++ゲーム製作総合スレッド Part1
http://toro.2ch.net/test/read.cgi/gamedev/1337516528/
C/C++ゲーム製作総合スレッド Part2
http://toro.2ch.net/test/read.cgi/gamedev/1351015269/
C/C++ゲーム製作総合スレッド Part3
http://toro.2ch.net/test/read.cgi/gamedev/1357899040/
0248名前は開発中のものです。
2013/10/03(木) 22:00:56.49ID:98DwJ9Gs安価見逃した上にハロワのビルドが速い言語と空目してしまったのでHQ9+と上げておくw
0249名前は開発中のものです。
2013/10/03(木) 22:33:47.68ID:edQZBgYu0250名前は開発中のものです。
2013/10/03(木) 23:13:17.00ID:DhfDfaDp0251名前は開発中のものです。
2013/10/03(木) 23:42:09.30ID:mySEiIjB0252名前は開発中のものです。
2013/10/04(金) 00:23:20.56ID:yG2oikok延々と全プログラムを書き出しているとかいうオチじゃね〜の?
そりゃ重いよ。
0253名前は開発中のものです。
2013/10/04(金) 00:26:55.32ID:kN3IM+RsDXスレのがよっぽどゲーム的
0254名前は開発中のものです。
2013/10/04(金) 00:55:47.13ID:yG2oikokそーゆーよっぽどな理由がない限りは、DXライブラリ使った方が
良いとは俺も思う
0255名前は開発中のものです。
2013/10/04(金) 01:11:50.59ID:yG2oikokこれやられっと処理速度がやたらと遅くなるんだが・・・・・・
0256名前は開発中のものです。
2013/10/04(金) 01:25:42.28ID:yG2oikok0257名前は開発中のものです。
2013/10/04(金) 01:32:27.72ID:NV+cCaxOチャット?
0258名前は開発中のものです。
2013/10/04(金) 01:32:40.31ID:LBEm60p60259名前は開発中のものです。
2013/10/04(金) 02:03:50.60ID:yG2oikok0260名前は開発中のものです。
2013/10/04(金) 02:13:07.11ID:Vxt/QfR9i5に16GB積んでVC2012でハロワをビルドしても数秒かかるよ
I/Oの強化が効果的だけど、例えばFC接続したRAID5構成(HDD24台)でRHELのGCCでビルドしたって一瞬じゃ終わらん
やっぱ、Delphiが最強だな
0261名前は開発中のものです。
2013/10/04(金) 02:29:42.32ID:LBEm60p60262名前は開発中のものです。
2013/10/04(金) 02:33:31.45ID:yG2oikok0263名前は開発中のものです。
2013/10/04(金) 02:34:54.05ID:LBEm60p60264名前は開発中のものです。
2013/10/04(金) 02:46:28.17ID:yG2oikokあと、オブジェクト指向にも向いてるし、モジュール設計も楽。
0265名前は開発中のものです。
2013/10/04(金) 03:03:29.50ID:Y9YGW56v0266名前は開発中のものです。
2013/10/04(金) 03:05:51.85ID:LBEm60p6良かったな
0267名前は開発中のものです。
2013/10/04(金) 03:31:25.01ID:B5Ii4kbUC++が圧倒的に遅いのは最強! 無敵!
0268名前は開発中のものです。
2013/10/04(金) 05:40:39.74ID:GRmzq35U別にスマートポインタ使える必要ないよな
アロケータも別に
0269名前は開発中のものです。
2013/10/04(金) 08:53:12.46ID:8I+rYF1pスマポ普通に使うが、なんで名前を出した?
boost::shared_ptr も、都合によって自前も。「ひらがな書けます」くらいのレベルの話だ。
0270名前は開発中のものです。
2013/10/04(金) 08:55:12.20ID:8I+rYF1p自前ライブラリとかlibにしとかないか普通。
それでも遅いって話ならいいけど
0271名前は開発中のものです。
2013/10/04(金) 11:53:46.23ID:17B7kATN構造が複雑になった場合、どのタイミングで解放されているのかよくわからなくなる
みたいなことってないの?
0272名前は開発中のものです。
2013/10/04(金) 11:59:28.70ID:n+pz5jM/0273名前は開発中のものです。
2013/10/04(金) 12:06:41.37ID:B5Ii4kbUオーナー管理で罠にハマるとつらい
0274名前は開発中のものです。
2013/10/04(金) 12:23:47.55ID:17B7kATNなんらかのインスタンスを参照している場合、
先にインスタンスを解放してしまったら、
参照している方で不具合が起こるじゃないか。
0275名前は開発中のものです。
2013/10/04(金) 13:38:33.03ID:8I+rYF1p考え方的に逆。って言うかちょっと違う。
「いつ解放されるかわからない」って状況はスマポ使う使わない以前の自分が動作を認識してるかって話であって、
ライフサイクルは自分がわかった上で利用するんだよ。
つまりそのデストラクタはいつ呼ばれるかってのを自分がわかってて書いてるのが前提。
スマポはその上の保険と省力。
0276名前は開発中のものです。
2013/10/04(金) 13:41:02.20ID:8I+rYF1pそれはスマポに限らず設計の問題。
JavaやC#にあるGCと混同してないか?
全く別物で、スマポは単純だぞ
0277名前は開発中のものです。
2013/10/04(金) 14:30:37.37ID:D4r1gxKkだからコンパイルの高速なスクリプト言語を組み合わせるんだ
0278名前は開発中のものです。
2013/10/04(金) 15:16:13.30ID:PrPp4O7S0279名前は開発中のものです。
2013/10/04(金) 15:17:40.69ID:OYfw4N/5たまたま解放忘れてても拾ってくれる保険なら労力増やしてまでやる必要が感じられない
原則delete行わずデストラクタで自動解放が主流なら今すぐ書き換えてくる
0280名前は開発中のものです。
2013/10/04(金) 15:31:33.71ID:1sDA81tE原則っていうかザックリ言うと、スコープから外れたときにdeleteを自動でやってくれる。
func(){
}
0281名前は開発中のものです。
2013/10/04(金) 15:38:32.32ID:1sDA81tEfunc(){
smart_ptr<foo> bar(new foo);
なんかごにょごにょ
} <- barだけしか使ってないならここで解放
これが基本だが、スマポ同士で代入ができるやつは関数の戻り値に渡したりするとスコープを超えられるのもある。
なので、いろいろな場所で使っていても、結果的にすべて共有しなくなった時にdeleteしてくれたりする。
0282名前は開発中のものです。
2013/10/04(金) 15:57:27.76ID:LJJoT65Rちょっと勉強と動作チェックしてくる
0283名前は開発中のものです。
2013/10/04(金) 16:17:23.72ID:pWUsBtbyマジかよ
スマポってそんな凄いやつだったのか!
でもそもそもnewとかdeleteしないプログラムしか書いたこと無いから意味無いような気がする・・・
0284名前は開発中のものです。
2013/10/04(金) 16:23:01.59ID:8I+rYF1pなんか気になったので補足しておくと、
> デストラクタが起動してデリートするのか
delete された時、解放時の処理の為にデストラクタが呼ばれるんだぞ?
意味わかってるのか不安になった。
0285名前は開発中のものです。
2013/10/04(金) 16:23:58.50ID:8I+rYF1p0286名前は開発中のものです。
2013/10/04(金) 16:31:39.55ID:8I+rYF1pスマポクラス側のデストラクタが呼ばれたら、スマポクラスが保持しているポインタをdeleteするって意味ならその通り。
ただそれだけの仕掛け。
>>284-285 はスルーで。てかクラスの入れ子関係で、デストラクタの中で、
子要素のデストラクタ呼ぶような処理普段書いてたら簡単にわかる話だ。
boost::shared_ptr はそれプラス、コピコンやコピーオペレータを持ってるだけ。だから単純な仕掛け。
0287ID:17B7kATN
2013/10/04(金) 16:41:09.39ID:Khs7TfOGそれは単純な例だけど、
構造が複雑になった場合、例えば複数のヒープ変数が必要で、一方が他方を参照している場合とか、
>どのタイミングで解放されているのかよくわからなくなる
ってならない?
>>281
これまさに
>どのタイミングで解放されているのかよくわからなくなる
ってならない?
0288名前は開発中のものです。
2013/10/04(金) 16:42:12.87ID:1sDA81tE解放忘れがないか、二重デリートがないか、インスタンスが生きているか、適切なライフサイクルか、、、、
などと複雑になりやすいコードに神経を使うよりも、
スマポを持ってたら生きているのが保障されるからコードが見やすくバグも少なくなるし。
たとえば、STGなんかで親子関係を持った敵がいたとして
親が破壊されたとき、子は生きていて親を参照している場合、
スマポなら親を生存リストから外すだけでおkで、子が全滅した時点で勝手にdeleteされるなーんて。
生ポならずっと子が生きているか監視しなければならないし。
この部分のコードが減るだけでバグが少なくなるよね。
ほんとスマートだわ。
0289名前は開発中のものです。
2013/10/04(金) 16:48:05.11ID:1sDA81tE基本的にどのタイミングで解放されてもいいんだよ。むしろ気にするような組み方はよろしくない。
アクセスしたときに必ず生存していることが重要。
循環参照には気を付けないといけないけど。
0290名前は開発中のものです。
2013/10/04(金) 16:53:36.47ID:Khs7TfOGメモリをケチろうとして重複を無くそうとすると、
参照関係が複雑にならないか?
0291名前は開発中のものです。
2013/10/04(金) 17:00:08.29ID:1sDA81tEそんなギチギチの環境で組んでるの?
たぶん、そんな複雑な参照してる場合は設計を一度見直したほうがいい場合があるよ。
0292名前は開発中のものです。
2013/10/04(金) 17:53:17.80ID:D4r1gxKk0293名前は開発中のものです。
2013/10/04(金) 19:27:18.60ID:B34lM/72実行中に書き換えられるようにすると凄く便利らしいね、ああいうの
0294名前は開発中のものです。
2013/10/04(金) 19:32:50.22ID:pTcYqrKi例外使う場合、正しく確実にファイナライズ処理を実行する方法は事実上スマポだけ。
なので細かい事を言えば、スマポを一切使わない場合、例外禁止&2段階初期化必須&コンストラクタ内では代入くらいしかしてはいけない、みたいな設計上の制約も出てくる。
スマポは超便利ってのもあるけど、こういうC++の暗黒面を補う事情もあったりする。
0295名前は開発中のものです。
2013/10/04(金) 20:21:48.75ID:8I+rYF1pMore C++ Idioms
http://ja.wikibooks.org/wiki/More_C%2B%2B_Idioms
0296名前は開発中のものです。
2013/10/04(金) 21:39:25.40ID:pWUsBtbySOCKETの変数をいろんなところでメッチャ使うんだけど
これを引数で持ってきてたんだけど、グローバル変数にしてやった方が圧倒的に楽だよな
でもグローバル変数って使わないべきだし、シングルトンも同じだから使わないべきなんだけど
こういうときってどうすりゃいいの
0297名前は開発中のものです。
2013/10/04(金) 21:46:22.36ID:yG2oikok使わない方が無難というだけ
必要があるなら遠慮なく使えばいい
0298名前は開発中のものです。
2013/10/04(金) 21:49:17.96ID:pWUsBtbyありがとうございます
0299名前は開発中のものです。
2013/10/04(金) 21:59:15.94ID:yG2oikok0300名前は開発中のものです。
2013/10/05(土) 06:58:26.67ID:42i+ls1b子の参照を持ってるのは親だけなのでは
0301名前は開発中のものです。
2013/10/05(土) 08:55:09.52ID:zPZwPgbhグローバル変数を使うなと言われる理由はいくつかあるけど、その一つに変数は関数より柔軟性が低いってのがある。
メンバ変数をプライベートにしてsetter/getterを作れっていうのと事情は大体同じ。
例えば、4人対戦ゲーの場合、プレイヤーIDを表す変数は0〜3までの値しかとって欲しくないとする。
変数に直接代入する場合、いざ使う時になってIDが正しいかチェックする必要があって、プレイヤーIDが0〜3になっているかチェックするコードが全体にばらまかれる。
関数経由で代入する場合、引数の値をチェックしてエラーを投げることができるので、値の範囲をチェックするコードは最初のsetterだけで済む。
変数は代入しか出来ないけど、関数は付随する処理(引数チェック、ログの記録)が出来るし、仕様の変更にもある程度柔軟に対応できる。
(プレイヤー人数を6人に増やしたいと思ったときに修正しなければならい箇所の違いを考えると…)
理想的には、Socket自体は通信関係のコード以外に触れられないようにして、
SendAttack(OBJECT_ID target);
SendMove(OBJECT_ID id, Position pos);
SendChat(PLAYER_GROUP_ID groupId, const char* msg);
みたなゲームの仕様に合わせたパケット送受信関数を作って、それをゲームロジック全体で使う。
この手の送受信関数を纏めたクラスのオブジェクトが、シングルトンやグローバル変数になるのは仕方ないんだけど、
Socketが丸出しのグローバル変数ってのはあんまりよくはないな。
まぁ小規模なゲームを一人で書いてる内は、そこまで致命的でもなかったりするが。
まだ仕様がハッキリと見えてない段階でプロトタイプを書いてるときは、何も考えずグローバル変数の方が手早い事も多いし。
長文でスマン。
0302名前は開発中のものです。
2013/10/05(土) 09:16:22.33ID:0JH/7YRj開放順が保証されないからデストラクタで何か処理するような場合困るかもしれないって事と、
namespaceも分けて無いグローバル変数でかつexternだらけとかになると迷子になる上、別の翻訳単位にもしも同名があった時面倒な事になる、ってのが
大昔に経験したリアルな問題
0303名前は開発中のものです。
2013/10/05(土) 09:18:23.46ID:0JH/7YRj普通 static キーワード付けて、externさせないってのが常套手段だよな。
0304名前は開発中のものです。
2013/10/05(土) 09:31:57.77ID:6oF2RLCdextern = public
0305名前は開発中のものです。
2013/10/05(土) 12:18:22.70ID:pPsHi/Dfそうは限らないよ。
親から一定間隔離れて行動したり、親の状況で振る舞いを変えることがあるから。
どちらの場合もある。
0306名前は開発中のものです。
2013/10/05(土) 12:29:05.40ID:lHo24dEmそう、グローバルを遠慮する必要なんてない、ってのは合意事項だよな
0307名前は開発中のものです。
2013/10/05(土) 13:13:45.24ID:lHo24dEmそうか参照が抜けてたか。
http://images2.fanpop.com/image/photos/9400000/kelsi-high-school-musical-9487566-333-500.jpg
http://img.photobucket.com/albums/v515/bloodylamer/bastardly-photos/0505/album102/olesya-rulin-09040702.jpg
これでどうだ。
0308名前は開発中のものです。
2013/10/05(土) 15:33:55.63ID:hWuxl6U4親から全ての子に指示するべきじゃない?
子供が親の参照はよくないと思う
0309名前は開発中のものです。
2013/10/05(土) 16:02:12.04ID:hYYXb5oUOgre3Dは親子それぞれ参照をもってるんだがな
0310名前は開発中のものです。
2013/10/05(土) 16:25:59.47ID:pPsHi/Dfそれも場合によると思うなぁ。親を辿りたい時があるし、
親が子に干渉しすぎるのはちょっと、という考え方もあるだろうし。
0311名前は開発中のものです。
2013/10/05(土) 17:01:45.43ID:GFX991pR例えばシューティングでの位置関係なら
親の移動が子全体に影響するなら、親が子の参照を持っているのが便利だよな
これはシーングラフみたいなやつか、スプライトとかはコッチだろうな
逆に子が親の行動をトレースするタイプだと参照の持ち方は逆になる
こっちはカメラのスナップかな、親が持つんじゃなくて、子が勝手にぶらさがる
0312名前は開発中のものです。
2013/10/05(土) 18:02:50.50ID:G4p0Eaf6子ノードは親ノードの弱参照を持つという形にしている
0313名前は開発中のものです。
2013/10/06(日) 12:59:02.01ID:zo41YPA1例えばゲーム設定上の関係性(物理、組織、通信回線、人間模様、etc)は色々だし
これらの関係性も、実装上は、制御(操作)の流れ、データの流れ、色々だし
話の前提条件が何かを伏せてる限り、問題の所在も実装の最適解も本人にしかわからん
説明が面倒なら、頑張れとしか言えん
0314名前は開発中のものです。
2013/10/06(日) 19:46:28.52ID:iRwfUiRGそれとも、戦闘ロジックの部分だけ無名関数で差し替えるとか?
0315名前は開発中のものです。
2013/10/06(日) 19:56:21.47ID:NCxdwdJm処理速度では前者、汎用性では後者だな
0316名前は開発中のものです。
2013/10/06(日) 22:48:36.24ID:Gau/gyhr前者が、敵1体を1単位とするような粗い粒度の処理の差し替えの話で
後者が、無名関数でもおkな程度に細かな粒度の処理の差し替えの話なら
場合に応じてそうした実装の使い分けをするというのは普通にアリなのでは
0317名前は開発中のものです。
2013/10/07(月) 00:06:33.12ID:Z8udyLbhtimeBeginPeriodとtimeEndPeriodはプログラム全体で同じ分解能なら開始時と終了時に1回呼ぶだけで合ってる?
それともタイムを使うごとに毎回呼ばないといけない?
0318名前は開発中のものです。
2013/10/07(月) 00:19:23.88ID:peQndcOh1回だけだと他のプロセスで精度を悪いほうに変えられたら駄目だろうな
0319名前は開発中のものです。
2013/10/07(月) 00:33:00.85ID:Z8udyLbhありがとうございます
そうか他のプロセスで弄られる可能性が有るから毎回呼ぶほうがいいのか・・・
1回呼べば固定されるはずなのにサンプルコードで何で毎回呼ぶのかわからなかったけどようやくわかった
0320名前は開発中のものです。
2013/10/07(月) 10:34:56.91ID:cd4YBeJh一回でいい。
ただtimeBeginPeriodとかはOS共有だから
他のアプリで操作されたらどうしようもない。
0321名前は開発中のものです。
2013/10/07(月) 17:24:54.99ID:qrJ0yezQC++アンチはどこに行けばいいんだよ
0322名前は開発中のものです。
2013/10/07(月) 17:27:52.18ID:fbGS27If0323名前は開発中のものです。
2013/10/07(月) 17:34:15.51ID:qrJ0yezQ0324名前は開発中のものです。
2013/10/07(月) 17:34:45.52ID:HiWWBNmC0325名前は開発中のものです。
2013/10/07(月) 18:09:02.74ID:rNPgmZ8O0326名前は開発中のものです。
2013/10/07(月) 18:30:40.04ID:hXeKSm4Cだとしたらゲ製でやることじゃないな
0327名前は開発中のものです。
2013/10/07(月) 18:33:42.33ID:m3YcIJSbさらに分割してどうするんだよ。
0328名前は開発中のものです。
2013/10/07(月) 19:06:58.27ID:Rxv904Ei0329名前は開発中のものです。
2013/10/07(月) 19:46:57.01ID:qP3zr35u0330名前は開発中のものです。
2013/10/07(月) 19:50:35.82ID:HiWWBNmC0331名前は開発中のものです。
2013/10/07(月) 20:19:25.16ID:807/8QJs個人の趣味の時は人目を気にすることなくベターC留まりの
作り捨て上等のコードでいいのよ
家ではみんなパンツ一枚でしょ
0332名前は開発中のものです。
2013/10/07(月) 20:22:05.83ID:807/8QJs○作り捨て上等のコードで“も”いいのよ
0333名前は開発中のものです。
2013/10/07(月) 22:42:28.85ID:rZ6Ej5K9もちろんオブジェクト指向
0334名前は開発中のものです。
2013/10/07(月) 22:47:44.55ID:IYoY04Miprivate:
int* p;
public:
void hoge();
}
void myclass::hoge()
{
p = new int[ sizeof( int) ];
}
void main()
{
myclass obj;
obj.hoge();
obj.hoge();
}
この場合初めにNewした領域はプログラムが完全に終了するまで消すことは出来ませんよね?
0335名前は開発中のものです。
2013/10/07(月) 22:49:26.71ID:Rxv904Ei0336名前は開発中のものです。
2013/10/07(月) 22:56:29.67ID:NV8ETZzm0337名前は開発中のものです。
2013/10/07(月) 23:13:34.32ID:IYoY04Mi>>336
ありがとうございます!!
2個目を消す場合、
クラスにDelete()関数を追加して、
void myclass::Delete()
{
delete[] p;
p = NULL;
}
void main()
{
myclass obj;
obj.hoge();
obj.hoge();
obj.Delete();
}
でも、ダメですか?
0338名前は開発中のものです。
2013/10/07(月) 23:15:28.95ID:Rxv904Ei0339名前は開発中のものです。
2013/10/07(月) 23:23:11.69ID:IYoY04Mi実際にこれを使うわけではないので安心してください!
プログラムの勉強を始めたばかりで内部的にどうなってるか知りたかったんです。
答えてくださった方たちありがとうございました!
0340名前は開発中のものです。
2013/10/08(火) 09:02:29.21ID:4d44TfVz一回目のnewで確保した領域をメモリリークさせるコードを書きたいの?
よくわからんテストコードだな。
0341名前は開発中のものです。
2013/10/08(火) 09:46:37.11ID:ttaYSeAJmyclassのデストラクタで配列解放しない理由は?
0342名前は開発中のものです。
2013/10/08(火) 09:56:41.94ID:ttaYSeAJ普通と言うかよくやる考え方の順序で言うと、まず真っ先に一旦myclass側のデストラクタで、そのクラスの管理責任として、
自身がメンバとして持っている要素の解放処理書いとくってのをワンセットにしてそれを土台の考え方として、
その後、それじゃ困るようななんらか事情や実装都合、あるいは設計上の理由があった時、
実行時の動作パス踏まえて考えた上で、そこでやってるような開放専用関数追加するとかって順番で考えて。
0343名前は開発中のものです。
2013/10/08(火) 16:01:33.64ID:kP7Tf/iB(じゃなきゃIOCCCなんて生まれない)
気持ちはわからないでも
0344名前は開発中のものです。
2013/10/08(火) 22:12:57.72ID:1rDNRsOYシングルトン使いまくりという自由人がいたような記憶があるが
あーいうのもオブジェクト指向的には奇怪な部類に入るだろうか
0345名前は開発中のものです。
2013/10/08(火) 23:19:06.01ID:+doHVCffどうせたかだが数万行の糞コードだろ
多少設計が糞でも力技でねじ伏せられるレベルだろ
少なくとも設計が悪いせいで開発が頓挫するほどのことじゃない
細かいこと気にしてる前にどんどん手を動かせ
ゲームなんかmain関数一本のグローバル変数使いまくりでも何の問題もない
0346名前は開発中のものです。
2013/10/08(火) 23:25:16.39ID:DeWA7nCL個人レベルなら本当にこれだけど、チームでやってるときにそれやられると死ぬ
あと、キャラクタークラスとかは流石に分けないときつくないか
0347名前は開発中のものです。
2013/10/09(水) 10:24:14.87ID:0BIVR7NU■ このスレッドは過去ログ倉庫に格納されています