X



C言語なら俺に聞け 151

■ このスレッドは過去ログ倉庫に格納されています
1デフォルトの名無しさん (ワッチョイ cf8f-fy95)
垢版 |
2019/04/02(火) 11:23:37.62ID:SQXqRaAc0
!extend:checked:vvvvv:1000:512
C言語の話題のみ取り扱います C++の話題はC++スレへ
質問には最低限の情報(ソース/コンパイラ/OS)を付ける
数行で収まらないソースは以下を適当に使ってURLを晒す
https://paiza.io/
https://ideone.com/
http://codepad.org/

C11
http://www.open-std.org/jtc1/sc22/WG14/www/docs/n1570.pdf

C99
http://www.open-std.org/jtc1/sc22/WG14/www/docs/n1256.pdf
http://kikakurui.com/x3/X3010-2003-01.html

C FAQ 日本語訳
http://www.kouno.jp/home/c_faq/

JPCERT C コーディングスタンダード
https://www.jpcert.or.jp/sc-rules/
VIPQ2_EXTDAT: checked:vvvvv:1000:512:----: EXT was configured
2019/05/05(日) 09:08:14.08ID:3EWrT4Pn0
>>389
無論使いさえすればいい、というわけではなく、この例では小さなシェルを実装しており、シェルのパイプ機能を実装するのに三重ポインタを使ったのです
2019/05/05(日) 09:21:39.41ID:2T/oydys0
>>387
引数を介すと代入が減るってこと?
2019/05/05(日) 09:47:47.39ID:3EWrT4Pn0
>>391
代入命令が増えるという意味ではなく、「同じ値」なのに代入してしまう、という作業が >>378「戻り値でポインタを返」す方式の書き方だと不可避です
2019/05/05(日) 10:05:07.93ID:bV6goPu10
呼び出しの前後で、ptrの値が 同じかもしれない、場合よっては変わるかもしれない関数

ptr = func1(ptr, opt); と func2(&ptr, opt);

うーんどっちも使うな…
2019/05/05(日) 10:28:11.80ID:2T/oydys0
>>392
じゃあ、一時変数に代入しとけば?
2019/05/05(日) 10:29:23.05ID:3EWrT4Pn0
>>393
前者
>ptr = func1(ptr, opt); 
は初心者用で、>>392 のいう無駄な代入が含まれています、二重ポインタがわかるのなら後者にするべきです
2019/05/05(日) 10:30:14.08ID:3EWrT4Pn0
>>394
シンプルな記述ができるのに、わざと複雑な書き方にするのは問題なのでは?
2019/05/05(日) 10:32:32.58ID:2T/oydys0
>>396
じゃあ、戻り値そのまま使えば?
mallocは使うんでしょ?
2019/05/05(日) 10:33:46.84ID:3EWrT4Pn0
>>397
その場合無駄な代入が発生しますね、>>393 がいい例を示しています
2019/05/05(日) 10:35:01.06ID:bV6goPu10
エラー伝達に NULL を使う realloc は即代入するとお漏らししちゃうし
あれ、なん引数書き戻しにしなかったんだろう? 素朴な疑問
2019/05/05(日) 10:35:57.12ID:2T/oydys0
>>398
代入されているのかされていないのか、わからない方が良いってこと?
2019/05/05(日) 10:36:08.55ID:bV6goPu10
×あれ、なん引数書き戻しに
○あれ、なんで引数書き戻しに
2019/05/05(日) 10:41:29.60ID:2T/oydys0
>>399
正直、nullが来た時点で終わってるしなあ…。
まあでも一時変数使うのが筋だと思いますよ。戻り値でも引数でも同じこと。
2019/05/05(日) 11:25:51.36ID:3EWrT4Pn0
>>400
ちがいます
代入するのか代入しないのかは malloc() したかしなかったかにかかっています。
代入は malloc() したとききだけにすればよく それが >>393 の func2(&ptr, opt); の書き方
一方 >>393 ptr = func1(ptr, opt); は malloc() したかしないかにかかわらず代入を行います、これは無駄な代入を含みます
2019/05/05(日) 11:31:24.71ID:2T/oydys0
>>403
だから、関数の内部的に何してるのかわからんのが良いってことじゃない?
2019/05/05(日) 11:37:36.53ID:3EWrT4Pn0
>>404
着目点はそこにはありません。関数による記述で内部を隠蔽するのが目的ではありません
問題は、malloc() したときだけ代入し、malloc() しなかったときには代入しない、という記述を正確にかけるかどうか…@、にかかっており
>>393 ptr = func1(ptr, opt); は@を記述できる可能性が皆無、一方
>>393 func2(&ptr, opt); は@を記述できる可能性がある、というわけです
2019/05/05(日) 11:38:01.66ID:orE8GGyod
>>393
前者の方が好ましい
2重ポインタなんて最適化の妨げになるものは、それしか使えない場面でのみ使うべき
2019/05/05(日) 11:44:46.28ID:3EWrT4Pn0
>>406
非常に大きな二分木(ノートが1億個)があって、そのはるか先端で malloc() してそこで代入すればいいだけなのに、
その先端から root に戻ってくる途中の30箇所ほどで、軒並み全部のノードで「必要のない無駄な代入」をするのですか?

