1 名前:デフォルトの名無しさん [2019/04/02(火) 11:23:37.62 ID:SQXqRaAc0.net] !extend:checked:vvvvv:1000:512 C言語の話題のみ取り扱います C++の話題はC++スレへ 質問には最低限の情報(ソース/コンパイラ/OS)を付ける 数行で収まらないソースは以下を適当に使ってURLを晒す https://paiza.io/ https://ideone.com/ codepad.org/ C11 www.open-std.org/jtc1/sc22/WG14/www/docs/n1570.pdf C99 www.open-std.org/jtc1/sc22/WG14/www/docs/n1256.pdf kikakurui.com/x3/X3010-2003-01.html C FAQ 日本語訳 www.kouno.jp/home/c_faq/ JPCERT C コーディングスタンダード https://www.jpcert.or.jp/sc-rules/ VIPQ2_EXTDAT: checked:vvvvv:1000:512:----: EXT was configured
610 名前:デフォルトの名無しさん [2019/05/21(火) 10:21:18.62 ID:BVi2WQ22a.net] >>590 それコンパイラ依存なのでは?
611 名前:デフォルトの名無しさん mailto:sage [2019/05/21(火) 12:55:43.68 ID:PZq+OQZ5p.net] >>589 これな Javaを最初に設計した奴はバカなんじゃないかと final の仕様を見たとき思ったな
612 名前:デフォルトの名無しさん mailto:sage [2019/05/21(火) 15:23:18.72 ID:ZAINLMmO0.net] Linux では、HDD へ書き込むのは、デフォルトで、5秒に1回 USB メモリで、書き込み回数を減らしたい場合は、 15秒に1回とかに設定する人もいる
613 名前:デフォルトの名無しさん mailto:sage [2019/05/21(火) 18:23:31.31 ID:6muVxYSDr.net] >>593 書き出し周期はファイルシステムに依存するよ 例えばext3かext4かで挙動は違う
614 名前:デフォルトの名無しさん [2019/05/21(火) 18:37:21.97 ID:G/IUf+gXp.net] C言語のfprintfを用いるときに、前行の改行を消す方法をご存知ないですか? エスケープシーケンスでバックスペースを試したのですか上手くいかなくて困っています。 状況としてはfor文を用いて改行を含んだ文字列を繰り返し出力させているんですが、最後の行だけ改行を無くし、続けて別の文を出力したいのです。 繰り返しの回数を変えて最後に改行なしの処理をいれればいいと思うのですが、簡単な方法があればと思い質問させていただきました。 よろしくお願いします。
615 名前:デフォルトの名無しさん mailto:sage [2019/05/21(火) 18:40:11.67 ID:UdJL+OJH0.net] ストリームの撒き戻しは難しいんじゃないか? 表示装置なのかファイルなのかでも変わるだろうし…
616 名前:デフォルトの名無しさん mailto:sage [2019/05/21(火) 18:54:48.20 ID:Hcv2vO/e0.net] ファイルポインタは巻き戻せる 標準出力ならエスケープシーケンスで右上に行けばいい
617 名前:デフォルトの名無しさん mailto:sage [2019/05/21(火) 19:19:14.41 ID:IJ+i04U80.net] こんな感じでいいのか? #include <stdio.h> int main(void) { FILE* fp; fp = fopen("Test.txt","w"); fprintf(fp,"hoge\n"); fseek(fp,-1,SEEK_CUR); /* 改行2byteなら-2 */ fprintf(fp,"fuga\n"); fclose(fp); return 0; }
618 名前:デフォルトの名無しさん mailto:sage [2019/05/21(火) 19:53:55.55 ID:UPiNM42a0.net] 質問者が知りたい情報とは違うので、スルー推奨かもですが。 もし自分が、同じことをやれ、と言われたら。 「改行を含んだ文字列」を、「改行」と「それ以外の文字列」の2つに分けて、別々に出力しようとするかなあ。 ループの回数を変える必要はなくて。イメージとしては for() ※行単位のループ { if(最初の行でなければ) fprintf で「改行」を出力 fprintf で「それ以外の文字列」を出力 } fprintf で「別の文を出力」
619 名前:デフォルトの名無しさん mailto:sage [2019/05/21(火) 19:58:03.98 ID:kdkwqODuM.net] >>595 bool First = true; for( … ){ if(First){ First = false; } else { fprintf("¥n"); } fprintf( … ); }
620 名前:デフォルトの名無しさん mailto:sage [2019/05/21(火) 19:58:35.62 ID:kdkwqODuM.net] あっ、被ったや
621 名前:デフォルトの名無しさん mailto:sage [2019/05/21(火) 20:07:13.38 ID:IJ+i04U80.net] ファイルが標準出力等でvt100互換端末であれば。 #include <stdio.h> #include <string.h> int main(void) { int i; i=fprintf(stdout,"hogehogehogehoge\n"); if (0) fprintf(stdout,"\E[01Afuga%*c\n",i,' '); /* これか? */ else fprintf(stdout,"\E[01A\E[%02dCfuga\n",i-strlen("\n")); /* あるいはこれか? */ return 0; } cmdとかdos窓なら無理?
622 名前:デフォルトの名無しさん [2019/05/21(火) 20:22:57.69 ID:G/IUf+gXp.net] >>596-602 皆様回答ありがとうございます。 ファイルを扱っているので、fseekで戻す方法を試してみようと思います。
623 名前:デフォルトの名無しさん mailto:sage [2019/05/21(火) 20:31:17.43 ID:JOJ6V6qzd.net] プログラムいじられるなら、改行出す方をどうにかした方が良さそうだが
624 名前:デフォルトの名無しさん mailto:sage [2019/05/21(火) 20:31:52.25 ID:8vKfOnx40.net] ansi.sysを組み込めばVT100互換エスケープシーケンスが という昔話…と思ったが、ググったらvistaまであったんだな驚き Windows 10 Threshold 2(10.0.1058)ではコマンドプロンプトでANSI/VT100互換表示が可能に というスラドの記事も出た
625 名前:デフォルトの名無しさん [2019/05/21(火) 20:52:46.26 ID:BVi2WQ22a.net] 最後に改行出すんじゃなくて最初に改行出すようにすれば良いだけでは? 一番最初の行だけは最初に出さなければ良いだけ。 バッファリングされて出力されないのが嫌なら行末でfflush()する。
626 名前:デフォルトの名無しさん mailto:sage [2019/05/21(火) 21:47:10.75 ID:n1jvW3Ih0.net] >>606 >>599-600
627 名前:デフォルトの名無しさん [2019/05/21(火) 22:06:40.11 ID:Y+BS98b80.net] >>607 おお。既にあった。 さっきスマホで見てて気付かなかった。
628 名前:デフォルトの名無しさん [2019/05/21(火) 22:09:47.12 ID:JtLDtEYt0.net] >>604-607 603です。>>600 の意味をちゃんとわかってませんでしたが、>>606 の方のレスでわかりました。 >>600 の方が安全な気がするのでそちらを検討します。
629 名前:デフォルトの名無しさん [2019/05/24(金) 09:00:19.45 ID:h3dkW7YJ0.net] C言語はクラスが無い。 それは実際どれくらい問題になりますか? 昔C使ってたけど、本格的な抽象的設計をやってたわけじゃなくて、 最近Java使っててそういうのをやりだしたけど、 今思い返してみるとC言語はクラスや継承や多態性が無いから かなり厳しい言語なんじゃないかな、と思ったんです。 メジャーなカーネルがCで作られてるという事実に驚愕します。 クラス無しで大規模開発は不可能としか思えません。 それどころか、1アルゴリズムの実装でもクラスは有用だと思うんですが。 最近、NimとかRustのようなCを代替するかもしれない勢いのある言語があります。 そういう言語はかなり抽象的な設計が可能です。 そういうのと比べると、小さなデバイスドライバみたいなものはCでいいだろうけど、 大規模開発におけるCはかなり無理があるんじゃないかな?と そうでもないものですか?
630 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 09:04:22.51 ID:a6wIXg41a.net] まあファイルがクラスと同じだし。 継承はしづらいけど、そんなもん使ったらC++でもむしろ見通し悪くなるでしょ?
631 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 10:11:20.70 ID:M2ZwKTAn0.net] 最大のデバイスドライバがOSのカーネルなんじゃねえの そしてそれがC言語の限界
632 名前:デフォルトの名無しさん [2019/05/24(金) 10:43:06.36 ID:h3dkW7YJ0.net] Linuxカーネルは2100万行を超えているそうなので たぶん地球上でもっとも大規模な開発の1つです。
633 名前:デフォルトの名無しさん [2019/05/24(金) 11:21:47.36 ID:0dR+L/D60.net] 責任ある人は気がくるっているじゃない。
634 名前:デフォルトの名無しさん [2019/05/24(金) 12:25:59.56 ID:Cw+6mW4za.net] Cでもオブジェクト指向的に考えて作ることは可能。構造体へのポインタまたは情報を区別する番号などを渡してその中身に基づいて処理する関数作ればいいので。 ファイルアクセスとかは作りがそうなってるよね。
635 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 12:32:21.84 ID:M3xcEept0.net] クラスはコンストラクタ/デストラクタは活用したけど 継承で面倒になって、ちょっと便利な関数付き構造体としてしか設計したことない。
636 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 12:35:03.01 ID:C+5joBz9M.net] C言語ではオブジェクト指向も関数型プログラミングもできる。その下位レイヤーだから。 面倒臭いけど。
637 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 12:50:51.48 ID:8pSuDyEhM.net] >>613 デバドラとかが山ほどあるだけでコア部分はそんなにたいしたことないよ
638 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 12:53:08.72 ID:8pSuDyEhM.net] >>610 構造体に関数ポインタ入れたりすれば継承も多態も可能 書くのが面倒ってだけの話 モジュールを適切に分割すれば個々の開発部分はそんなにでかくならないし
639 名前:デフォルトの名無しさん [2019/05/24(金) 12:59:14.48 ID:Cw+6mW4za.net] まあしかしC++は複雑怪奇な状態になったような感じがするのでなんか別の言語でオブジェクト指向やった方が良いような気がする。
640 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 13:49:11.26 ID:FIKXvkBI0.net] Javaがとてもシンプルな言語に見えてくる
641 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 14:27:11.63 ID:YkjJvwKvd.net] linux kernelなんておもくそオブジェクト指向的な構造だろ
642 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 19:13:34.31 ID:E0qJKDus0.net] 関係ないけどOOPが流行り始めた頃に「WindowsのUIはオブジェクト指向だ」と言ってたやつを思い出した。
643 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 19:26:36.07 ID:omgaeJxY0.net] 目指していた方向はそうだったと思う
644 名前: mailto:sage [2019/05/24(金) 20:26:08.87 ID:0N6+tWvP0.net] >>615 >Cでもオブジェクト指向的に考えて作ること あくまでも「オブジェクト指向『的』」であることに注意すること C ではオブジェクト指向を実現できない(断言)
645 名前: mailto:sage [2019/05/24(金) 20:27:08.05 ID:0N6+tWvP0.net] >>617 >C言語ではオブジェクト指向も関数型プログラミングもできる C ではオブジェクト指向はできない(断言) 継承をCでどのように記述するのでしょうか?
646 名前: mailto:sage [2019/05/24(金) 20:27:59.68 ID:0N6+tWvP0.net] >>622 >linux kernelなんておもくそオブジェクト指向的な構造だろ あくまでも「オブジェクト指向『的』」であってオブジェクト指向そのものではありません(断言)
647 名前:デフォルトの名無しさん [2019/05/24(金) 20:41:47.14 ID:1FXcUtRQa.net] いやできなくはないよ。何せC++は元々はCへのコンバータだったしな。C++のソースを読んでC言語に変換して後のことはCコンパイラに任せてたんだよ。それが初期のC++。 もちろんCは言語そのものがオブジェクト指向をサポートしてないから人間がそれをやろうとするととても面倒な事になるけどな。
648 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 20:51:16.47 ID:E0qJKDus0.net] そんなん言い始めたらアセンブラでもオブジェクト指向プログラミングできることになっちゃう。 言語としてOOPがサポートされてなきゃ認められないでしょ。
649 名前: mailto:sage [2019/05/24(金) 21:00:32.57 ID:0N6+tWvP0.net] >>628 >C++のソースを読んでC言語に変換して後のことはCコンパイラに任せてたんだよ。それが初期のC++。 C++ から C へのトランスパイラが存在したからといって、C にてオブジェクト指向(的ではなくそのものずばり)なプログラミングができるわけではありません C++ のコンパイラが存在するからといって機械語が OO でないのと同じです、まず、 C++ https://ideone.com/vAp2Sj に対応する C のコードを示してください
650 名前: mailto:sage [2019/05/24(金) 21:01:09.07 ID:0N6+tWvP0.net] >>629 >言語としてOOPがサポートされてなきゃ認められないでしょ。 激しく同感いたします!
651 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 21:12:51.85 ID:ZwmHdTYl0.net] >>610 全く問題にならない classというキーワードがなくても コードを書く者の考え方次第でカプセル化や継承はできる FILE構造体がその例だ 多態性がないというのは、おまえさんの認識不足で 関数ポインタでそんなものはすぐに実現できる そういう認識不足があるからこそ メジャーなカーネルをなぜ書けたかが理解できないのだ
652 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 21:15:04.81 ID:ZwmHdTYl0.net] >>630 対応するCのコードを示せるやつがいたら、おまえどうする? 朝8時の品川駅のホームでストリーキングでもするか?
653 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 21:24:37.67 ID:QPLeHwR8a.net] まあ継承なんてオブジェクト指向と関係ないよ
654 名前: mailto:sage [2019/05/24(金) 21:45:54.65 ID:0N6+tWvP0.net] >>632 >classというキーワードがなくても >コードを書く者の考え方次第でカプセル化や継承はできる C ではカプセル化はできても継承は不可能ですよ
655 名前: mailto:sage [2019/05/24(金) 21:46:59.73 ID:0N6+tWvP0.net] >>633 >対応するCのコードを示せるやつがいたら、おまえどうする? あなたができないことをそんなにアピールしなくてもいいと思いますよ
656 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 21:56:28.68 ID:wwZ4gkZH0.net] 仮想関数テーブルの実装方法について語るスレはここですか?
657 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 22:01:07.63 ID:ZwmHdTYl0.net] >>635 いーや、できる おまえさん禿本やリップマンくらい読んだか? 裸踊りを賭す自信もねえやつがいきがってんなよ
658 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 22:02:14.93 ID:ZwmHdTYl0.net] >>637 いいぜ おら、来いや
659 名前:蟻人間 mailto:sage [2019/05/24(金) 22:06:22.36 ID:/xfbOr910.net] >>630 https://ideone.com/omqT5r
660 名前: mailto:sage [2019/05/24(金) 22:17:20.89 ID:0N6+tWvP0.net] >>638 ではストロヴストルップやリップマンはどういっているのか、ここに引用していただけますか? あらかじめいっておきますが、引用はできない、なぜならば、そんな内容をストロヴストルップもリップマンも書いていないのだから
661 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 22:18:09.05 ID:TMKOHW7N0.net] >>625-627 , >>629 オブジェクト指向と言う概念と実装の区別がついてないんだな 低能なプログラマーによくある行動w 例えばLinuxで言えばリダイレクトなんて言うのはもろオブジェクト指向な機能だよね Applicatlon > xxx ってやればxxxがファイルならApplicatlon が出力したデータをファイルに書き込むし、xxxが端末なら端末にデータを表示するし、xxxがプリンタならデータを印刷する Applicatlonは出力先が何であるかを気にする必要はない もちろんLinuxはC言語でこれを実現してるしより面倒だろうけど当然アセンブラで実装することも可能
662 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 22:21:05.39 ID:0NhXAFL60.net] 概念ならFILE構造体とそれの操作関数群
663 名前: mailto:sage [2019/05/24(金) 22:21:27.40 ID:0N6+tWvP0.net] >>640 >typedef struct C >{ > A ThisA; > B ThisB; > int c; >} C; これは委譲であって継承ではありません。私は >>626 で「Cでは継承はできない」と主張しており、これを否定するために委譲は使えません
664 名前: mailto:sage [2019/05/24(金) 22:23:27.35 ID:0N6+tWvP0.net] >>642 それは smalltalk 的な OO であって C++ の OO の概念とは多少食い違うと思います
665 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 22:24:05.41 ID:0NhXAFL60.net] コンストラクタとデストラクタの機構だけは欲しいと思ったことがしばしば
666 名前: mailto:sage [2019/05/24(金) 22:24:31.62 ID:0N6+tWvP0.net] >>643 FILE は OO 的ではありますが、OO そのものではありません OO というからには委譲とは別の継承を表現できねばなりませんが、 C では継承を表現できません
667 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 22:41:32.12 ID:K6buSCwsM.net] glibとか大昔からあるじゃん… glibがooでないならooの定義をまず示せ
668 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 22:42:05.32 ID:hUeULEjja.net] オブジェクト指向ってC++固有の概念なの? だとすると、そりゃCで実現は無理でしょう。関係ないんだから。CとC++は。
669 名前: mailto:sage [2019/05/24(金) 22:44:44.02 ID:0N6+tWvP0.net] >>648 glibc++ は OO かもしれませんが glibc が OO だとは寡聞にして聞きませんね
670 名前: mailto:sage [2019/05/24(金) 22:45:51.47 ID:0N6+tWvP0.net] >>649 >オブジェクト指向ってC++固有の概念なの? いいえ、Java も C# も OO だし、 python も ruby も OO で表現できます
671 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 22:50:26.22 ID:hUeULEjja.net] >>650 GLibだよGLib 今知らないのもどうかと思うけど、使ってみると面白いと思うよ
672 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 22:51:22.70 ID:hUeULEjja.net] >>651 いや、それだとつじつま合わないでしょ 自分の決めた道を突き進めよ
673 名前:蟻人間 mailto:sage [2019/05/24(金) 22:53:40.43 ID:/xfbOr910.net] GTKのGLibだよね。
674 名前: mailto:sage [2019/05/24(金) 22:54:27.15 ID:0N6+tWvP0.net] >>653 どうつじつまがあわないというのですか?説明ください 私は「OO ならば委譲と区別された継承を記述されなければならない」と主張しています
675 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 22:55:59.59 ID:K6buSCwsM.net] >>650 glibcじゃねーよ… gimp、inkscape、gnomeほか様々なソフトウェアで使われてる。 linuxとは無縁だったんだな
676 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 23:36:16.20 ID:SCqWQYPI0.net] >>629 出来るに決まっている OO言語はオブジェクト指向プログラミングがやり易いようになっているだけでそれじゃなきゃOO出来ないというのはOOについて理解していないだけ
677 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 23:46:49.71 ID:SCqWQYPI0.net] >>644 多重じゃない継承の場合Cでは1つめのメンバにベースクラスのインスタンスを書くというルールなだけ それだけで呼び出し元のコードはほぼなにも考えずにベースクラスの機能を使うことができる
678 名前:デフォルトの名無しさん mailto:sage [2019/05/24(金) 23:58:34.02 ID:S5Q/uU3j0.net] >>655 CでもOOできるし、継承できるし、オーバーライドもできる。 20年位前の本に「ANSI C に準拠したコンパイラならできる」と紹介されている。 メモリを意識したコードを書けない人には理解できないけどね。
679 名前:デフォルトの名無しさん [2019/05/25(土) 00:01:58.97 ID:7Hh+Cor80.net] C言語はABIが標準化されている、という文を見たんですが、 その標準仕様の名前は何ですか? 新しいプラットフォームがその標準仕様を満たせば バイナリレベルあるいはソースレベルで移植性があるんでしょうか?
680 名前:デフォルトの名無しさん mailto:sage [2019/05/25(土) 00:07:07.65 ID:KPhaQb+n0.net] >>654 ていうかお前、MZ級にウンコな片山博文やんけ。 >>660 標準の名前は無いんじゃないの? とりあえず「ABI」でググれ。
681 名前:デフォルトの名無しさん mailto:sage [2019/05/25(土) 00:11:09.80 ID:oops2jeN0.net] アーキテクチャ跨いでABIが統一できるわけないよね 引数の渡し方なんてアーキテクチャ変わったらそもそも使えるレジスタ変わるし 同一アーキテクチャの特定OS内ならバージョン変わってもABI互換ってのは良くあるけど
682 名前:蟻人間 mailto:sage [2019/05/25(土) 00:29:35.52 ID:2ZlhwbAL0.net] >>661 そのプライドを大切にしろよ
683 名前:デフォルトの名無しさん mailto:sage [2019/05/25(土) 05:52:48.29 ID:Tic4GHY30.net] >>645 お前のOOの定義書いてくれ 俺の思うOOじゃないとか言われたらどうしようもないわなw
684 名前:デフォルトの名無しさん mailto:sage [2019/05/25(土) 05:57:11.32 ID:6KmI3UXB0.net] Cでオブジェクト指向プログラムなんて書くのは時間の無駄 速度が必要な部分だけCで作るのが正解
685 名前:デフォルトの名無しさん mailto:sage [2019/05/25(土) 06:05:28.22 ID:6T2yG8cn0.net] >>641 てめえの怠慢を俺が尻拭いする筋合いはねえぜ 調べるところまで教えてやったんだ 自分で調べる気がねえなら不勉強のまま取り残されろ
686 名前:デフォルトの名無しさん mailto:sage [2019/05/25(土) 07:19:56.39 ID:DOpjF4HUM.net] >>665 > Cでオブジェクト指向プログラムなんて書くのは時間の無駄 そう言うこと ただ時間がかかると言うのとできるできないの話は別 なのでお前のレスのほうが時間の無駄w
687 名前: mailto:sage [2019/05/25(土) 15:51:01.79 ID:jppBZDTS0.net] >>658 >多重じゃない継承の場合Cでは1つめのメンバにベースクラスのインスタンスを書くというルールなだけ C では構造体のメンバの順番をプログラムから指定することはできたのでしょうか? C コンパイラはアラインメントを考慮して最適化をはかり構造体のメンバを、プログラマの記述から適宜入れ替えていもいいのでは? となると一つめのメンバにベースクラスのインスタンスを書いても、コンパイラに入れ替えられてしまっては無意味なのでは?
688 名前: mailto:sage [2019/05/25(土) 15:52:11.46 ID:jppBZDTS0.net] >>659 >CでもOOできるし、継承できるし、オーバーライドもできる。 できないとおもいますよ、できるというのなら >>630 を C で記述してみてください >20年位前の本に「ANSI C に準拠したコンパイラならできる」と紹介されている。 出典を明記ください
689 名前: mailto:sage [2019/05/25(土) 15:53:43.84 ID:jppBZDTS0.net] >>666 >てめえの怠慢を俺が尻拭いする筋合いはねえぜ あなたは私の怠慢を主張するのと同様の筋で、私はあなたの欺瞞を主張します 出典元や引用を正確にできないのであれば、あなたは嘘をついていると判断されてもしかたがないと思います
690 名前: mailto:sage [2019/05/25(土) 15:55:14.60 ID:jppBZDTS0.net] >>661 片山先生は私とは比較にならないほど生産性の高いプログラマですよ
691 名前: mailto:sage [2019/05/25(土) 16:03:59.98 ID:jppBZDTS0.net] >>652 はじめて知りました、>>650 は勘違いした内容でした、すみません ご紹介ありがとうございます。今試しているところです!
692 名前:デフォルトの名無しさん mailto:sage [2019/05/25(土) 16:17:34.75 ID:Tic4GHY30.net] >>668 真面目な話、規格書読んでこい ツッコミどころが頓珍漢すぎる
693 名前: mailto:sage [2019/05/25(土) 17:02:40.54 ID:jppBZDTS0.net] >>673 コメントありがとうございます。確かに >>668 には誤りが含まれていました ISO/IEC 9899:1999 6.7.2.1
694 名前:.5 As discussed in 6.2.5, a structure is a type consisting of a sequence of members, whose storage is allocated in an ordered sequence, JIS X3010:2003 構造体は,メンバの列から成る型とし,メンバの記憶域は,並べられた順に割り付ける(6.2.5参照)。 しかし、この記述は構造体のパディングが構造体の先頭に詰められる場合を排除していないと考えます よって、>>658 >多重じゃない継承の場合Cでは1つめのメンバにベースクラスのインスタンスを書く >それだけで呼び出し元のコードはほぼなにも考えずにベースクラスの機能を使うことができる 構造体の先頭にパディングがあった場合は、この記述は正しくないのではないでしょうか。 [] [ここ壊れてます]
695 名前: mailto:sage [2019/05/25(土) 17:37:11.41 ID:jppBZDTS0.net] >>674 よくよく考えると、私の「この記述は構造体のパディングが構造体の先頭に詰められる場合を排除していないと考えます」もかなり疑わしい、 パディングというものは、一つのメンバがあって、それに対してもう一つのメンバを置くときにパディングを置くものであって、最初からパディングを置く必然性がないですね struct S { int a; } b; のとき &b = &(b.a) は保障されている、時間がたつにつれてそんな気がどんどんしてきました… >>658 を認め、同時に単一継承であれば C で OO と継承を表現できることを認めます
696 名前: mailto:sage [2019/05/25(土) 18:11:59.97 ID:jppBZDTS0.net] >>674 > a type consisting of a sequence of members, whose storage is allocated … この is にも惑わされてしまいました これは a type consisting of a sequence of members, each of which is allocated about storage in an ordered sequence とか a type consisting of a sequence of members, each of which's storage is allocated in an ordered sequence くらいに解釈するべきなんですね 検討する機会をいただきありがとうございました
697 名前:デフォルトの名無しさん mailto:sage [2019/05/25(土) 21:04:32.61 ID:DDy3bloZM.net] >>675 絶対許さんぞおおおお
698 名前:デフォルトの名無しさん mailto:sage [2019/05/25(土) 21:07:06.72 ID:aM9QB8YDa.net] オブジェクト指向って抽象化が目的なのに、メモリ配置とか気にするのは馬鹿みたいだよな
699 名前:デフォルトの名無しさん mailto:sage [2019/05/25(土) 21:23:55.56 ID:cjrLAMgS0.net] MicrosoftのCOMはほとんど全てのコンパイラが構造体のメモリ配列を同じ様にするってのを利用してるんだっけ?
700 名前:デフォルトの名無しさん mailto:sage [2019/05/25(土) 22:13:30.07 ID:UN9uDEfaM.net] >>678 ここにも概念と実装の区別がついてないバカが…w
701 名前:デフォルトの名無しさん mailto:sage [2019/05/25(土) 23:25:49.27 ID:KPhaQb+n0.net] >>669 C言語でオブジェクト指向を表現する (クラス、継承) https://qiita.com/qiita_kuru/items/8f3441bce9b2f53d1d62 この辺でも読んどけ。 「何故できるか」まで言及したもっといい文献はあるがカスには教えない。 俺は「せざるを得ない」状況だったのでCでOOしたが、ネイティブでOOできるならそれに越したことはない。 あ、同じ板でハッシュが一致してるのでお前は蟻。
702 名前:デフォルトの名無しさん mailto:sage [2019/05/26(日) 01:24:13.78 ID:zv+FEFKTa.net] >>681 またおまえか
703 名前:デフォルトの名無しさん mailto:sage [2019/05/26(日) 08:36:08.16 ID:o+/j3IaP0.net] >>670 は? 俺は主張なんざしてねえぜ 事実をありのまま指摘しただけだ 何勘違いしてやがる というか勘違いということにせねば立場がねえってかw
704 名前:デフォルトの名無しさん mailto:sage [2019/05/26(日) 08:56:22.54 ID:7tI1cTYc0.net] もうこんなとこで喧嘩しても勝敗つかないんだからやめろw 仲良くできねえのかお前らは
705 名前:デフォルトの名無しさん mailto:sage [2019/05/26(日) 12:29:05.12 ID:lzKtO2WM0.net] でも冷静になって考えてみろ 単細胞時代から何億年と喧嘩してきた結果今の人間がいる訳だから喧嘩をやめてしまったらそれは果たして生物と言えるのか 逆に言えばAIが人知を超える時 人間は機械に滅ぼされ地球から人間はいなくなっているという事 つまり今何をすべきかと言うと人間は思考をやめアホになるべきである
706 名前: そうアホの坂田こそ未来の救世主ネオなのである [] [ここ壊れてます]
707 名前: mailto:sage [2019/05/26(日) 15:17:23.15 ID:CpBTYp0n0.net] >>681 そのご紹介のリンク先は、内容について、はっきりいって詰めが甘いです すなわち、継承と委譲を区別できていません そんな中途半端な理解で quita に掲載するとか、玉か石かどちらかといえば、石の部類でしょう、全然参考になりませんでした そんな中途半端な内容の記事を掲載するあなたも同様と判断いたします
708 名前: mailto:sage [2019/05/26(日) 15:19:14.79 ID:CpBTYp0n0.net] >>683 事実かどうかは、主観的か客観的か、に依存すると思いますが、 相対論においてはすべての事象について純客観的などありえない…@ ので、@より、あなたは主観を主張しているものと私は理解します
709 名前:デフォルトの名無しさん mailto:sage [2019/05/26(日) 15:46:43.76 ID:aNhG7Lwu0.net] >>686 「継承」に必要な操作一式を委譲に基づいて提供できているなら継承できていると思うんだけど、 言語サポートを伴って暗黙的に機能しない限り「継承」と呼ぶべきではない、ということなの? そこで明確に区別することにあんまり意義が見出せないんだけど、その定義どっか出典示せる?
710 名前: mailto:sage [2019/05/26(日) 15:52:14.70 ID:CpBTYp0n0.net] >>688 委譲による実装で継承を実現できているのなら、それは継承(の一形態)である、…@ という主張ですね @は私にも理解できますが、委譲はダイヤモンド継承を回避できない欠点があるのでは、と考えています 「ダイヤモンド継承」については C++ の書籍には大概載っているかと、具体的な書籍名は探しておきます