今までみた絶望的なソースコード [転載禁止]©2ch.net

レス数が950を超えています。1000を超えると書き込みができなくなります。
1デフォルトの名無しさん
垢版 |
2015/04/17(金) 23:00:30.63ID:55USvuES
今井氏:ソースコード公開は、社長のティム(*2)の意向です。彼はバリバリのプログラマーで、初期の「Unreal Engine 1」を
1人で書いた人ですが、若い時に雑誌に載っていたコードを書き写して勉強したそうです。それで今の若い人にも、プロのソー
コードとはこういうものだというのを見せたいという願いがあって、ソースコードを公開しています。本当に今のゲーム業界の
事情を憂いてる1人だと思います。(*2)Epic Gamesの創業者兼CEOであるTim Sweeney氏

出村氏:読みやすいコードですよ。「C++」というのは、黒魔術(高度な計算)が多くなりがちな言語ですが、
そういうこともなく、すっきりしていて目的の機能も探しやすい。解読しやすいコードなので、確かにお手本になると思います。

僕は初代のゲームボーイからプレイステーション 2の頃くらいまでゲームプログラマーだったのですが、ゲームプログラミングでは
必ず数学が出てきます。行列とか三角関数とか。もちろん今でもまったく不要になったわけではありませんが、そういう知識の
重要性は薄れてきていると思います。「Unreal Engine」では特にそうです。
http://game.watch.impress.co.jp/docs/interview/20150417_698349.html

初級者から中級者へ昇格する時期は、ほぼどのようなソースコードでも読める程度にプログラミング言語に精通し、
また偉いプログラマーの提唱したデザインパターンも一通り理解したくらいの時期である。

すると、プログラミング言語の持つあらゆる機能と、偉いプログラマーの提唱するあらゆる技術を使わねばならない
という思い込みが発生する。そしてHello Worldにまで崇高なオブジェクト指向や壮大なデザインパターンを
適用しようとしだすのである。

その結果、
* 大量のクラス
* 迷路のような変数渡し
* 底なしに深いネスト
などといった凄いものが生まれる。また、条件分岐に三項演算子を乱用するなどの症状も多く見受けられる。
最終的には第三者にとって読みにくい保守性の悪いスパゲッティコードが生成されることになる。
http://monobook.org/wiki/%E4%B8%AD%E7%B4%9A%E8%80%85%E7%97%85
2018/07/13(金) 22:02:32.65ID:o297Rvos
プログラマになった時点で
なんぼ汎用的でも所詮は人のつくったオモチャの知識で
頭埋め尽くされてるんやで…
2018/07/14(土) 09:00:00.17ID:IpCsX+RG
>>875
コンピュータサイエンスの研究して提案してる側でないとそうなるよね
2018/07/14(土) 09:26:23.70ID:Rke0wYi7
>>874
それでもフレームワークはコミュニティが存在して詰まるポイントは情報交換してるから良い

弱小ベンダが作った独自ノンプログラミングツールはサポートも含め使い方解らない
878デフォルトの名無しさん
垢版 |
2018/07/14(土) 10:28:38.58ID:v4Gtt50J
>>875
2018/07/14(土) 15:34:32.10ID:emjHoWOe
某一部上場企業に出向してた時がcobolをラップした日本語でプログラミングする企業だったな。
もう史上最低レベルでわからんかった。それで皆やってたから俺の応用力がないんだろうけど。
プログラミングじゃなくてコピペで作る積み木をやってる感覚だった。ベースのソースファイルなんか1つで100万行超えてたからな・・・
880デフォルトの名無しさん
垢版 |
2018/07/14(土) 15:37:32.14ID:/tfnebNh
>>879
それ地獄の所業だな
2018/07/14(土) 15:54:39.16ID:emjHoWOe
>>880
しかも単体テストが出来ないから結合テストの時まで目視。作った段階じゃ動くかどうかもわからない。
本番環境じゃなくてテスト環境なのに、テストする為だけにプロセスコンパイル申請して(自分で勝手にコンパイル出来ない)
リンカが動いてる時はなんと100人近いプログラマが一切動けない。だからバグ頻発させる案件担当は恨まれる。

1箇所でも変数やバグ修正する度に、修正した変数が使われてる関数全ソースを「紙に出力」して案件担当に報告する。
無論その関数も二段組で10枚を超えるようなものもザラ。