>それしか使えない場面でのみ使うべき

この二分木を実装する、というのがまさしく「それしか使えない場面」なのですよ
2019/05/05(日) 11:45:42.03ID:2T/oydys0
>>405
つまり、後者でmallocしてnullが返った時はそれを代入するってことですか?同じじゃん。
2019/05/05(日) 11:47:06.67ID:2T/oydys0
>>407
二分木のコストってのは比較であって代入じゃないと思いますよ。
まあアルゴリズムの一般論としては。
2019/05/05(日) 11:53:15.92ID:3EWrT4Pn0
>>408
>>393 func2(&ptr, opt); では
malloc() して null が返ってきたときは、例えば何もしない、ということはできますね

でも >>393 ptr = func1(ptr, opt);
は、malloc() しようがしまいが代入してしまいますね、これは「やる必要のない無駄な代入」が含まれることになり、好ましくないです
>>393 ptr = func1(ptr, opt); の記述法は二分木を最初に習うときに、この記述法で理解を促すという意味では有用であっても、
いつまでもこれで書いているようでは進歩していない、もっといえば怠惰である、と考えています
2019/05/05(日) 11:55:53.32ID:3EWrT4Pn0
>>409
しかし無駄な代入を放置してよいというわけではないでしょうね、削れるところは削るべきです
単純二分木よりさらに改良された平衡二分木(AVL木、赤黒木等)を紹介する書籍では、最初から >>393 func2(&ptr, opt); で記述されていますよ
2019/05/05(日) 11:57:28.30ID:2T/oydys0
>>410
じゃあ隠蔽しろという話なんじゃないの?
関数の中で成功失敗を判定して外にnullは返すな入力時のままにしとけ、という関数。
2019/05/05(日) 11:58:36.27ID:2T/oydys0
>>411
代入回数比較してよ。頼むよ。
2019/05/05(日) 12:05:45.99ID:3EWrT4Pn0
>>412
ちがいますね
問題は、malloc() したときだけ代入し、malloc() しなかったときには代入しない、という記述を正確にかけるかどうか…@、にかかっています。

>>413
>>407 に書いておきました、1億ノードの二分木にて各ノードが最適に配置されているとして、削ることのできる代入は malloc() 一回に対して 30 個の代入になります
>>393 ptr = func1(ptr, opt); では 1億ノードの二分木にノードを追加する際、30個の無駄な代入が発生します
代入のコストは大したことがない、にしても、アルゴリズムを正確に記述できないのは問題ですね
洗練された記述とはそういうものではないでしょうか
2019/05/05(日) 12:48:51.19ID:2T/oydys0
>>414
いや、mallocがnull返した時はいれないんでしょ?
成功か失敗かじゃないの?呼んだかどうかじゃなくて。
2019/05/05(日) 12:52:54.83ID:2T/oydys0
仕事では戻り値に成功失敗が入ってオブジェクトのポインタは引数に来るような関数は使うけどさ、
結局どっちもチェックするよ。信じられねえもんな。
2019/05/05(日) 13:12:30.38ID:3EWrT4Pn0
>>415
malloc() が成功したか失敗したかは、今の話には関係ありません
今関係があるのは、
malloc() したときだけ代入し、malloc() しなかったときには代入しない、という記述を正確にかけるかどうか…@
です
2019/05/05(日) 13:42:25.11ID:2T/oydys0
>>417
じゃあ、絶対代入するってことだろうよ。
引数に渡したポインタに。ポインタを。
2019/05/05(日) 13:51:49.48ID:3EWrT4Pn0
>>418
malloc() したときは代入しますよ、でも malloc() しないときは代入なんかせず、そのまま呼び出し元に返るだけです
それが>>393 ptr = func1(ptr, opt); 方式と絶対的に違うのです
2019/05/05(日) 13:55:35.88ID:2T/oydys0
>>419
戻り値はvoidってこと?
2019/05/05(日) 14:02:45.71ID:3EWrT4Pn0
>>420
>>393 func2(&ptr, opt); 式なら void もありえます
2019/05/05(日) 14:08:06.37ID:2T/oydys0
>>421
いや、必須なのでは?
2019/05/05(日) 14:11:38.90ID:3EWrT4Pn0
>>422
いいえ、実際に実装するならば、エラーを伝達する手段として返り値を準備することは大いにありえるでしょうね
void が必須ではありません
必要な代入なら使えばいい、でも
>>393 ptr = func1(ptr, opt);
方式は不必要な代入があり、単に二重ポインタを使用して記述すればこれは除去できるので、
>>393 ptr = func1(ptr, opt);
を書くのは問題だし、これを書く人は頭を使っていない、と判断します
2019/05/05(日) 14:33:08.37ID:bV6goPu10
異常は戻りをNULLにするパティーンで 
 node_t *func3(node_t**, ...)