ソースも絶望だったが会社そのものも絶望だった・・・これで一部上場企業でISO取得してるってんだから
世の中狂ってると思ったわ。今もあんなんやってんだろうか・・・
2018/07/14(土) 16:13:46.94ID:FpRN5ZR0
ISOなんてソフトに関しちゃダメな証でしかない。
2018/07/14(土) 23:35:54.44ID:TeU19955
ある有名大学を卒業した若手女子プログラマーが書いていたもの

if
 for
if
else
if
else
   if >>4
else
//上書き
      result
2018/07/14(土) 23:48:20.01ID:C/4HyVCo
それがどうした?
2018/07/15(日) 00:05:51.22ID:WkgjesJQ
再帰n個まで対応として同じ処理をネストで内部にたくさん継ぎ足すのはなかなか
2018/07/15(日) 14:23:36.32ID:hJBIKok3
しょうもねえ
2018/07/17(火) 15:33:56.20ID:7HO9UDJa
ネストが4階層以上あるコードが頻出してるかどうかで
プログラマとしてのセンスの9割以上が分かると思う
888デフォルトの名無しさん
垢版 |
2018/07/18(水) 12:19:37.23ID:/ZX5NzfB
センスのない経験則やなw
2018/07/18(水) 13:59:31.91ID:FzU0QTYV
ネストの4階層はよく言われてる事だろ
ネストの深さは闇の深さってな
890デフォルトの名無しさん
垢版 |
2018/07/19(木) 21:56:52.07ID:vNM0RZQs
ネストの深さで分かるのは無能である事だけやぞ?
センス関係ないやんw
てか無能はコード見るまでもなく一言話せば分かるしw
迸っとるからな無能がwおまえらみたいにw
2018/07/19(木) 22:48:50.17ID:9MpINeJL
だいぶ仕上がってますね
2018/07/19(木) 22:56:52.61ID:zpCf8yuT
ネスト取っ払うのなんてセンスいるか?
2018/07/19(木) 23:03:03.88ID:f+n36xTV
メソッドに抽出したりcontinue,break,returnで浅くする工夫なら普通はやるわな
2018/07/20(金) 13:13:13.22ID:LdIsG+oi
>>890
おっと自己紹介はそこまでだ
2018/07/20(金) 16:09:29.36ID:xRxkFDHW
もうさぁ・・・一般的に言われてるソースじゃなくて、実際の仕事で見たソースの話してくんない?
本でよく見るような話いらんわ。しょうもない。
2018/07/20(金) 20:33:44.27ID:1Qoi51WN
実際あるから本のネタになるんだよ
897デフォルトの名無しさん
垢版 |
2018/07/20(金) 23:12:22.02ID:Bp0BPmn2
底辺の話を一般論のようにする馬鹿
2018/07/20(金) 23:52:33.01ID:WFn/Bh7m
どのレスに対してなのか安価ぐらい付けなさいよ馬鹿
899デフォルトの名無しさん
垢版 |
2018/07/21(土) 07:46:57.20ID:o84eWw0G
自覚があるけどあえて名指ししてほしい馬鹿
2018/07/23(月) 13:56:06.67ID:dzfMKL/P
こんな3年以上前にあるスレでお前ら元気だなw
2018/07/23(月) 16:44:38.45ID:Lk4y5zZB
褒めてもクソコードしか出せんぞ
2018/07/23(月) 20:32:42.08ID:2ez6F7EW
最近糞コードより糞メールに心を痛める毎日
2018/07/24(火) 14:06:33.45ID:HRVbYe1/
中国やアメリカで仕事して日本に帰ってくると
未だにメールでやり取りしてて心を痛める毎日
904デフォルトの名無しさん
垢版 |
2018/07/24(火) 15:37:09.77ID:WBO96fmU
ほんそれ
2018/07/24(火) 20:50:50.75ID:5PAxBe9J
むこうは何つかってるん
2018/07/24(火) 22:01:57.77ID:pAzLnnVR
すらっくやろ
2018/08/06(月) 19:05:58.90ID:933yDlcJ
>>905
アメリカはSlack
中国はQQとWeChat(日本のLINEみたいなやつ)