正常だった場合に ptr = func3(&ptr, opt); と書けるしw (無駄な努力の可能性
2019/05/05(日) 14:34:34.27ID:bV6goPu10
って書いたけど鼻から悪魔踏みそうな嫌らしさがあるな…
2019/05/05(日) 15:03:58.07ID:3EWrT4Pn0
>>424
そのパターンでは、異常値 NULL をうっかりノードに登録してしまうと、そのノードより下が浮いてしまい危ないですね、ま、異常系をミスったままリリースしてしまうことも私はよくやりますけど
2019/05/05(日) 15:42:24.13ID:8x8syc+Fa
>>423
いや、必須でしょ?代入消せるんだから。消さないと。
2019/05/05(日) 17:54:28.38ID:3EWrT4Pn0
>>427
言葉尻を捕らえて攻めたつもりになっているようですね
「すべての代入を消去できる」なんていってませんよね

>>393 ptr = func1(ptr, opt);

この代入は不要な代入を含むので、

>>393 ptr = func1(ptr, opt);

は不適当な書き方だ、とこれまで首尾一貫して述べているのです
2019/05/05(日) 18:13:23.13ID:bV6goPu10
423の文意は
「void が必須なわけではなく
 引数と同じ型のポインタを戻すことはせずに、別の目的の何か、たとえばエラーコードとして int を戻す
 なんてのはアリでしょ?」
ってことだと思うけど
2019/05/05(日) 18:42:49.42ID:dOx23ziba
returnしちゃだめでしょ
代入が駄目ってくらいだから
2019/05/05(日) 18:56:43.02ID:bV6goPu10
「代入不要なケースでも代入記述を要求するのはよろしくない」スタイルの延長だと
戻り値評価も破棄可能ならそうすべき って話か
2019/05/05(日) 19:00:00.98ID:3EWrT4Pn0
>>430
どんな代入もだめだとは主張していませんね…

>>393 ptr = func1(ptr, opt);
方式は不必要な代入があり、単に二重ポインタを使用して記述すればこれは除去できるので、
>>393 ptr = func1(ptr, opt);
の代入が駄目だとはいってきていますけれども
2019/05/05(日) 19:03:30.45ID:TxpPZKKr0
>>407
2019/05/05(日) 19:13:46.27ID:TxpPZKKr0
あ、ごめん、ミスって文章を書く前に投稿してもうた。

>>407
あらためて確認するが、この代入を「無駄」としているのはアルゴリズムの表現の上では不要なことをしているという
意味の上での無駄であって、性能上の無駄という意味ではないんだね?
そして、アルゴリズムを正しく表現する上では (ときには二重・三重のも含めて) ポインタが必要だと。
2019/05/05(日) 20:16:09.59ID:3EWrT4Pn0
>>434
>性能上の無駄という意味ではないんだね?
性能の上で分析するとなると、間接参照にてデータをロード、ストアするコストと値をストアするコストを天秤にかける、ことになりますね
なるほど、その点を言いたくて、でも言いたくなくて、しつこく絡んでいたのですか…

私は二重ポインタでの表現の方がトータルでお得だ、とは思ってはいますが、これまで表に出ている私の発言は、あえてそこには踏み込まず(だって性能の話はうかつに断言できませんからね…)、
おっしゃるとおり「アルゴリズムの表現の上では不要なことをしている」に留まっています
2019/05/05(日) 20:57:45.43ID:TxpPZKKr0
>>435
たとえば数学上の表記なら「A=1 であり B=1 のとき A=B は真である」と「1=1 は真である」には何も差が無い。
途中で名前を付けるのは人間に対する便宜であって、無駄な「操作」は存在しない。

代入が無駄たりうるのは C のパラダイムだからなので、
「C で表現するにはポインタが必要だし、代入では不適当だ」は事実であっても
「ポインタが無い言語では表現できない」というわけではないよ。

C の低級な世界でまともな意味論を表現しようとするのがそもそもの間違いだろう。
2019/05/05(日) 21:02:18.49ID:3EWrT4Pn0
>>436
>「ポインタが無い言語では表現できない」というわけではないよ。
それは理解しています、なぜなら
Java での二分木の実装を検討したことがある(探せば2ch過去ログにあるかもしれません)
Java にはポインタはありませんが、実装できるかできないか、といえば「できる」の方に入りますね
2019/05/05(日) 21:54:26.85ID:TxpPZKKr0
>>437
そこまでわかっているのなら、
「代入しない」と「同じ値を代入しなおす」が意味論的に等しいということがどうしてわからないんだ。
439デフォルトの名無しさん (ワッチョイ 2f05-S4IJ)
垢版 |
2019/05/05(日) 23:34:40.25ID:RXFRr1FQ0
C言語のプログラム内で確保していいメモリってユーザー空間の仮想メモリ上限いっぱいまで取っていいの?
複数の変数a, b, c, ・・・の値を表示するだけのプログラムを時系列に並べて考えてみるんだけど

0. 実行ファイルを起動する
1. 32bitプロセスが生成される ←たとえば32bit windowsだとユーザー空間とカーネル空間で計4GBの仮想メモリが確保される
2. int a; ←仮想メモリ(1で確保されたユーザー空間)上にaが確保される
int b; ←上に類似
int c; ←上に類似
・・・・・(複数の変数の宣言やprintf関数が続く)

こんな感じなんだろうけど
上記の2でユーザー空間いっぱいになるまで変数を宣言してもいいの?
2019/05/05(日) 23:38:14.20ID:TxpPZKKr0
>>439
いいけど、もっと効率的な方法があるならそれに越したことは無いっていうそれだけの話
441デフォルトの名無しさん (ワッチョイ 2f05-S4IJ)
垢版 |
2019/05/05(日) 23:41:29.98ID:RXFRr1FQ0
簡潔に書くと
安全のためにはどこまでメモリを使っていいの?
そのメモリの大きさはユーザー空間の上限と同じなの?
という室問なのに長くなってしまた
442デフォルトの名無しさん (ワッチョイ 2f05-S4IJ)
垢版 |
2019/05/05(日) 23:47:50.76ID:RXFRr1FQ0
>>440
ありがとう
ただ初心者なので効率性を目指すにはきつい部分が出てくる
そうなるとメモリの残量を監視する、つまり残量の値を取得する必要があるわけだけど
これは一般的にはwindowsのAPIを使うのが普通なの?
(そんなものがあるのかは知らない)
2019/05/05(日) 23:52:54.47ID:RPhfdkos0
>>442
スタックとヒープという概念は知ってる?知らなければまずそれを調べてみて。
それと、初心者なら効率を求める前に正しくメモリ管理を扱えるようになる必要があるが、その時点で残量は気にする必要はないぞ。
444デフォルトの名無しさん (ワッチョイ 2f05-S4IJ)
垢版 |
2019/05/05(日) 23:59:16.82ID:RXFRr1FQ0
FIFOだとかナントカ程度にしか。
「〜〜領域」という幾つかの用語がOSとかの環境が違っても
全く共通のものなのかよく分からないから正直スルーしてる
2019/05/06(月) 05:38:27.60ID:wr9bFPpT0
>>414
>1億ノードの二分木にノードを追加する際、30個の無駄な代入が発生します
2^10 = 約1,000 千
2^20 = 約1,000,000 百万
2^30 = 約1,000,000,000 十億

>>441
Java VM の初期値は、256MB とか。
それよりも大きいと強制終了されるが、起動時に、512MBに設定できる

たぶん、4GB の仮想メモリでも、ユーザー空間3GB・カーネル空間1GBぐらいだろ

それ以上のデータは、動画みたいにstream になる。
バッファサイズ、例えば、1MB を読んでは捨てて、次の1MB読んでは捨てて、の繰り返し

読み込んだデータを使ったら、すぐに捨てないといけない。
ユーザー空間に、空きを作らないといけない
2019/05/06(月) 06:20:53.21ID:Geq8Gq1G0
>>445
いつものRubyバカだろ。いい加減な知識でC言語のメモリの話題に口を挟むのはやめろ。この板になれている者からすれば「またいつものか...」ですむが、初心者にとっては害悪でしかないから消えろ。
2019/05/06(月) 06:25:32.64ID:Geq8Gq1G0
>>444
組み込みとかの特殊な環境では例外もあるけど、基本的には環境によらずC言語で必須の概念だからスルーせずにちゃんと調べるべき。
2019/05/06(月) 08:39:59.60ID:s1ulBxFy0
>439
>上記の2でユーザー空間いっぱいになるまで変数を宣言してもいいの?
他のプロセスがスワップ起こして重くなるから止めろって言いたい。
449デフォルトの名無しさん (ワッチョイ 2f05-73UM)
垢版 |
2019/05/06(月) 10:14:49.95ID:Om5TJBQR0
>>447
うん調べてみるよ
ありがとう

>>448
そんな視点もあるのか
他のプロセスも考慮しないといけない
思ったよりも数段以上やっかいだな
450デフォルトの名無しさん (ワッチョイ 2f05-73UM)
垢版 |
2019/05/06(月) 10:19:59.43ID:Om5TJBQR0
>読み込んだデータを使ったら、すぐに捨てないといけない

データをガンガン読み込んでいくようなプログラムだと「使ったらすぐ捨てる」のが鉄則か
2019/05/06(月) 10:40:24.77ID:F7BEaxMm0
>>439
ユーザープロセスなのでカーネル空間はマッピングされないよ。プロセス管理のための領域はカーネル空間に多少は確保されるとは思うけど、それはユーザープロセス用ではないし。
ページサイズの関係で効率的に確保できるかどうかは別問題だけど仮想メモリ領域いっぱいまで取れるか否かと言えば取ることはできる。
実際にそんなことしたらスワップ発生しまくりでまともに動かないとは思うけど。
2019/05/06(月) 12:43:21.39ID:53K/0wkW0
実装としてはだいたいcopy on writeだから、確保だけだったら特に問題発生しないよ
2019/05/06(月) 16:08:26.90ID:95XsbNbMM
>>451
どのOSなのか明示してくれ。
少なくともlinux 32bitは3GB以降はkernel空間にマッピングされてるだろ
454デフォルトの名無しさん (ワッチョイ 4321-QjK4)
垢版 |
2019/05/06(月) 21:20:46.06ID:lSipB+Y80
配列にある16進数アスキーを
整数型変数に数値として入れたいのですが、上手くいきません。
valの値をprintfで出力しても「0」になります。

rbuf[5]の中身は「0xDC」
rbuf[6]の中身は「0x18」でした。(printfで出力してみたところ。)


#include <stdio.h>
unsigned char sbuf[255] = {'\0'}; //送信バッファ
unsigned char rbuf[255] = {'\0'}; //受信バッファ
unsigned char work[10] = {'\0'}; //ワークバッファ
unsigned int val = 0; //値

work[0]=rbuf[5];
work[1]=rbuf[6];
work[2]='\0';
sscanf((char *)work, "%x", &val);

よろしくお願いします。
2019/05/06(月) 21:29:36.69ID:v87Zm/5a0
sscanf の %x は、文字列で記述された数字+アルファベットの列を 16進数として抜き出す
sscanf("10", "%x", &val); → val の値は 10進で16 となる

0xDC 0x18 の並びから どういう整数値にしたいんだろうか?
456454 (ワッチョイ 4321-QjK4)
垢版 |
2019/05/06(月) 21:38:34.55ID:lSipB+Y80
>>455
回答ありがとうございます。
val=0xDC18
という感じで取り出したいです。
2019/05/06(月) 21:40:18.62ID:v87Zm/5a0
>>456 それなら
val = rbuf[5]; じゃあかんの?
458454 (ワッチョイ 4321-QjK4)
垢版 |
2019/05/06(月) 21:50:08.40ID:lSipB+Y80
>>457
ありがとうございます。そういうことか・・・
下記で上手くできました!

val= rbuf[5];
val = val << 8;
val |= rbuf[6];
2019/05/06(月) 21:54:12.13ID:v87Zm/5a0
>>458 解決してよかったね
0xDC 0x18 の並びから
(最低でも32bit長の整数)0xDC18 が欲しかったということだね
2019/05/06(月) 21:55:43.20ID:v87Zm/5a0
(俺がちゃんと >>456 を読めてなかった説 val=0xDC18 って書いてるやんけw)
461デフォルトの名無しさん (アウアウウー Sabb-vI8p)
垢版 |
2019/05/06(月) 22:06:19.06ID:NYoOX9LAa
>>454
> rbuf[5]の中身は「0xDC」
> rbuf[6]の中身は「0x18」でした。(printfで出力してみたところ。)

だったらそれはASCIIではないよね。
462デフォルトの名無しさん (アウアウウー Sabb-vI8p)
垢版 |
2019/05/06(月) 22:08:02.81ID:NYoOX9LAa
などと、ゆっくり書いていたら既に解決か・・・
463デフォルトの名無しさん (ワッチョイ 4321-QjK4)
垢版 |
2019/05/06(月) 22:09:16.82ID:lSipB+Y80
>>460
>>461
ありがとうございます。
お陰様で解決できました。
勝手にASCII、文字列と勘違いしていたのがよくなかったです。
2019/05/07(火) 06:48:35.98ID:/Z9tG+PY0
ASCII は、7 bit キャラだろ

欧州文字コードなら、8 bitとか
2019/05/07(火) 15:31:36.79ID:gGAOuhJk0
BASIC時代 文字→文字コード変換関数が ASC(文字) だったな。
2019/05/08(水) 20:11:19.53ID:w7dyIR3e0
逆はCHR$(コード)だったな。
2019/05/08(水) 22:02:13.36ID:LqpjdKM80
「なんで朝潮?」と思ってしまった当時の俺w
2019/05/09(木) 08:32:10.12ID:IVg2TokP0
わらってよりとも というのは、当時の人気番組名をもじったものだよ
2019/05/09(木) 12:40:11.38ID:J26JobOx0
https://ae01.alicdn.com/kf/HTB1goomIL1TBuNjy0Fjq6yjyXXaS/Cetak-Pria-Kaus-Katun-Leher-o-Tshirts-ANSI-Pemrograman-C-Buku-Jepang-Lengan-Pendek-Wanita-Kaus.jpg_640x640.jpg
2019/05/09(木) 20:40:23.75ID:axmpki24M
「はじめてのC」なら買う
2019/05/09(木) 22:18:17.14ID:fgRKvhjn0
その本の名前、買うときに恥ずかしいw
2019/05/09(木) 23:03:35.49ID:vEdVh+9n0
質問です
文字列の配列
char matrix[Y][X]を関数に引数として渡して、渡した先の関数でtxtファイルに出力したい。
YとXはその時々によって違う値でmatrixは文字列の配列だけど1行ごとに'\0'が入っていないとき、渡した先の関数でYとXをどうやれば参照できますか?
例えば
matrix = {{‘a’, ‘b’, ‘c’}, {‘d’, ‘e’, ‘f’}};
みたいな配列です
2019/05/10(金) 00:00:40.06ID:IBOrEgMWa
X(配列のサイズ)を共有してやればいいんじゃないかな
2019/05/10(金) 00:14:05.05ID:Ojl9YgLP0
>>472
matrixのアドレスと共にX、Yの値を渡さないと無理
475デフォルトの名無しさん (ワッチョイ bf02-XC4S)
垢版 |
2019/05/10(金) 03:11:16.60ID:+vHN15fT0
>>472
https://qiita.com/Hiraku/items/babed27bc1d750c2e12d
2019/05/10(金) 09:26:09.21ID:bwAvNWKg0
>>474
やっぱり配列のサイズ一緒に渡さないとだためですか
477デフォルトの名無しさん (アウアウウー Sa1b-wdoq)
垢版 |
2019/05/10(金) 09:44:04.32ID:0Zlxa6bHa
そう。他の言語だと裏でこっそり渡すようになっていたりしてプログラムに書かなくても動くかも知れないが、Cはそこまでやってくれない。
2019/05/10(金) 10:05:05.80ID:hw8N8wYC0
標準関数も一次元配列ですら大きさを渡してるからねー
(文字列は '\0' が終端である という了解を持って大きさを不要にしているだけ)
2019/05/10(金) 12:34:03.34ID:zZfQYrbwd
>>475
URL張って解党した気になってるアスペルガーのカスがスレ来んな
480デフォルトの名無しさん (ワッチョイ bf02-y0Vo)
垢版 |
2019/05/10(金) 23:50:49.39ID:svzEPJh90
え?読んでもわからなかったの?
2019/05/11(土) 07:43:24.28ID:glRpLuyC0
確かにつまらんね
リンクだけとかググレカスとか
せっかく掲示板にいるのに対話がないのは
2019/05/11(土) 09:55:06.58ID:GtXmrqj00
>>481
リンクを示すのも、ググればわかるようなことにググれというのも対話だよ。
対話を終わらせてるのはお前だろ。

リンク先を見て意味がわからんかったならどうわからなかったか、
よりよい説明があると思うならそれを示してもいい。
望むことだけ欲しいというのは対話とは言えんよ。
2019/05/11(土) 10:34:34.75ID:glRpLuyC0
>>482
話が噛み合ってない
おまえさんとは平行線のようだな
2019/05/11(土) 11:46:55.45ID:0ygzdBDA0
ID:glRpLuyC0が対話する気なさすぎて草w
2019/05/11(土) 12:23:55.76ID:9iCvmH6s0
ここは質疑を行うスレであって
対話したり、雑談したりする場ではない
2019/05/11(土) 19:10:51.09ID:HOBfdmGr0
Cの上位互換(?)として、C++がありますが。C++は覚えた方がいいですか?
もしくは、CとC++を両方覚えたら、Cは不要になり、C++でコードを書くようになりますか?
C++でできることはCでもできるように見えますので、ならCだけでいいようにも思えたり。
2019/05/11(土) 19:18:54.28ID:KtHZQgR00
>>486
C++ は最近規格の改定がすすみ、いろんなことが C++ の枠内でできるようになりました
2019/05/11(土) 19:21:03.92ID:2v2BzL6t0
>>486
言っておくが、python,C++,Java,javascript,C#,shellでできる事はC言語でも出来る
更に君が作ろうとしてるものや、やりたいことは、もう誰かが作ってる
ましてや大規模になると、googleとかamazonと戦う羽目にもなる
それが嫌ならプログラミングなんて辞めとけ
2019/05/11(土) 19:32:35.19ID:HOBfdmGr0
>>487-488
了解です、ありがとうございます
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

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