中国は一般人でもメールはほとんど使わない
あとは何でもQRコードで電子決済
道路の両脇に並んでる崩れ落ちそうな肉まん屋ですら電子決済に対応してる
自転車乗るのはスマホ3タッチするだけ

深センあたりに行けば分かるがもう日本は完全手遅れ
2018/08/08(水) 20:23:17.99ID:bSSLrH09
そんなにちがうものだろうか
国は嬉しいかもしれんが個人は
2018/08/23(木) 09:04:38.91ID:NPcuqlt3
履歴書手書きもうやだ
910デフォルトの名無しさん
垢版 |
2018/08/23(木) 09:43:28.39ID:29gBK1aD
1000人以上水増し
2018/08/28(火) 22:37:03.51ID:Nb4zQWFO
methodという名前のクラスを見つけた
912デフォルトの名無しさん
垢版 |
2018/08/28(火) 22:46:56.46ID:EM1Qb6Tt
>>911
www
2018/08/29(水) 01:03:25.64ID:+pRcq4Dh
Methodオブジェクトパターンかメタプログラミング文脈ならありえる
914デフォルトの名無しさん
垢版 |
2018/08/29(水) 19:19:49.93ID:lmwWHcLE
>>911-913←なかなかの絶望的なコーダーwwww
2018/10/10(水) 01:27:15.56ID:+GhPUDy2
深いネストを隠蔽するために関数化。
916デフォルトの名無しさん
垢版 |
2018/10/13(土) 13:54:10.63ID:KAvgvbU+
バクレポ「機能しない 」

中身
{
;//ここに実装する
}
2018/10/13(土) 16:31:33.86ID:/Sv6qn96
>>916
それみて思い出したのがあったw

BOOL xxx(xxx)
{
// なんかコンパイル通らないのでコメントアウト
/*
:
*/
return TRUE;
}
918デフォルトの名無しさん
垢版 |
2018/10/14(日) 12:49:48.40ID:G4e8iFcg
予定として工事中のまま残しとくのはあるな
2018/10/14(日) 13:11:12.33ID:CcpM1t8g
int func(prm1,prm2, …中略…,prmN)
{

//
// 色々処理する(見通し悪い1400ライン)
//
return 0;
}
2018/10/14(日) 20:13:14.41ID:dYWyiuYC
修正に修正を重ねて稼働し続けてきたリソース。
ソース分析しろ言われて開いたらネストが13以上…
921デフォルトの名無しさん
垢版 |
2018/10/14(日) 21:13:04.73ID:WLfX4fFS
解けない因数分解ω
2018/10/14(日) 21:14:53.44ID:TkD6W0eM
>>920
まずユニットテスト書いてリファクタ
2018/10/14(日) 21:20:05.33ID:b97yHnkE
古いコードを延々と残しておくのをやめてほしいな。
ソースコードの半分以上が使われてないコードだったりして見通しが悪いったらありゃしない。
その割に修正履歴はクソの役にも立たないコメントが付いてる。
924デフォルトの名無しさん
垢版 |
2018/10/14(日) 21:21:59.05ID:SE0u9ZQa
>>923
使われとらんのやったら消せばいいやろ
消さないおまえが悪い
925デフォルトの名無しさん
垢版 |
2018/10/14(日) 21:25:39.07ID:WLfX4fFS
めっちゃ長いネストをプリントアウトして一生懸命読んでたら
コメントだったでござる
926デフォルトの名無しさん
垢版 |
2018/10/14(日) 21:29:08.49ID:SE0u9ZQa
未だに紙出ししてコード読むおじいちゃん居るんかよw
2018/10/14(日) 21:35:16.62ID:TkD6W0eM
画面に収まりきらないとかメモ書き込んだりするならやるけどな

それだけ元がひどいんだろ
928デフォルトの名無しさん
垢版 |
2018/10/14(日) 21:41:26.50ID:SE0u9ZQa
画面に収まりきるコードてHello, Worldかなw
2018/10/14(日) 21:50:49.34ID:TkD6W0eM
ずいぶん狭い画面だね
930デフォルトの名無しさん
垢版 |
2018/10/14(日) 21:55:26.77ID:SE0u9ZQa
>>929
画面に収まるコードて25行以下のことやぞw
今どきのディスプレイにあわせて制約ゆるく解釈てんじゃねーよタコwww
2018/10/14(日) 21:57:38.53ID:TkD6W0eM
それ何か面白いの?
932デフォルトの名無しさん
垢版 |
2018/10/14(日) 21:58:28.19ID:SE0u9ZQa
>>931
おまえの無知がおもろいんやけどw
2018/10/14(日) 21:58:53.76ID:TkD6W0eM
よかったね
934デフォルトの名無しさん
垢版 |
2018/10/14(日) 22:00:41.53ID:SE0u9ZQa
>>933
残念やったねwww
935デフォルトの名無しさん
垢版 |
2018/10/14(日) 22:16:44.48ID:BqZmi47p
なんでお前ら揉めてんねん
2018/10/14(日) 23:22:10.76ID:CcpM1t8g
みんな糞コードが悪いんや。
937デフォルトの名無しさん
垢版 |
2018/10/15(月) 04:30:42.78ID:0W4mw5Ny
25行っていつの話だω
縦400しかない頃か

90年代初頭でも480のハイレゾで30行くらいは行けたぞ
2018/10/15(月) 04:50:52.67ID:/DZZgAIK
目糞鼻糞
2018/10/15(月) 07:29:09.96ID:iWG64tv6
どっちがおじいちゃんかわからないねwww
2018/10/15(月) 08:16:17.00ID:ugWChiCs
インデックスが一つも無いオラクルのシステム
しかもパッケージだからイジるなと・・・

検索に何分かかってるんだよ
2018/10/15(月) 08:23:23.46ID:ugWChiCs
>>919
voidが無かった時代もあるんだわ
え、そんな問題じゃない?
942デフォルトの名無しさん
垢版 |
2018/10/15(月) 10:35:12.32ID:/DZZgAIK
ハイレゾにモードチェンジするコマンド名忘れたな
943デフォルトの名無しさん
垢版 |
2018/10/15(月) 10:36:16.16ID:/DZZgAIK
>>941
voidが無くてもva_listはあっただろ
2018/10/15(月) 11:38:50.62ID:RUpsnhtW
↓経験10年以上の奴のプログラムがこれwwww

bool Hoge::isExistElement() const
{
  int cnt = 0;
  for (int i = 0; i < m_ElemList.size(); i++) {
    ++cnt;
  }
  return (cnt > 0)? true : false;
}

データ量が増えるとめちゃ遅くなるので、原因を調べたら
この関数がループの中で繰り返し呼ばれてたwwww
945デフォルトの名無しさん
垢版 |
2018/10/15(月) 17:39:03.89ID:HKiVHmTj
return m_ElemList.size() > 0;
あるいは
for(int i = m_ElemList.size(); --i >= 0;) return true;
return false;

なんかの罠か?
全力で釣られてやったぞ
2018/10/15(月) 20:01:02.54ID:gXcd9TOh
不要な行は消せば良い言う人いるが、
消したくても消せない環境があるのよ…
クソコード × クソ規約 でお腹いっぱいぱい
947デフォルトの名無しさん
垢版 |
2018/10/16(火) 03:33:36.46ID:t3pQN/xM
トンキン試合ぶち壊しω最低だなωω
2018/10/20(土) 16:35:46.84ID:4GOhJijx
wをωかくのキモいね
949デフォルトの名無しさん
垢版 |
2018/10/21(日) 20:00:18.61ID:0rXyRLVH
もまいらが優秀だと思う著名なプログラマーは誰?
950デフォルトの名無しさん
垢版 |
2018/10/21(日) 20:20:22.20ID:Oh4Mk/D5
おれが昨年作った糞コードを張りたいけど、
死ね!と言わない?
951デフォルトの名無しさん
垢版 |
2018/10/21(日) 21:04:49.37ID:it9nlgqU
死んでる物体に死ねとは言わないでしょ普通
2018/10/21(日) 21:37:32.52ID:gNVlu9Yw
>>950
いわないから見せて!
https://ideone.com
2018/10/22(月) 09:23:43.91ID:3+JbbVPy
ムチャクチャだとされるCのコード

#include <stdio.h>
#include <stdlib.h>

// 構造体の宣言
typedef struct {
int num;
char *str;
} strct;

int main(void) {
// 実体を生成
strct *entity;

// 動的メモリの確保。確保したメモリをstrct型ポインタにキャスト。
entity = (strct*)malloc(sizeof(strct));

// メンバの初期化
entity->num = 0;
entity->str = (char*)malloc(sizeof(32));

// メモリに文字列を代入
sprintf(entity->str, "%s %s!", "Hello", "World");
printf("%s\n", entity->str);

// メモリの解放
free(entity->str);
free(entity);

return 0;
}
2018/10/22(月) 09:39:27.73ID:1/yFf04Z
>>953
siseof(32)ってなんだろ?
2018/10/22(月) 09:53:43.00ID:YaHJAE+1
数値リテラルは大抵intかな
2018/10/22(月) 10:05:30.30ID:XZ32Z+1r
>>953
sizeof(32) が怪しいくらいじゃね?
個人的には main(void) も気になるけど、どの辺がムチャクチャ?
2018/10/22(月) 10:33:20.99ID:1/yFf04Z
typedefで小文字とstlctって名前も少々気持ち良くない
958デフォルトの名無しさん
垢版 |
2018/10/22(月) 23:15:17.28ID:tG7xaI7F
sprintf で思いっきりバッファオーバーフローしとる
2018/10/23(火) 01:03:56.45ID:d4On2qFi
>>958
そりゃsizeof(32) の指摘に含まれてるからあえて言う必要は無いんじゃね
960デフォルトの名無しさん
垢版 |
2018/10/23(火) 12:33:21.37ID:klyqqLAB
なぜ誰もfreeに突っ込まない?おまえら初心者ばかりか?
2018/10/23(火) 14:07:56.51ID:hMZ53Rau
えっ…
962デフォルトの名無しさん
垢版 |
2018/10/23(火) 14:25:23.38ID:yFsvvFWj
freeなんて飾りです
2018/10/23(火) 16:20:31.77ID:fVBjYNqz
おいおい
964デフォルトの名無しさん
垢版 |
2018/10/23(火) 23:23:13.96ID:U+Jl4m6O
初心者さん、言葉がでない
2018/10/24(水) 09:09:08.71ID:vJ0gepnW
free不要論争勃発
966sage
垢版 |
2018/10/24(水) 15:23:23.13ID:wUNs4a59
sejuku が話題になってるスレがあったけど見つからねぇ
長野透とかいうひとのソースを分析してみた
最近の C というか ideon のメモリ割り当てって安全なのか?
#include <stdio.h>
#include <string.h>

int main() {
char s1[7] = "hello "; // taken 0x10 bytes
char s2[19] = "world! long length"; // taken 0x20 bytes
char s4[16] = "ABCDEFGHIJKLMOP";
char *s3;

s3 = strcat(s1, s2);
printf("%08x[%s]\n", s1, s1);
printf("%08x[%s]\n", s2, s2);
printf("%08x[%s]\n", s4, s4);
printf("%08x[%s]\n", s3, s3);
return 0;
}
https://ideone.com/58GHMk
2018/10/28(日) 12:22:39.71ID:Ujmok0wr
>>966
auto の話ならたまたま
2018/10/28(日) 15:14:32.11ID:0CAv0Ngu
>>966
>strcat(s1, s2);
これは決定的にあかん奴やね…
969デフォルトの名無しさん
垢版 |
2018/10/28(日) 19:14:51.01ID:h5ZEQ7FS
memcpyだよな
970デフォルトの名無しさん
垢版 |
2018/10/30(火) 14:36:53.65ID:p4LrBCE7
解読不能

今起こり猿馬見れんだろ大会なの小倉の
日のお風呂中日本中4代目の枕にメール
お願い泊なっている心も離れてない練習
ご紹介私の命の言葉としての勉強
2018/12/07(金) 02:37:05.58ID:Hbbkocqb
昔の翻訳ソフトってこんな感じだった
2019/04/23(火) 18:25:02.94ID:7ENhr2Wk
>>881
会社名を知りたい
973デフォルトの名無しさん
垢版 |
2019/06/19(水) 04:46:05.82ID:tVNS+22r
【出資】松本卓朗 人工知能詐欺【注意】
https://rio2016.5ch.net/test/read.cgi/rikei/1560859403/
2019/06/23(日) 21:33:39.90ID:uh+kjram
熱い麺と冷たい麺
レス数が950を超えています。1000を超えると書き込みができなくなります。
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

ニューススポーツなんでも実況