07/09/06 02:48:24
struct node *hoge(struct node* a)
{
struct node *b;
b = a;
a = NULL;
free( b );
return a;
}
free関数の形式を調べてみるとvoid free(void *ptr);と書いてありました
URLリンク(www.bohyoh.com)
つまり、上記の関数を実行すると、引き数で渡されたポインタaがNULLを代入される前に指していた領域を開できるということでしょうか?
自分で調べてみて「たぶんあっているな。」とは思ってもどうしても確信できなくて不安になってしまいます。みなさんはそんなことありませんでしたか?(このレス二つ目の疑問です)
523:デフォルトの名無しさん
07/09/06 04:23:10
適当な結果を標準出力に出力しつつ時々
y/n を聞いてくるコマンド ques が
あったとします。y/n を検知して
代わりに y を入力してくれる
プログラムを書きたいのですが、
何をキーワードに検索してよいのか
すらわかりません。パイプで検索したのですが
何か違う感じでした。
よろしくお願いします。
524:デフォルトの名無しさん
07/09/06 07:33:36
>>522
・できる。
・根本的にポインタを理解できていればそんなことはないと思う。
>>523
他に標準入力する項目がなく、quesが確実に標準入力を利用しているというのなら、
yes | ques
でOK。
525:デフォルトの名無しさん
07/09/06 10:22:16
>>524
すいません。C言語でやりたいのです。
それと質問に応じて no と答える場面もあります。
よろしくお願いします。
526:デフォルトの名無しさん
07/09/06 11:01:35
>>525
それなら、パイプで間違ってないと思う。
コマンドの標準出力/標準エラー出力を監視しながら特定のパターンを認識したら、
コマンドの標準入力に対して、yまたはnを投げる。
>何か違う感じでした。
何を期待しているか知らないが、コンソールアプリでは
WindowsのGUIアプリのように、入力待ちになったとかのイベントが
飛んできて、そこに処理を記述するわけではない。
実装はどうしても泥臭くなると思うが。
527:デフォルトの名無しさん
07/09/06 11:03:40
ファイル操作について質問なのですが、
もし現在の日付をfprintf("%d %d %d %d %d %d\n",local->tm_year・・・以下略
こういう風にファイルに保存したとしますよね。
このファイルを読み込むとき、
fscanf("%d%d%d%d%d%d",&year,・・・以下略という風に読み込んだとき、
何故yearという変数にはしっかりとyearで保存した数字が格納されるのですか?
説明下手ですみません。
528:デフォルトの名無しさん
07/09/06 11:07:05
fprintf("%d %d %d %d %d %d\n",local->tm_year・・・
で書き込むと当然、
2007 09 06 ・・・
となるから、fscanf("%d%d%d%d%d%d",&year,・・・で読み込むときは
空白か改行まで読まれるので
2007
09
06
・・・
と順に読み込まれる
529:デフォルトの名無しさん
07/09/06 11:08:05
なぜって言われても、それが fscanf という関数の機能なんだし。
どういう結果になると思ってた?
530:デフォルトの名無しさん
07/09/06 11:10:00
なるほど・・・左上から順に変数に格納されるんですね。それなら呼び出す
順番に気をつけないとメチャクチャになりますね。分かって良かった。
ありがとうございました。
531:
07/09/06 16:45:10
すいません。gccの拡張命令について知りたいのですが
どこかに命令一覧が載ってるサイトってありますか?
532:デフォルトの名無しさん
07/09/06 16:52:09
配列を引数として関数にいれて、関数でその配列の中身を表示しておいて
mainでその関数を100回くらいまわしたら
値がかわってくるんだけど何が原因だと思われますか?
配列は20要素で
引数は4つ使ってます。
533:デフォルトの名無しさん
07/09/06 16:56:09
>>532
そりゃプログラムのバグでしょ
具体的にコード見せてくれないとそれ以上はわからん
534:デフォルトの名無しさん
07/09/06 17:09:10
void makemake(---){ (これをmainと思ってください)
double ma[120][20];
double h1[20],h2[20],n[120];
int num;
fileinput(h1,h2,num);
for(i=0;i<120;i++){
n[i]=fmake(ma[i],h1,h2,num);
}
}
そしてfmake関数に渡します
double fmake(double a[20],double b1[20],double b2[20],int n){
int i;
for(i=0;i<20;i++){
printf("b1:%lf b2:%lf",b1[i],b2[i]);
}
}
まー一部なんでわかりにくいかもしれませんが。
fmake関数のprintfで20ループくらいまでは
きちんと表示されるんですけど途中でnanとかおかしな数字が表示されるんです。
535:デフォルトの名無しさん
07/09/06 17:10:21
not a number
536:532
07/09/06 17:13:30
534ですけどお願いします。
537:デフォルトの名無しさん
07/09/06 17:25:07
そのファイルがおかしいんじゃないの
538:デフォルトの名無しさん
07/09/06 17:26:57
>>536
思わず笑ってしまった。
>>535の not a number は>>534の nan を指してる。
NaN (Not a number)、日本語だと非数。
浮動小数点演算で、0除算など計算結果が正しく求められない計算を
したときに、値が正常でないことを示す特別な値が格納される。その値のこと。
繰り返しはまったく同じものを表示しているわけではないみたいだけど、
fileinputで読んできた値がすでにおかしいんじゃないの?
539:デフォルトの名無しさん
07/09/06 17:45:24
>>534
fileinput をでっちあげて動かしてみたが、まったく問題ない。
省略した部分がおかしいと思われ。
540:532
07/09/06 17:46:27
ファイル入力が間違ってるんじゃないかって指摘するってことは
プログラムはあってるってことですか
ありがとうございます。
どうしようもなくなったら直接fmakeにb1,b2のファイルいれますわ。
541:デフォルトの名無しさん
07/09/06 17:49:45
>>540
プログラムもなにも、挙げられた断片だけでは何もしないコードに見え
る。fmake()は何も返してないし。
542:532
07/09/06 17:53:22
正規分布のプログラムなんすよ。
double a[20], データ120X20
double b1[20], 20次元の平均
double b2[20], 20次元の分散
int n 平均・分散の組。
式は書くの大変だから省いてるだけです。
543:デフォルトの名無しさん
07/09/06 18:02:25
予想ではたぶんその式が悪い
544:532
07/09/06 18:04:15
double fmake(double a[20],double b1[20],double b2[20],int n){
int i;
for(i=0;i<20;i++){
printf("b1:%lf b2:%lf",b1[i],b2[i]);
}
以上
545:デフォルトの名無しさん
07/09/06 18:06:14
わからなければ計算したり配列弄るごとに中身出力してみ
546:デフォルトの名無しさん
07/09/06 18:30:27
どこが悪いかわかんないのに、なんでそこが悪いと思うのか理解できない。
547:デフォルトの名無しさん
07/09/06 19:15:12
このソースがコンパイルできないんですけど
どこに問題があるんですかね?
コンパイラはgcc3.3.6です。
URLリンク(www8.uploader.jp)
548:532
07/09/06 19:33:26
>>532て書いてるんですけど。
式はあってるんだよ確認ずみだから。
入力のプログラムがあやふやだからここで聞いただけ。
549:デフォルトの名無しさん
07/09/06 19:35:12
はいはい。コンパイラのバグかなんかじゃねえの。
550:デフォルトの名無しさん
07/09/06 19:39:09
そろそろ荒らし化しそうな予感
551:デフォルトの名無しさん
07/09/06 19:48:25
こんなアホ相手にするお前ら優しいな
552:デフォルトの名無しさん
07/09/06 19:48:45
よく言われる
553:デフォルトの名無しさん
07/09/06 19:51:32
>>547
配列の宣言の仕方とsizeの扱い直せばいけると思う
554:デフォルトの名無しさん
07/09/06 19:53:07
>>553追加でコンパイルするだけならsizeはそのままでもいいかも
連投スマン
555:デフォルトの名無しさん
07/09/06 20:18:46
どんどん本性が出てきたな
556:デフォルトの名無しさん
07/09/06 21:39:02
>>510 が、もう見てないだろうから、書いてみる
#include<stdio.h>
int main(void){
int x, y, width=3, height=4;
for(y=0;;y++){
for(x=0;x<width;x++) printf("+---");
printf("+\n");
if(y>=height) break;
for(x=0;x<width;x++) printf("| "" "" "); // コピペ用
printf("|\n");
}
return 0;
}
557:デフォルトの名無しさん
07/09/06 22:38:24
殆どのネットゲームのBOTは C言語で開発されてるんでしょうか?
サイトありましたらおしえてください m)_ _m)
558:デフォルトの名無しさん
07/09/06 22:43:18
無い
559:デフォルトの名無しさん
07/09/06 23:16:50
URLリンク(www.google.co.jp)
560:デフォルトの名無しさん
07/09/07 10:46:15
>>559
ありがとうございました
561:デフォルトの名無しさん
07/09/07 12:55:50
ネトゲのBots全てがCで作成されているかは知らんが
Cで作成できないことはない。
まぁ開発にあたっては、Cの知識だけでなく、それ以上の多くの知識が求められます。
562:デフォルトの名無しさん
07/09/07 14:31:57
UWSCあたりならすぐに書けそうだな。
563:デフォルトの名無しさん
07/09/07 16:02:02
関数は自分で積極的に作ったほうがいいですか?
それとも既存のものの効率的な組み合わせにこだわったほうがいいですか?
564:デフォルトの名無しさん
07/09/07 16:59:44
既存のものの効率的な組み合わせをする関数を自分で積極的に作ったほうがいい
565:デフォルトの名無しさん
07/09/07 19:00:20
>>564
ありがとうございます。なるほど!積極的に作ります
566:デフォルトの名無しさん
07/09/07 19:21:22
グローバル変数として宣言する場合と、staticを付けて関数内で宣言する場合は
どういう違いがあるんでしょう?いくつかの説明文見たところ自分では同じように
思えるんですが、グローバル変数にstaticを付けるプログラムの例を見かけたので気になりました。
567:デフォルトの名無しさん
07/09/07 19:27:15
static を付けないグローバル変数 → 他のファイルからでも参照できる
static を付けたグローバル変数 → 他のファイルからは参照できないが、同じソースファイル内ならどの関数からでも参照できる
static を付けた関数内の変数 → 他の関数からは参照できない
間違って書き換えたりしないように、見える範囲をなるべく最小限にする方が良い。
568:デフォルトの名無しさん
07/09/07 19:40:10
>>567
ありがとうございます、アクセスできる範囲に違いがあるんですね。
つい値を保持できる期間ばかりに目が言ってたみたいです
569:デフォルトの名無しさん
07/09/07 23:03:28
入力された文字列が正しい文字列かを判断するプログラムなんですけど
#include <stdio.h>
#include <string.h>
int getflg(char wd);
main()
{
int n;
char word;
printf("文字入力:");
scanf("%s",&word);
n=getflg(word);
printf("flg=%d",n);
}
int getflg(char wd)
{
int flg=0;
if ( strcmp(wd,"あいうえお")==0 ){
flg=1;
}
return flg;
}
これだとエラーがでるのですがどうすればよいのでしょうか;;
570:デフォルトの名無しさん
07/09/07 23:06:22
>char word;
>printf("文字入力:");
>scanf("%s",&word);
え?w
571:デフォルトの名無しさん
07/09/07 23:08:53
>>569
「文字」ではなく「文字列」だから
#include <stdio.h>
#include <string.h>
int getflg(char *wd);
main()
{
int n;
char word[20];
printf("文字入力:");
scanf("%s",word);
n=getflg(word);
printf("flg=%d",n);
}
int getflg(char *wd)
{
int flg=0;
if ( strcmp(wd,"あいうえお")==0 ){
flg=1;
}
return flg;
}
だね
572:569
07/09/07 23:13:04
>>570
すいません
>>571
文字だと&が必要で
文字列だと&は必要ないということですかね?
あと*wdにするのはなんでですかね?汗
573:デフォルトの名無しさん
07/09/07 23:18:20
>>572
>文字列だと&は必要ないということですかね?
必要ない
>scanf("%s",word);
>if ( strcmp(wd,"あいうえお")==0 )
文字列同士の比較をしたいわけでしょ
char wd だと1文字だけしか渡せない、文字列として渡したいならポインタとして渡すしかない
char *wd は文字列のポインタを渡している
574:デフォルトの名無しさん
07/09/07 23:30:21
#include <stdio.h>
#include <string.h>
int getflg(char *wd);
main()
{
int n;
char word[20];
printf("文字入力:");
scanf("%s",word);
n=getflg(word);
printf("flg=%d",n);
}
int getflg(char *wd)
{
return !strcmp(wd,"あいうえお") ? 1 : 0;
}
575:デフォルトの名無しさん
07/09/07 23:34:11
>>534
> double ma[120][20];
これでスタックフレームを何byte消費しているか理解しているか?
static double ma[120][20];
static double h1[20]
static double h2[20]
static double n[120];
にしてみろ
これで結果がお前の予想通りになったなら
コンパイラはお前の予想通りには動かないということを知っておけ
576:569
07/09/07 23:35:04
>>573
char wdだと1文字だけなんですか?
577:デフォルトの名無しさん
07/09/07 23:41:55
>>575
> これでスタックフレームを何byte消費しているか理解しているか?
たった、18,9Kじゃん。
578:569
07/09/07 23:47:17
>>576をちと言い換えたいんですが、
int getflg(char wd[])
と違いは何かありますか??
579:デフォルトの名無しさん
07/09/07 23:52:06
>>578
int getflg(char wd[]);
と
int getflg(char wd);
の違いが理解できない奴はCをする資格が無い
VBかJavaScriptあたりで妥協しておくことをお勧めする
580:デフォルトの名無しさん
07/09/07 23:54:25
理解できないっていうか、こういう基本的なところをネットで訊きながら進めるのって、効率悪すぎだろ。
入門書でも買えばいいのに。
581:デフォルトの名無しさん
07/09/08 00:14:43
Cでは文字列変数というのはなくてバイト(char)の配列として扱っているんだよね
ほかの言語ではまずありえないことだけど
582:569
07/09/08 00:33:22
>>580
基礎的なHPをいろいろ探してみてきたが
int getflg(char *wd);
これだと、ポインタによる引渡しで
int getflg(char wd[]);
これだと、wdに文字列を直接代入する的なものですか?
583:デフォルトの名無しさん
07/09/08 00:33:43
haskellもそうじゃなかったっけ
584:デフォルトの名無しさん
07/09/08 00:34:39
>>582
いや、ややこしいことに
int getflg(char *wd);
と
int getflg(char wd[]);
は同じ
585:デフォルトの名無しさん
07/09/08 00:38:23
>>582
C FAQのポインタあたりを一通り読んでみるとか。
URLリンク(www.kouno.jp)
586:581
07/09/08 00:38:56
>>582
ちがいます
Cではchar wd[]とchar *wdはほぼ同じ扱いです
587:
07/09/08 00:41:32
でも配列とポインタだと&かましたときの値が違うんじゃないの?
588:デフォルトの名無しさん
07/09/08 00:45:14
関数の宣言で使用する場合は同じ(ポインタと解釈)。
589:デフォルトの名無しさん
07/09/08 01:04:12
>>586
ちがいます
Cでは関数の引き数の宣言において、char wd[]とchar * wdは全く同じ扱いです。
590:デフォルトの名無しさん
07/09/08 01:10:48
char wd[10]
とか書くとまた変わって来るからややこしい。
591:デフォルトの名無しさん
07/09/08 01:45:54
int getflg(char *wd); も
int getflg(char wd[]); も
int getflg(char wd[10]); も
int getflg(char wd[42]); も一緒
592:デフォルトの名無しさん
07/09/08 02:30:12
すみません、質問です。C言語でmallocによる動的な領域確保の勉強をしています。
char型の領域を動的に確保してそこにコマンドライン引数のargv[i]を格納していきます。
void main(int argc, char *argv[]){
int i;
char *hikisu;
for(i=0; i<argc; i++){
hikisu[i] = (char *)malloc(sizeof(char));
memset(hikisu[i], NULL, sizeof(char));
strcpy(hikisuu[i], argv[i]);
}
}
これでコンパイルが通らないのですが、何が悪いのかよくわかりません。
ご教授お願いします。
593:デフォルトの名無しさん
07/09/08 02:38:44
>>592
動的確保以前のポインタの勉強をしなおせ。
--
// インクルードファイルを適切にインクルードしていない
void main(int argc, char *argv[]){
// mainの戻り値型はintにするべき
// 中括弧は別の行に書くのが一般的
int i;
// 一文字変数はインクリメンタルサーチしにくいからお勧めしない
char *hikisu;
// ポインタ変数は、ポインタ一個しか保持できない。引き数を複数保持したいなら、これではダメ
for(i=0; i<argc; i++){
hikisu[i] = (char *)malloc(sizeof(char));
// malloc()の引き数はバイト数。これでは1バイトしか確保できない
memset(hikisu[i], NULL, sizeof(char));
// malloc()したエリアをmemset()で潰してしまうのはナンセンス(一部に妄信者はいるが)
// つーか、引き数が無茶苦茶
strcpy(hikisuu[i], argv[i]);
// これも引き数が間違っている
}
}
--
まぁ、取り敢えずこの辺にしておいてやるかw
594:デフォルトの名無しさん
07/09/08 02:44:46
>>592
stdlib.hがincludeされてない。
strcpy(hikisuu[i], argv[i]);
「hikisuu」はどっから出てきた?(タイプミス?)
この2つ直すととりあえずコンパイルは通るかもしれない。(コンパイラ次第)
が、落ちる可能性が高いな。
ていうかコンパイルのエラーを書け。
595:デフォルトの名無しさん
07/09/08 21:00:46
Javaにはメソッドのコメントの書き方で、
/**
@param
@return
*/
のようなのが決まっていて、これでHTMLのドキュメントを自動作成できますが、
Cにはそのようなものはありますか?
596:デフォルトの名無しさん
07/09/08 21:03:28
つ[Doxygen]
597:595
07/09/08 21:25:58
レスありがとうございます。
できるだけ標準的なものを使いたいのですが、そのDoxygenというのはよく使われていますか?
もしJISやISOやその他の標準化団体の制定した書式があるようならば、教えて欲しいのですが。
598:デフォルトの名無しさん
07/09/08 21:28:38
標準化はされてない
デファクトスタンダードには近いかも
599:デフォルトの名無しさん
07/09/08 23:08:08
戻り値で成功か失敗かの判定だけ必要なとき、
成功は0で、失敗は-1で返すのがいいんでしょうか?
古いCの関数はこれが多いですよね。
成功は1で失敗は0にすると、判定側でif(!func()){ printf("error"); }
のような書き方ができるので、これの方が便利な気もするのですが、
どっちがいいんでしょうか。
600:デフォルトの名無しさん
07/09/08 23:16:04
>>599
古いCの関数っていうか、unixのシステムコールだろ。
601:デフォルトの名無しさん
07/09/08 23:24:16
>>599
俺は自分でSUCCESSとFAILUREをdefineして使うのが好き。
SUCCESSが1でも0でもif(func!=SUCCESS)と書く。
この辺は好みじゃね?
602:デフォルトの名無しさん
07/09/08 23:40:14
シンプルに0か0以外がいいよ。
いろいろ値が定義してあると、読むのに負担がかかる。
単純なTRUE,FALSEでも、0以外と0になっているかとか、定義が一箇所かとか気にする必要あるし。
いまやってる仕事なんて、RTN_OKとRTN_ERRだけかと思ってたら、RTN_NODATAとか返してたり返した無かったり
するし。
603:デフォルトの名無しさん
07/09/08 23:55:20
あるディレクトリにある、大量のファイル(ファイル名は***1.dat、***2.dat、***3.datと1000個ぐらい続く)
を順番に読み込みたいのですが、どのようにすれば良いのでしょうか?
通常のファイルを開く方法(fopen)では、指定ファイル名をしてforループで回して変更するとかいう事が出来ない
みたいなので困っています。どなたかご教授よろしくお願い致します。
604:デフォルトの名無しさん
07/09/08 23:58:01
普通に一個ずつ順番に読めばいいんじゃないの?
605:デフォルトの名無しさん
07/09/08 23:58:21
>>603
OSのAPIに頼ってディレクトリのファイル名一覧を作る。
で、順番にfopenか何かで開く。
606:デフォルトの名無しさん
07/09/08 23:58:49
ファイルシステムを直接読めばいいのでは?
607:デフォルトの名無しさん
07/09/08 23:59:52
ファイル名が連番になってるのならforループで舞わせばいいい。
608:デフォルトの名無しさん
07/09/09 00:00:30
つ system
609:デフォルトの名無しさん
07/09/09 00:00:39
>>603
ファイル名が規則的なら、、ループで回して処理できるよ。
610:デフォルトの名無しさん
07/09/09 00:10:34
age
611:デフォルトの名無しさん
07/09/09 00:31:10
***1.dat、***2.dat、***3.dat てことは連番だな
612:デフォルトの名無しさん
07/09/09 00:42:52
int i;
FILE *fp;
char filename[12];
for (i = 1; i <= 1000; i++) {
sprintf(filename, "***%d.dat", i);
fp = fopen(filename, "r");
以下略
613:603
07/09/09 00:50:17
>>612様
どうもありがとうございます。
sprintfという関数を知りませんでした。
非常に助かりました。
614:デフォルトの名無しさん
07/09/09 12:21:33
すみません 初心者です。
この最後のFor文は何をしているのですか?
よろしくお願いします。
int wk1;
char DateT[10+1];
char bufs[128];
DateT[0] = "2007/10/01"
memset( bufs, 0x0, sizeof(bufs) );
memcpy( bufs, DateT+ 5, 2 );
wk1= atoi(bufs); wk1-= 1;
for( i=6; i>=5; i--, wk1/=10 )
DateT[i]= (char)((wk1%10)+'0');
615:デフォルトの名無しさん
07/09/09 12:31:14
10 月を 09 月に変えてるんじゃね?
616:デフォルトの名無しさん
07/09/09 12:33:45
月の値、01~12を00~11に置き換えている。
617:デフォルトの名無しさん
07/09/09 12:37:52
>614
とりあえずそのコード、コンパイル通らなくない?
質問するくらいだから自分で書いたコードじゃないんだろうけど、あんまり参考にしたくないコードだと思う。
で、for 文限定だと
短い答え:数値を文字列に変換している。
もうちょっと長い答え:
wk1 % 10 で wk1 の一の位の数値を得る。
これに '0' ('0' の文字コード値を足すと 0 なら '0' に 1 なら '1' と数値→文字の変換が出来る。
wk1 /= 10 で十の位が一の位に移って繰り返し。
618:デフォルトの名無しさん
07/09/09 12:51:37
>>614
?? DataT[0] = "2007/10/01"
そいつは、通らねえよ。
それにしても、俺の現場にあるソースに似てるwまさかww
619:sage
07/09/09 13:47:36
>>615様
>>616様
>>617様
>>618様
どうもありがとうございました。助かりました。
私の知り合いが解析しているソースを
出来ないなりに私も手伝おうかと思って頭から調べているときに
ひっかかった次第です。
自分はもう少しCの勉強が必要ですね。orz
620:デフォルトの名無しさん
07/09/09 13:50:39
恥ずかしいんでsageます。
失礼しました。
621:デフォルトの名無しさん
07/09/09 20:40:55
2chのスレッドの仕組みについても学んでください
sageで書き込んでもスレッドは下がりません
622:デフォルトの名無しさん
07/09/09 21:54:44
いまリストでキューを実現しようと考えてるのですが、うまくデータを入れることができません
どうすれば改善できるか見てもらえないでしょうか?
URLリンク(www.dotup.org) C言語ってコメント入れているファイルです
623:デフォルトの名無しさん
07/09/09 22:06:18
普通、キューに入れるときに動的にメモリ確保するんでない?
624:デフォルトの名無しさん
07/09/09 22:08:41
>>622
根本的に改善する余地あり
改善案は次の通り(命名に付いては適当に変えたほうが良い)
QUE *queue_init(void);
void queue_terminate(QUE *que);
int queue_enque(QUE *que, void *data);
void *queue_deque(QUE *que);
int queue_size(QUE *que);
625:デフォルトの名無しさん
07/09/09 22:12:52
キューのデータそのものと頭とケツの位置とかを保持する管理構造体を作って、それをQUE構造体とすべき
626:622
07/09/09 22:17:55
>>623
確かにそうですね。とりあえず今回はって事で書きました
>>623
queue_terminateはどういう処理をしますか?
>>625
そうします
627:デフォルトの名無しさん
07/09/09 22:21:08
>>624じゃないが、
QUE *queue_init(void); → QUE型のメモリ割り当て、初期化
void queue_terminate(QUE *que); → 保持しているキューデータのメモリ解放、QUE型をメモリ解放
だと思う。まぁC++のあれだよね^^
628:622
07/09/09 22:42:24
>>627
そういう事ですか、わかりました
根本的な改善はわかったんですが、今回のデータを入れることができないっていう事の
改善策はありませんか?
また次も同じことになりかねないので・・・
629:デフォルトの名無しさん
07/09/09 22:57:07
>>626
いそいで作ってみた
バグあるかも
URLリンク(2sen.dip.jp:81)
630:デフォルトの名無しさん
07/09/09 22:57:11
構造が悪いから分かりにくくなってるだけ
631:624=629
07/09/09 23:04:25
引数チェックが甘かった orz
まあいっか
632:622
07/09/09 23:15:53
>>629
拝見しました。管理用とデータ用の構造体を作ったほうがいいことがよくわかりました
参考にさせてもらいます。ありがとうございます~
633:デフォルトの名無しさん
07/09/10 00:00:07
>>632
>>629 の不完全型はデータを隠蔽するのに便利!
オススメのテクニックだよ
634:デフォルトの名無しさん
07/09/10 13:51:08
西暦と月を入力すると,以下のようなカレンダーを出力するプログラムを作成せよ
閏年にも対応すること.
西暦年が4で割り切れる年は閏年
ただし、西暦年が100で割り切れる年は平年
ただし、西暦年が400で割り切れる年は閏年
指定された年,月の一日の曜日を求めると良い.曜日を求めるには,Zellerの公式を使う.年も月も整数型の変数を用い,日の部分は1に置き換えること.
(年+年/4-年/100+年/400+(13*月+8)/5+日 )%7
1月と2月は前年の13月,14月として考える.
この式の答えと曜日の関係は以下の通り.
0:日曜日,1:月曜日,2:火曜日....,6:土曜日
Sun Mon Tue Wed Thu Fri Sat
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30 31
このようなプログラムを作りたいのですがちんぷんかんぷんでまったくできません。
よろしければ見本のようなものを作ってもらえないでしょうか。
お願いします。
635:デフォルトの名無しさん
07/09/10 13:54:01
丸投げは宿題スレ
636:デフォルトの名無しさん
07/09/10 14:01:37
すれ違い申し訳ありませんでした。
637:デフォルトの名無しさん
07/09/10 14:04:46
Cで構造体を初期化するとき {0}を代入するのと、memsetで0をセットすることの違いはなんでしょうか?
typedef struct tagAAA {
int a;
int b;
int c;
} AAA, * PAAA;
AAA aaa1 = {0};
AAA aaa2;
memset(&aaa2, 0, sizeof(AAA));
おしえてください。
638:デフォルトの名無しさん
07/09/10 14:27:28
浮動小数点型やポインタ型のビット表現がゼロとは限らない
639:デフォルトの名無しさん
07/09/10 14:38:39
>>638
memsetでもそれは同じではないの?
両方、構造体のサイズ分、0 でクリアされるとおもってるんだけど。
640:デフォルトの名無しさん
07/09/10 14:43:38
>>637
memsetで0をセットは百害あって一利なし。使わないほうがよい。
構造体を初期化したいときには、各々の構造体メンバー変数に対し、
決められた初期変数を代入すること。
memsetが唯一有効なのは、メモリーをバイナリーエディッターで除くとき。
反論↓↓↓
641:デフォルトの名無しさん
07/09/10 14:45:29
>>639
doubleの0x00000000は0.0と保障されているわけではない。
ということでしょ。
642:デフォルトの名無しさん
07/09/10 14:46:49
えーと↑↑↑
エディッターのあたりがよくわからない
643:デフォルトの名無しさん
07/09/10 14:50:06
初期化でBYTEレベルでALL 0 にしたい場合は、
= {0} での初期化と、 memset での初期化の違いはあるの?
① AAA aaa1 = {0};
② AAA aaa2; memset(&aaa2, 0, sizeof(AAA));
は同じことをしているのかということです。
644:デフォルトの名無しさん
07/09/10 15:17:06
構造体は知らないけど、配列の場合はコンパイルすると同じコードになるって前にみかけた気がする。
645:デフォルトの名無しさん
07/09/10 15:28:18
>>643
コンパイラによっては、{0}の方が、より最適化される可能性が高い。
646:デフォルトの名無しさん
07/09/10 15:29:45
>643
① graceful
② rude
647:デフォルトの名無しさん
07/09/10 15:58:29
指定の行の削除方法が分かりません
例えば下記のようなファイルがあり
あいう
あああ
いいい
ううう
これを「いいい」だけ削除して下記のようにしたいのですが、1行だけ削除するようなやり方がわかりません
あいう
あああ
ううう
やりかたをご教授いただけないでしょうか
648:デフォルトの名無しさん
07/09/10 15:59:05
サンプルとかみても memset のほうがおおい。
AAA aaa1 = {0}; とかで構造体を初期化しているのってほとんどみないような。
649:デフォルトの名無しさん
07/09/10 16:01:45
>>648
なんで、構造体を初期化する必要があるの?
構造体メンバーを初期化する必要はあると思うが、構造体全体の初期化はあまり意味がないだろう。
650:デフォルトの名無しさん
07/09/10 16:03:13
そもそも、初期値が0とは限らない。
651:デフォルトの名無しさん
07/09/10 16:04:28
windows api つかうときってmemsetで初期化することあるでしょ。
CRITICALSECTIONとか、RECTとか。いちいちメンバごとに初期値いれるソースとかみたことないよ。
いったん初期化してから個別に値いれることはあるけど。
652:デフォルトの名無しさん
07/09/10 16:11:33
① AAA aaa1 = {0};
② AAA aaa1; memset(&aaa1, 0, sizeof(AAA));
①=② FA?
653:デフォルトの名無しさん
07/09/10 16:18:14
={0} は浮動小数点やポインタも正しく 0.0 や NULL に初期化される。
memset で全ビットを 0 にする方法では、処理系によっては浮動小数点やポインタが 0.0 や NULL にならない場合がある。
①≠②
654:デフォルトの名無しさん
07/09/10 16:45:34
>>653
ありがとう。すっきりしました。
655:デフォルトの名無しさん
07/09/10 17:37:39
>>647
改行コードで区切って、消す行の後を違う領域に分けた後、消す行のところに繋げる
656:デフォルトの名無しさん
07/09/10 20:07:43
memsetで初期化のクセを覚えてしまうと、
C++のクラスのオブジェクトに対してもそれをやりそう。
657:デフォルトの名無しさん
07/09/10 20:45:13
コンストラクタがまさかのmemset呼び?
658:デフォルトの名無しさん
07/09/10 20:49:28
>>657
うちの連中ならやりそうだw
ところで、>>637のは
AAAA aaa1 = {}; //{0}の0省略
はできないの?C++の本に乗ってたんだけど、Cでも試したら出来てそうなんだけど。
659:デフォルトの名無しさん
07/09/10 21:05:36
>>658
エラー E2264 式が必要といわれた
@BCC5.5
660:デフォルトの名無しさん
07/09/10 21:06:25
>>658
C++ならできた。CL.EXE
661:デフォルトの名無しさん
07/09/10 21:09:58
>>658
ANSI C的には文法違反。
{}の中には少なくとも一つの式がいる。
662:658
07/09/10 22:42:45
>>659-661 なるほど。情報サンクス。
gccではc89,c99モードにしてやっても出来るみたいなんだけど、
c99はまだ完全なサポートではないし、ことさら制限する様なことはしないのかも。
jiscのサイトから拾ったC言語の文書では、省略可を表すopt記号が無かったからやはり省略不可みたい。
参考)URLリンク(www.jisc.go.jp)
663:デフォルトの名無しさん
07/09/10 22:49:09
Cを無料でダウンロード出来るトコなんてないですかそうですか
やっぱり電気屋とかで買うんですかね?
664:デフォルトの名無しさん
07/09/10 22:50:54
てめぇ~~~ら、一生に一度の俺の質問に答えてくれ!
どうしてC言語の勉強を始めたの?
665:デフォルトの名無しさん
07/09/10 22:52:24
日本語を無料でダウンロード出来るトコなんてないですかそうですか
やっぱり日本とかで買うんですかね?
666:663
07/09/10 23:11:01
>>665
楽しいか?
667:デフォルトの名無しさん
07/09/10 23:14:07
>>664
遊ぶのに理由がいるのかい?
668:デフォルトの名無しさん
07/09/10 23:17:54
>>667
遊びというのは個人的な理由。ではなぜ C言語を選んだ かの理由は???
669:デフォルトの名無しさん
07/09/10 23:19:06
>>667
君、そういうことを言ってしまうと、自分にとって遊びだからという理由で
なぜその遊びを選んだかの理由は関係ないじゃ~~んって無責任な人間になってしまうよ?
なぜなら、殺人を遊びに選んだら、なぜ殺人をしたんですか?という質問に対して
君は常に「遊びだから」という身勝手な言い訳をし続けることになるから。
670:デフォルトの名無しさん
07/09/10 23:19:58
身勝手かどうかは主観に依存するよな。
671:デフォルトの名無しさん
07/09/10 23:30:07
>>670
殺人を遊びという理由は身勝手。なんで殺人をしてしまったのか?
という理由が述べられていない。ただの愉快犯なら情状酌量の余地なし。
すぐさま死刑で良いでしょうw
672:デフォルトの名無しさん
07/09/10 23:31:01
>>670
要するにお前は理由もなくC言語をやっていたんだ。まぁあれだろ
通っていた学校でやらされた程度で、実は面白くないと?w
673:デフォルトの名無しさん
07/09/10 23:31:47
同意。身勝手かどうかを判断する客観的な主体は存在し得ない。
深読みしてみると質問の趣旨は、なぜ数あるプログラミング言語の中から
Cを選んだのか?ってことなんかな。つか複数使える人のほうが多いと思うがね。
674:デフォルトの名無しさん
07/09/10 23:34:14
>>664
単位取得に必要だったからやった
今も後悔はしていない
675:デフォルトの名無しさん
07/09/10 23:36:05
まぁ、普通に答えると始めたきっかけは高校でやらされたからに他ならない。
676:デフォルトの名無しさん
07/09/10 23:38:04
何も知らないころよく聞く言語名がCだったから、かなぁ
677:デフォルトの名無しさん
07/09/10 23:39:48
>>663
環境書かないと分からんだろが!
サンプルソースが欲しいのか
コンパイラが欲しいのか
何が欲しいのかもよく分からん
フリー
コンパイラ
URLリンク(www.google.co.jp)
678:デフォルトの名無しさん
07/09/10 23:42:10
>>677
>>665
679:デフォルトの名無しさん
07/09/10 23:43:09
>>664
きっかけは、情報処理技術者試験のためデス。
学校でFORTRAN習ったけど、当時自宅のMS-DOS環境で開発環境を入手できたのがCだった。
680:デフォルトの名無しさん
07/09/10 23:52:47
>>664
最初は高校でやったMS-BASIC(だったか?)によってプログラミングが楽しくなり
学校においてあった8ビットCPUのポケコンをさわり、欲しくなったので先生に頼んで取り寄せ、16ビットCPUのポケコンを購入
インタプリタで動作するCが組み込まれていてBASICより面白いと思う
大学で自分のPCを買えるようになってコンパイラ方式のCをはじめる
681:デフォルトの名無しさん
07/09/10 23:59:48
>>673
遊びこそ主観だろ、答えたくないバカは黙ってろよ。歩インポイントでお前を
名指しして質問されているわけじゃないだろ?w お前みたいな基地外にはむしろ聞いてないって。
それから、何が主観かなんてどうでも良いんだよ。理由がいえないなら黙ってろ
682:デフォルトの名無しさん
07/09/11 00:00:22
うひょっ、わけわからない入力をしてたw
歩インポイント > お前にピンポイント
683:デフォルトの名無しさん
07/09/11 00:05:49
動的に確保した領域の大きさってどうやったらわかりますか?
684:デフォルトの名無しさん
07/09/11 00:08:23
>>667
全員が全員、遊びでC言語をやっているわけじゃないと思うんだが?
勝手にC言語=遊びみたいなことを言うなよw
お前の場合は遊びに理由がって関係ない話をしているだけ。
お前にとっては遊びで始めたというのが理由であって、C言語は遊びじゃないぞ。
685:デフォルトの名無しさん
07/09/11 00:23:04
>>683
どこかに書いておけばいい
686:デフォルトの名無しさん
07/09/11 00:26:06
自転車置き(ry
687:デフォルトの名無しさん
07/09/11 00:26:39
int *a;
のとき、
aはポインタのアドレス
*aはポインタに格納された値
なんですよね?
じゃあ
&aだと何を表すんですか?
688:デフォルトの名無しさん
07/09/11 00:27:33
>aはポインタのアドレス
いいえ
689:デフォルトの名無しさん
07/09/11 00:28:22
じゃあなによ?
690:デフォルトの名無しさん
07/09/11 00:34:50
aはポインタ型の変数
また、&aはaという変数へのポインタ
691:デフォルトの名無しさん
07/09/11 00:34:52
ポインタ
692:デフォルトの名無しさん
07/09/11 01:01:04
>>687
*aはポインタが指し示すオブジェクト。とでもいった方がよいかな。
値といっても=の左辺になれる事を理解すること。
693:デフォルトの名無しさん
07/09/11 01:20:04
aは、int型のオブジェクトのアドレスを格納するポインタ型の変数=ポインタ。
*aはポインタが指し示すオブジェクト。
&aで、int型のポインタ変数aのアドレスを参照できる。
int a = 10;
int *p;
p = &a;
printf("aのアドレスは%p\n", p);
printf("aのアドレスは%p\n", &a);
printf("aの値は%d\n", *p);
printf("aのポインタのアドレスは%p\n", &p);
これであってますか?
694:デフォルトの名無しさん
07/09/11 01:25:53
おk
695:デフォルトの名無しさん
07/09/11 01:27:08
>>695
*p = 20;
などの操作をして、aの値を確認してみるのも良い。
696:695
07/09/11 01:28:16
ミスった
>>693ね。
697:687
07/09/11 01:39:59
なるほどよくわかりました
ありが㌧
698:デフォルトの名無しさん
07/09/11 02:53:25
コンパイラがVisual C++ 2005 Express Edisionでstring,hが開けないって出るんだけど何ででしょう?
定義は#include <string,h>って書いてるんですけど他に何か設定しないとダメですか?
699:デフォルトの名無しさん
07/09/11 02:56:20
string,hじゃなくてstring.hじゃないか?
700:デフォルトの名無しさん
07/09/11 02:57:25
×string,h
○string.h
というオチじゃないだろうな?
701:698
07/09/11 03:02:51
そ れ だ
メモに貼り付けてフォント変えたら違いが判った
ありがとう!
702:デフォルトの名無しさん
07/09/11 06:39:00
>>680
> 16ビットCPUのポケコンを購入
> インタプリタで動作するCが組み込まれていて
メーカー教えて
703:デフォルトの名無しさん
07/09/11 06:51:08
文字配列とポインタで質問です
char *str[]={”山田”、”井之上”、”御手洗”、”鈴木”};
とした場合
配列は
char
str[0][0]="山", str[0][1]="田", str[0][2]="\0", str[0][3]="\0"
str[1][0]="井", str[1][1]="之", str[1][2]="上", str[1][3]="\0"
str[2][0]="御", str[2][1]="手", str[2][2]="洗", str[2][3]="\0"
str[3][0]="鈴", str[3][1]="木", str[3][2]="\0", str[3][3]="\0"
str[4][0]="\0", str[4][1]="\0", str[4][2]="\0", str[3][3]="\0"
と自動で入って各行の配列の先頭のアドレスが*str[1]や*str[2]に入ってるんでしょうか
704:デフォルトの名無しさん
07/09/11 06:59:57
いいえ
705:デフォルトの名無しさん
07/09/11 07:04:34
という事は
> char *str[]={”山田”、”井之上”、”御手洗”、”鈴木”};
これはどういう状態でしょう?
706:デフォルトの名無しさん
07/09/11 07:06:51
文法エラーの状態です
707:デフォルトの名無しさん
07/09/11 07:10:23
本に載ってる型の定義をそのまま写してみたんですがorz
ちょっとそのまま書いてみて試してみます
708:デフォルトの名無しさん
07/09/11 07:12:47
全角/半角、クォーテーション/ダブルクォーテーションに注意
709:デフォルトの名無しさん
07/09/11 07:19:55
char *str[]={"山田","井之上","御手洗","鈴木"};
文法ってそっちでしたかorz
これでよろしいですか?
710:デフォルトの名無しさん
07/09/11 07:55:59
ちょっと眠気で頭が鈍くなってきたけど
山田、井之上、御手洗、鈴木はそれぞれメモリのどこかに書き込んで
*str[0]~[3]にはメモリのそれぞれの文字列の先頭アドレスが入ってるってことかな
711:デフォルトの名無しさん
07/09/11 08:18:26
>>710
str[0]~[3]にはメモリのそれぞれの文字列の先頭アドレスが入ってるってこと
だと思うよ
712:デフォルトの名無しさん
07/09/11 08:26:49
あぁそっか*をつけるとアドレス先の中身だっけ
まだ微妙に疑問点あるけどひとまず寝ます
頭が動いてないorz
ありがとう
713:デフォルトの名無しさん
07/09/11 13:47:31
文字列の質問です。
1から100の自然数を”1”から”100”という文字列に変換せよ
って問題ですけど、どんなプログラムになりますか?
714:デフォルトの名無しさん
07/09/11 13:53:24
for文で回してsprintf使うとか。
715:デフォルトの名無しさん
07/09/11 14:16:56
char** func()
{
int i,j = 0;
char *cp[100]={'\0'};
for(i = 0; i < 100; i++)
cp[i] = ( char *)malloc(sizeof(char)*4);
for(j = 0,i = 1; i <= 100; i++,j++)
sprintf(cp[j],"%d",i);
return cp;
}
716:デフォルトの名無しさん
07/09/11 14:46:08
そりゃないだろw
717:デフォルトの名無しさん
07/09/11 14:52:54
>>715
変数の寿命を…
718:デフォルトの名無しさん
07/09/11 15:50:26
>>715
さっきは適当に書いて張りました
以下ソース
char** func(char **cp, size_t n)
{
int i,j = 0;
for(i = 0; i < n; i++)
cp[i] = ( char *)malloc(sizeof(char)*4);
for(j = 0,i = 1; i <= 100; i++,j++)
sprintf(cp[j],"%d ",i);
return cp;
}
719:デフォルトの名無しさん
07/09/11 15:57:14
for(i = 0; i < 100; i++)
sprintf(cp[i],"%d ",i+1);
これでいいじゃん
720:デフォルトの名無しさん
07/09/11 16:08:13
>>718
nが配列のサイズならループの最大値100にすんな
引数で渡してる奴を戻り値にすんな
721:デフォルトの名無しさん
07/09/11 16:28:09
ポインタの100個の配列もmallocすればいいのだ
でも質問者は完全版を求めてるの?
722:718
07/09/11 16:29:51
>>720
たしかにそうだね
オナニーしようかしまいか迷ってる最中に
書き込んだクソソースなんで
あんま吟味しないでね
723:デフォルトの名無しさん
07/09/11 16:39:01
何かアプリケーションを作ろうと思ったらCとC++どっちがいい?
724:デフォルトの名無しさん
07/09/11 17:10:17
伺系アプリの間違いだと信じたい
725:デフォルトの名無しさん
07/09/11 17:57:45
>>702
また難儀な・・・
押入れから引っ張り出してきたよ
あ~なつかしぃい
CASIO PERSONAL COMPUTER FX-890P 16-bit CPU
(液晶の枠部分に書かれている文字)
しかもこれ専用(?)のフロッピーディスクドライブ&そして(確か)増設メモリまで買ってしまったはず
起動したらまだ動く(リチウム電池は空)
(スレチスマソ)
726:デフォルトの名無しさん
07/09/11 18:09:21
>>725
姉妹品?のZ-1ならもってた
捨てちゃったけど
727:デフォルトの名無しさん
07/09/11 18:17:14
>>726
これかな?
URLリンク(www5.plala.or.jp)
っていうかキー配列とか同じだ
FX-890Pの文字がZ-1になってるぐらい
728:デフォルトの名無しさん
07/09/11 19:04:06
bcc32を使っているのですが、c言語のソースプログラムのファイル名に、
list1-1.cのように「-」を使ってもいいのでしょうか?
729:デフォルトの名無しさん
07/09/11 19:06:40
いいよ
730:デフォルトの名無しさん
07/09/11 19:59:08
>>723
C++のほうがお勧めかな。
理由
C++を勉強すると、Cも勉強できる。
C++を知っているとJavaとかも簡単に理解できる。
731:デフォルトの名無しさん
07/09/11 20:39:29
C#
732:デフォルトの名無しさん
07/09/11 20:44:32
printfとputsはどっち使えばいいですか?
皆さんどっち使ってます?
733:デフォルトの名無しさん
07/09/11 20:48:28
>>732
用途による
734:デフォルトの名無しさん
07/09/11 20:50:23
>>732
使っているのは断然 printf だよ
printf を使うことで処理速度に問題が出るようなコードは書いてないから
735:デフォルトの名無しさん
07/09/11 20:58:22
賢いコンパイラは適当に最適化してくれるから、printfつかっとけ。
736:デフォルトの名無しさん
07/09/11 22:44:59
<double>
43 23
<apple>
100E+02 102E-8 102E-12
<leon>
23E+01 12E-02
<kon>
24 23.3
とかいうファイルからE表記の数値だけを抜き取るにはどうすればいいですかね?
737:736
07/09/11 22:45:47
<double>
43 23
<apple>
100E+02 102E-8 102E-12
<leon>
23E+01 12E-02
<kon>
24 23.3
とかかれたファイルからですね。ファイル名はlist.txtとしておきます。
738:デフォルトの名無しさん
07/09/11 22:52:38
>>737
// 使用法 a.exe < list.txt
#include<stdio.h>
#include<string.h>
int main(void)
{
char buf[100];
double value;
int pos;
while(scanf("%s", buf)==1)
{
if(strchr(buf, 'E')!=NULL)
if(sscanf(buf, "%le%n", &value, &pos)>=1)
if(buf[pos]=='\0')
printf("%e\n", value);;
}
return 0;
}
739:736
07/09/11 23:13:38
やってみます
740:736
07/09/11 23:14:44
ありがとうございます
741:デフォルトの名無しさん
07/09/11 23:16:58
(゚Д゚≡゚Д゚)エッナニナニ?
742:デフォルトの名無しさん
07/09/12 02:40:36
入力した文字を逆にして出力したいのですが
#include <stdio.h>
#include <string.h>
int rev (char *);
int main()
{
char str[100];
printf("文字を入力してください\n");
gets_s(str);
rev(str);
printf("逆にしたのはこれです\n");
printf(str);
return 0;
}
int rev (char *str)
{
int i=0;
char str2[100];
size_t len;
len=strlen(str);
while(len>=0){
str2[i]=str[len];
i++;
len--;
}
str=str2;
return 0;
}
743:デフォルトの名無しさん
07/09/12 02:41:11
なぜかlenのカウントも増えていくんですけど何処がおかしいですか?
744:デフォルトの名無しさん
07/09/12 02:49:36
>char str2[100];
>str=str2;
とりあえずこれはまずい
「C言語 スコープ」とかでぐぐれ
745:デフォルトの名無しさん
07/09/12 02:50:27
関数からの見える範囲でしたっけ
ちょっと調べてみます
746:問題
07/09/12 03:04:16
問題:ポインタで操作しなさい
char moji[] ="ABCDEF~XYZ"; /*最大文字26文字*/
char *pc;
pc=moji;
結果
moji:ABCDEF~XYZ
開始位置==>B
終了位置==>F
表示:BCDEF
moji:ABCEF~XYZ
開始位置==>D
終了位置==>D
表示:D
moji:ABCDEF~XYZ
開始位置==>E
終了位置==>B
表示:EF~XYZAB
747:746の続き
07/09/12 03:05:46
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void print(char* s, char* e)
{
printf("表示:");
for( ; s <= e ; s++ ) putchar(*s);
puts("");
}
int main(void)
{
char moji[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
char *pc = moji, *pcstart, *pcend, start, end;
while(1) {
printf("moji:%s\n開始位置==>", moji); scanf("%c", &start);
printf("終了位置==>"); scanf("%c", &end);
pcstart = strchr(moji, start);
pcend = strchr(moji, end);
if( pcstart == NULL || pcend == NULL ) break;
if( pcstart <= pcend ) print(pcstart, pcend);
else print(pcend, pcstart);
}
}
この問題でどうしてもエラーが出るんですが何方かわかる方がいましたら教えてください
748:デフォルトの名無しさん
07/09/12 03:14:23
>>742
void rev(char *str)
{
int len = strlen(str);
int i;
char temp;
for(i = 0; i<len/2; i++)
{
temp = ary[i];
ary[i] = ary[len -i-1];
ary[len -i-1] = temp;
}
}
749:742
07/09/12 03:16:21
>>746
ちょ・・・ヒントかなぁって思って頑張って書いてたよorz
750:デフォルトの名無しさん
07/09/12 03:21:16
>>747
エラーってどんなエラー?
scanf("%c"~の挙動を理解してないとかそんなオチ?
751:742
07/09/12 03:26:59
>>748
sry[i]って初めて見るんですけどこれはなんでしょう?
参考に組ませて頂きます
752:742
07/09/12 03:27:42
×ary[i]
○ary[i]
でしたね
753:746の者です
07/09/12 03:29:31
警告 W8012 07.cpp 7: 符号付き値と符号なし値の比較(関数 MojiSearch(char *,char *) )
警告 W8012 07.cpp 8: 符号付き値と符号なし値の比較(関数 MojiSearch(char *,char *) )
警告 W8004 07.cpp 5: 'j' に代入した値は使われていない(関数 MojiSearch(char *,char *) )
↑がエラー内容です
6ヶ月ぶりにCに触れたんですが仕組みを忘れちゃってどう直せばいいのかわからなくなってしまったんですよ^^;
754:デフォルトの名無しさん
07/09/12 03:31:52
まずそのソースうpしる
>>747にMojiSearchなんて関数ないだろ
755:デフォルトの名無しさん
07/09/12 03:32:34
>>747
scanf実行後stdinには'\n'が残っていて
後のscanfが'\n'をとりこんでしまってる。
一応getc(stdin)で取り繕って変更したソース
の一部を載っける
int temp;
while(1) {
printf("moji:%s\n開始位置==>", moji);
scanf("%c", &start);
temp =getc(stdin);
printf("終了位置==>");
scanf("%c", &end);
temp =getc(stdin);
756:デフォルトの名無しさん
07/09/12 03:40:33
>>753
それはエラーじゃなくて警告って言うんだよ
757:デフォルトの名無しさん
07/09/12 04:30:43
>>753
signedとunsigned比較してんだろ
3つ目の警告は見たまんま
758:742
07/09/12 05:06:22
>>748
#include <stdio.h>
#include <string.h>
void rev (char *);
int main()
{
char str[100];
printf("文字を入力してください\n");
gets_s(str);
rev(str);
printf("逆にしたのはこれです\n");
printf(str);
return 0;
}
void rev (char *str)
{
int i=0,len=strlen(str);
char str2;
printf("文字の長さは%dです\n",len);
for(i=0;i<len/2;i++){
str2=str[i];
str[i]=str[len-i-1];
str[len-i-1]=str2;
}
}
ary[i]がまだ謎だけど出来たよ、ありがとう
759:746
07/09/12 10:35:45
自分で書いた方のソースがvoid rev (char *ary)だったんで
レス欄にコピペしたとき、「ああ、strか」と思い
aryの部分をstrに全部書き換えたつもりだったが
中途半端に書き換えちった
というわけ
760:デフォルトの名無しさん
07/09/12 10:48:01
警告を無視する奴は、とりあえず渓谷に行って来い
761:742
07/09/12 15:41:36
>>759
なるほど
あえて自分で考える事が出来たし結果オーライだったw
lenの-1も気づかなかったしなorz
スコープについてはまだ良くわかってないけど・・・
762:デフォルトの名無しさん
07/09/12 22:46:17
スマソ スコープについて調べろってのは勘違い
str2へのポインタを関数の外で使おうとしてるのかと思った
763:デフォルトの名無しさん
07/09/12 22:55:14
2点質問があります。
1.関数で配列全体を呼び出しもとに帰すにはどう記述すればよいのでしょうか?
例)a[0],a[1],a[2],a[3]といった、算出した値を配列要素としてではなく、配列全体をreturn文で返す
方法がわからずにおります。
2. 1+X+X^15で生成する疑似ランダムデータの作製法がわからずにおります。
どうかご教示願います。
764:デフォルトの名無しさん
07/09/12 22:58:17
>>763
マルチポストですか?
スレリンク(tech板:278番)
765:デフォルトの名無しさん
07/09/12 23:03:43
やさしいCを打ち込み終了し他の本も色々調べたのですが、
ポインタとかを理解するにはPICを勉強したほうが分かりやすいですか?
766:デフォルトの名無しさん
07/09/12 23:05:53
>>764
急いでいるのでマルチポストをしてしまいました。申し訳ございません。
767:デフォルトの名無しさん
07/09/12 23:07:33
>>765
問題をやった方が良い
768:デフォルトの名無しさん
07/09/12 23:31:22
>>764
大体、関連した話題を扱うスレッドには同じ人が見にきているものだ。
だからマルチポストするとすぐに見つかってしまう。しかも反感を買い回答が得られなくなる。
だから1箇所に投稿し、回答が得られるまで自分でも必死こいて調べるべし。
769:デフォルトの名無しさん
07/09/12 23:33:34
>>765
問題をやるのがいいな。
770:デフォルトの名無しさん
07/09/12 23:56:35
>>767,769
ありがとうございます。問題を解くことからはじめます。
771:デフォルトの名無しさん
07/09/13 02:41:58
>>771
宿題スレの問題をやってみるとか。
いろんな人が同じ問題を問いて解答も出してくれるので、
自分とここが違う、とか、これはこうやって実現するのか、とか、
いろいろ気づくところがあるかも知れないよ。
772:デフォルトの名無しさん
07/09/13 02:42:28
>>771は>>770にだよう。自分に言ってどうする。
773:デフォルトの名無しさん
07/09/13 02:49:26
標準ライブラリ関数を使わずに、コンソールに文字列を出力してみようと思い
システムコールのwriteを使ってみたつもりです。
#include <unistd.h>
int main(void) {
char s[] = "test\n";
write(1, s, sizeof(s));
return 0;
}
Cygwin の gcc 3.3.3 で、-ansi -Wall -pedantic -fno-builtin で
コンパイルできて、期待した動作になりました。
で、glibc-2.6.1の io/write.c を見ると
/*
続く
774:デフォルトの名無しさん
07/09/13 02:54:40
続き、少しインデントを変えています。
*/
#include <sysdep.h>
#include <errno.h>
#include <unistd.h>
#include <stddef.h>
ssize_t __libc_write (int fd, const void *buf, size_t nbytes)
{
if (nbytes == 0) return 0;
if (fd < 0) {__set_errno (EBADF); return -1;}
if (buf == NULL) {__set_errno (EINVAL); return -1;}
__set_errno (ENOSYS); return -1;
}
libc_hidden_def (__libc_write)
stub_warning (write)
weak_alias (__libc_write, __write)
libc_hidden_weak (__write)
weak_alias (__libc_write, write)
#include <stub-tag.h>
write.c にはこれだけしかないのですが、
fd の値や *buf 内のデータなどは、どこで使われているんでしょうか?
たとえば buf は NULL とだけ比較していますが、
実際に fd に向かって buf を書き込む(?)処理は、どこでやっているんですか?
775:デフォルトの名無しさん
07/09/13 11:37:00
>>773
URLリンク(www.sixnine.net)
>Cygwin は glibc を提供しません。
>代わりに、同じ機能の大部分(全てではありません)を提供する newlib を使用します。
>glibc を Cygwin へ移植するのは難しいでしょう。
776:問題
07/09/13 11:59:26
何方か今から掲示する4問の問題が合ってるか教えてください(パソをメンテに出していて手元になくて調べられないんです^^;)
キーボードより表示開始文字と表示終了文字を入力し、開始~終了までの文字を表示しなさい
char moji[]="ABCDEF~XYZ"; /*大文字26文字*/
実行画面
moji:ABCDEF~XYZ
開始位置==>B
終了位置==>F
表示:BCDEF
moji:ABCDEF~XYZ
開始位置==>D
終了位置==>D
表示:D
moji:ABCDEF~XYZ
開始位置==>E
終了位置==>B
表示:EF~XYZAB
777:776の答え
07/09/13 12:00:14
moji:ABCDEF~XYZ
開始位置==>B
終了位置==>F
表示:BCDEF
778:776の答え(777ミスです)
07/09/13 12:01:06
#include <stdio.h>
#include <ctype.h>
int main(void)
{
char moji[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"; /*大文字26文字*/
char start, end, *p;
printf("moji:%s\n", moji);
printf("開始位置==>");
scanf("%c", &start);
fflush(stdin);
printf("終了位置==>");
scanf("%c", &end);
fflush(stdin);
if(!isalpha((int)start) || !isalpha(end)) return 1;
start = (char)toupper(start);
end = (char)toupper(end);
p = moji + start - 'A';
for(;;)
{
putchar(*p);
if(*p == end) break;
if(*(++p) == '\0') p = moji;
}
return 0;
}
779:問題2
07/09/13 12:04:11
文字列と削除文字列を入力し文字列中から削除文字を排除しなさい
実行画面
文字列入力(m1)==>ABCDEFAABCDABC
削除文字==>A
結果文字列(m2):BCDEFBCDBC
780:問題2の答え
07/09/13 12:05:38
#include <stdio.h>
#include <string.h>
#define MAX 256
int main(void)
{
char str[MAX],ch;
size_t sz_str,i;
printf("文字配列入力(m1)==>");
fgets(str,sizeof(str)/sizeof(str[0]),stdin);
sz_str=strlen(str);
printf("排除文字==>");
ch=getchar();
for(i=0; i<sz_str; i++) {
if(str[i]!=ch) putchar(str[i]);
}
return 0;
}
781:デフォルトの名無しさん
07/09/13 12:25:21
この形式の問題何回目だよwwwww
782:デフォルトの名無しさん
07/09/13 12:34:12
くだらん質問なんだけど
バッファサイズを256とか512みたいな16の倍数にしてるコードよく見るけど
そうするとどういう効果があるの?
783:デフォルトの名無しさん
07/09/13 12:34:49
単にキリがいいから使ってるだけ
784:デフォルトの名無しさん
07/09/13 13:12:50
どっちかっつうと2の乗数だが、キリが良いから
785:デフォルトの名無しさん
07/09/13 13:17:36
>>784
2の乗数っていうか、2の羃だね。
786:デフォルトの名無しさん
07/09/13 13:23:03
キリがいいからか
漏れもなんとなくキリがいいから使ってたよw
サソクス
787:デフォルトの名無しさん
07/09/13 13:33:44
文系グラマは100とか1000使うのかな
788:デフォルトの名無しさん
07/09/13 13:46:38
main関数の戻り値ってどういう時使うんですか?
789:デフォルトの名無しさん
07/09/13 13:55:42
>>788
コマンドインタプリタで該当プログラムの終了ステータスとして利用する。
790:デフォルトの名無しさん
07/09/13 15:03:30
>>788
他のプログラムから起動させたとき
791:デフォルトの名無しさん
07/09/13 16:22:48
>>788
#!/bin/sh
if ./a.out; then
echo "成功" # main が 0 を返した時
else
echo "失敗..." # main が 1 を返した時
fi
792:デフォルトの名無しさん
07/09/13 20:54:10
printf("%6.1f",123.45);
を実行すると
123.5
となるのはなぜですか?
123.4になぜなりませんか?
793:デフォルトの名無しさん
07/09/13 20:57:12
一つしたの桁を四捨五入するから。
794:デフォルトの名無しさん
07/09/13 21:01:27
>>793
thx
795:デフォルトの名無しさん
07/09/14 01:02:02
>>775
ありがとうございます。newlibですか。
ではCygwinはおいといて、>>774はglibcの実装についての質問とさせてください。
glibcのwrite.cで定義されている __libc_write の仮引数の使われ方について
なぜこの引数でfdへ書き込みがおこなわれるのでしょうか?
796:デフォルトの名無しさん
07/09/14 02:17:33
たぶんそのソースは実際にコンパイルされるコードじゃない。
システムコールをどうやって呼ぶかはOSやCPUによって異なるから、それはただのプレースホルダだろう。
ざっとみてみたところ、sysdeps/unix/syscalls.listからmake-syscalls.shで自動生成されるんじゃないかと思った。
でも複雑すぎて追いきれん。
実際に特定のターゲット向けにビルドしてみて、生成されたファイルを見なきゃ判らなさそう。
797:デフォルトの名無しさん
07/09/14 02:41:12
>>795
その関数はターゲット用のwrite()が存在しない場合に使われるダミー関数。
writeしても呼ばれない。
798:デフォルトの名無しさん
07/09/14 08:46:05
0: -19.312 -0.144 -0.996 1.412 -0.173 1.933 3.954 4.917 6.333 1.552
-1.515 -1.667 -0.151 0.230 -0.024 0.083 0.377 0.665 0.722 -0.195
-2.321 -1.814 -0.133 0.515 1.343 0.000
1: -19.304 -0.162 -1.799 4.184 1.255 -0.393 -0.335 0.469 1.268 -2.177
-2.390 0.198 -0.151 -0.086 0.111 0.100 0.038 1.462 0.937 -0.569
-0.975 -1.590 -0.486 -0.450 0.133 0.000
2: -18.166 -0.254 -0.178 1.909 2.438 6.705 5.126 -4.463 -0.205 2.752
1.499 4.116 -0.151 0.167 -0.024 -0.312 -0.069 1.179 0.724 -0.214
0.460 -0.921 0.742 0.284 -0.377 0.000
こうかかれたファイルから小数点のところだけ
とりだして二次元配列にいれるにはどうすればいいすかね?
小数点のところ26個あるんですけど。
799:デフォルトの名無しさん
07/09/14 09:33:40
コロンの後まで飛ばして読み込め
800:デフォルトの名無しさん
07/09/14 11:16:37
指定したパスに、ある拡張子のファイルが存在するか調べるために
_dos_findfirstを使用して、BCCでコンパイルしたら
> Warning W8053 2007-09-14_1.c 11: '_dos_findfirst(const signed char *,unsigned int,find_t *)'
> is obsolete in function main
という警告が出ました。obsoleteとは「旧式の、廃れた」という意味です。
これに代わるものはありますか?
801:デフォルトの名無しさん
07/09/14 11:26:11
>>800
dos.hの_dos_findfirst()か、_dos_xxxは古いわなあ。
io.hの_findfirst()でどうか。
802:デフォルトの名無しさん
07/09/14 11:32:30
>>801
なるほど、ありがとうございました。
803:デフォルトの名無しさん
07/09/14 14:01:30
ものすごく初歩的な質問で申し訳ありません。
C言語の入門書にそって勉強していたのですがすぐに躓いてしまいました。
hello worldを表示するソースファイルをコンパイルしようとしたのですが下のエラーが出てきてしまいました。
C:\cwork>bcc32 sample.c
Borland C++ 5.5.1 for Win32 Copyright (c) 1993, 2000 Borland
sample.c:
エラー E2209 sample.c 2: インクルードファイル 'stdio.h' をオープンできない
警告 W8065 sample.c 6: プロトタイプ宣言のない関数 'printf' の呼び出し(関数 main
)
*** 1 errors in Compile ***
何かと思い検索してみて確認したのですが原因がわかりません。
なにか分かる方いらっしゃればアドバイスよろしくお願いします。
804:デフォルトの名無しさん
07/09/14 14:18:24
>>803
C:\borland\bcc55\Include\ の中にファイルはあるか?
インストールはどのファイルをどうやって実行した?
805:デフォルトの名無しさん
07/09/14 14:24:35
>>803
URLリンク(www.google.co.jp)
806:デフォルトの名無しさん
07/09/14 14:27:54
>>803
PATHを通してないんでしょうな、多分。
807:デフォルトの名無しさん
07/09/14 14:41:49
PATH通してなかったらbcc32自体出来ないだろ
808:デフォルトの名無しさん
07/09/14 14:55:56
オレもそう思った。
cfgもデフォルトだろうし、アップデート用のインストーラ使ったんじゃないかと予想。
809:デフォルトの名無しさん
07/09/14 15:13:25
皆様すばやいレスありがとうございます。
>>804様
C:\borland\bcc55\Includeの中にstdio.hはありました。
インストールはその入門書についてあるCDに収録されていた
freecommandlinetools2.exeというファイルを実行しました。
>>807様
Pathは通したつもりでいます。
入門書に書かれてあることをそのまま行っただけなので間違いないとは言い切れませんが。
810:デフォルトの名無しさん
07/09/14 15:20:23
C:\borland\bcc55\Bin に、
bcc32.cfg、ilink32.cfg はあるか?
テキストエディタで開いて、以下に設定されているか確認。無ければ以下のをそれぞれ保存
・bcc32.cfg
-I"c:\Borland\Bcc55\include"
-L"c:\Borland\Bcc55\lib;c:\Borland\Bcc55\lib\PSDK"
・ilink32.cfg
-L"c:\Borland\Bcc55\lib;c:\Borland\Bcc55\lib\PSDK"
811:デフォルトの名無しさん
07/09/14 15:22:48
結局、インクルードパスか、、、cfgが確実だな
812:803
07/09/14 15:36:19
>>810様
bcc32.cfg、ilink32.cfg はC:\borland\bcc55\Binにあります。
bcc32.cfg、ilink32.cfg ともに;c:\Borland\Bcc55\lib\PSDK"の部分はありませんでした。
そこで;c:\Borland\Bcc55\lib\PSDK" を追加してみましたがやはりエラーでした。
813:デフォルトの名無しさん
07/09/14 15:36:28
>>807 >>808
知ったかぶるなら黙ってろ。お前らの頭じゃPATHの意味すらわかってなさそうだから。
814:デフォルトの名無しさん
07/09/14 15:39:02
>>812
面倒くさいんでこれ使っちゃいな
URLリンク(www.vector.co.jp)
815:デフォルトの名無しさん
07/09/14 15:41:25
>>812
どうしても嫌ならこれで
URLリンク(www.enri.go.jp)
816:デフォルトの名無しさん
07/09/14 15:43:39
>>807
カレントディレクトリをコンパイラのある場所に移動すりゃ良いんじゃね?
エラーメッセージから推測できるのは、必要なファイルのある場所の
設定がされていないということ。つまり、そういうことだ。
PATHが必要なものに設定されていればどうなるか、分かるよね?
817:デフォルトの名無しさん
07/09/14 15:43:57
>>813
おまえ、名指しで何か言うなら知ったかしないほうがいいぞ
PATHの意味を言ってみ?
818:デフォルトの名無しさん
07/09/14 15:44:54
>>816
>C:\cwork>bcc32 sample.c
>Borland C++ 5.5.1 for Win32 Copyright (c) 1993, 2000 Borland
この2つからPATHが通っているのは明白
819:デフォルトの名無しさん
07/09/14 15:46:34
>>817
味方にボールを送る事に決まってんだろうが
820:デフォルトの名無しさん
07/09/14 15:53:56
それはPASS
821:デフォルトの名無しさん
07/09/14 15:56:07
>>819
アホか
ヤマハの電動アシスト自転車の事だろ
822:803
07/09/14 15:57:16
>>814-815様
ありがとうございます。
試してみようと思います。
>>816様
ソースファイルを作成したc:\cworkというディレクトリに移動しているのですが、こういうことでしょうか?
823:803
07/09/14 16:10:52
>>814様のソフトをダウンロードして自動設定したら解決できました。
皆様お忙しいところくだらない質問に時間を割いていただき本当にありがとうございました。
824:デフォルトの名無しさん
07/09/14 16:13:02
結局、原因はなんだったんだろうな
825:デフォルトの名無しさん
07/09/14 16:19:23
どういたしまして
がんばって
826:デフォルトの名無しさん
07/09/14 16:21:01
cfgのタイプミスだろうなあ・・・
827:デフォルトの名無しさん
07/09/14 16:36:51
>>821の言っている事がわからない
828:デフォルトの名無しさん
07/09/14 16:41:00
知らないならレスしなくていいよ
つーか知っててもスルーしてるが
829:デフォルトの名無しさん
07/09/14 18:49:34
FFFFFF80を2進数に直すと、どうして
11111111 11111111 11111111 1000000になるのかわかりません
特に、80は 0101000では?
830:デフォルトの名無しさん
07/09/14 18:51:39
>>829
(0101)2 → (5)10
831:デフォルトの名無しさん
07/09/14 18:56:10
レス、ありがとうございます
???
間違っているのですか?
832:デフォルトの名無しさん
07/09/14 18:56:41
16進の80
2進だと1000000
10進の80と誤解してると思われ
833:デフォルトの名無しさん
07/09/14 18:59:02
0一個たんなかった
834:デフォルトの名無しさん
07/09/14 19:02:19
>>832
ん~どうしてもわかりません
では、2進数の80では、0101000で合っていて
16進数の80では、どうして1000000になるのでしょうか?
835:デフォルトの名無しさん
07/09/14 19:10:41
2進数の80なんかあるか。2進数は1と0だけ。
836:デフォルトの名無しさん
07/09/14 19:12:30
(x)y を y進法で表すxとする
(80)10 = (0101000)2
(80)16 = (128)10 = (10000000)2
837:デフォルトの名無しさん
07/09/14 19:13:01
16進数の80 = 10進数の128 = 2進数の10000000
16進数の50 = 10進数の80 = 2進数の10100000
838:デフォルトの名無しさん
07/09/14 19:16:47
>>836 >>837
計算違くね
(80)10 = (0101 0000)2
839:837
07/09/14 19:18:05
うぁ。みすorz
840:829
07/09/14 19:23:39
皆さん、レスありがとうございます。
>>16進数の80 = 10進数の128 = 2進数の10000000
16進数の50 = 10進数の80 = 2進数の10100000
では、一旦10進数に置き換えてから、2進ぬするのでしょうか?
どうやれば、16進数の80は10進数の128に、又は16進数の50は10進数の80に
直せるのでしょうか?
841:デフォルトの名無しさん
07/09/14 19:31:21
>>840
ググれば解説しているサイトはたくさんある
842:デフォルトの名無しさん
07/09/14 19:32:12
>>840
16進から2進の場合、は分割するんよ
FFFFFF80
F=1111 , 8 = 1000 , 0=0
あとはくっつける
1111 1111 1111 1111 1111 1111 1000 0000
FFFFFF80(16)=11111111111111111111111110000000(2)
って感じ
843:デフォルトの名無しさん
07/09/14 19:34:44
>>840
失礼、ちょっと訂正
FFFFFF80
F(16)=1111(2) , 8(16)=1000(2) , 0(16)=0000(2) ね
10進に直すより16進→2進 、2進→16進の方が楽(のはず)
844:デフォルトの名無しさん
07/09/14 19:42:23
さすがにゆとり教育杉な気もしてきた
845:デフォルトの名無しさん
07/09/14 19:44:21
C言語がいいらしいんですが無料でできますか?
846:デフォルトの名無しさん
07/09/14 19:46:33
はい
847:デフォルトの名無しさん
07/09/14 20:11:41
ありがとうございましm(__)m
これで先に進めます
848:デフォルトの名無しさん
07/09/14 20:49:08
>>840の解説に同意。
16って2^4(二の四乗)の事ですよね。
つまり、2進数表現4ビットの最大値(1111)
が、16進数Fに相当している事もわかりますよね。
したがって、>>840の解説を御借りすると、
FFFFFF80
F=1111 , 8 = 1000 , 0=0
【|】(パイプ)で区切ると
1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1000 | 0000 (2)
F F F F F F 8 0 (10)
となります。
849:デフォルトの名無しさん
07/09/14 20:50:17
>>840じゃなくて、>>842でした。
850:デフォルトの名無しさん
07/09/14 22:59:14
C言語なんですが、ファイルに書き込むときって自分でEOF書き込むんですか??
それとも、閉じるときに勝手にやってくれるんでしょうか。
851:デフォルトの名無しさん
07/09/14 23:03:47
>>850
閉じるときに勝手にやってくれる。
つか、EOFというデータはないんだけど。
ファイルの最後まで読んだときfreadなどのファイル入出力関数がEOFを返すだけ。
852:デフォルトの名無しさん
07/09/14 23:24:22
あ、そうなんですか!
てっきり、改行コードみたいにEOFっていう記号があるのかと思いました。。。
853:デフォルトの名無しさん
07/09/14 23:37:45
URL
854:デフォルトの名無しさん
07/09/14 23:59:28
>>796 >>797
超ありがとうございます。
勉強します。
855:デフォルトの名無しさん
07/09/15 00:25:48
>>852
EOF=1A じゃなかったかな。昔のテキストファイルには使っていたと聞くよ。
856:852
07/09/15 00:40:18
>>855
MS-DOSのテキストファイルにはEOF(1Ah)が書かれていたようですね。
EOF(1Ah)がファイル内に実際にデータとして書かれているものと書かれていないもの
さらに、書かれているもののうちアプリケーションがこのEOF(1Ah)をデータとして
意識すべきものと意識しなくてよいもの
があるようですね。
ファイルのデータをレングスで管理しているファイルシステムはEOFがなくて、
このレングスがないファイルシステムにはEOFがデータとしてある。
ということでしょうか。
857:852
07/09/15 00:45:30
ということで>>850さん
EOFをアプリケーションで書き出す必要があるかないかは、
「ファイルの仕様による」ということです。
Windowsのハードディスクのファイルは書き出す必要はありません。
858:デフォルトの名無しさん
07/09/15 00:51:53
>>852、855
ありがとうございます~ むっちゃわかりやすかったっす。
859:デフォルトの名無しさん
07/09/15 01:47:18
CのライブラリのEOFとアプリが使う終了のマークを一緒にしたらだめでしょ。
860:デフォルトの名無しさん
07/09/15 02:08:55
>>817
お前とかうぜーよ、偉そうに。英語すら理解していないだろ。
URLリンク(dictionary.goo.ne.jp)
必要なデータやプログラムのある場所へPATHを通しておくことで
どこのディレクトリからでも扱えるようにできるようになることくらい知っているだろ。
っつかお前、DOSとかその他そういった仕組みを持ったシステムを使ったことないだろ?
861:デフォルトの名無しさん
07/09/15 02:12:21
>>857
>Windowsのハードディスクのファイルは書き出す必要はありません。
判っていないのならレスしなくてもよろしいのでは?
862:デフォルトの名無しさん
07/09/15 02:13:29
どうやらPATHの意味をそれぞれ勝手に解釈している同士が罵り合っている模様。
仲のいいことで。
863:デフォルトの名無しさん
07/09/15 02:17:01
>>861
そういうレスはいけないと思うよ。
間違っているを指摘すべきだと思う。
864:デフォルトの名無しさん
07/09/15 02:41:12
猫でもわかるC言語プログラミングP.196によると下記のようなプログラムはだめ
ということですがBCCではコンパイルが通り、実行しても問題は見られませんでした
char *strではなくchar str[32]なら可とのこと
なぜでしょうか?
もうひとつ
下記のプログラムでprintf("%sの長さは%dです\n",*str,len);
のように%sに対して*strとすると実行時にエラーになりますが
*strなら中身のASCIIコードが入っているはずで問題ないと思うのですが…
ご教示願います。
#include <stdio.h>
#include <string.h>
int main()
{
char *str;
size_t len;
printf("文字列を入力してください。--");
scanf("%s", str);
len = strlen(str);
printf("%sの長さは%dです\n",str,len);
return 0;
}
865:デフォルトの名無しさん
07/09/15 02:41:52
>>864
%s→%c
866:デフォルトの名無しさん
07/09/15 02:43:37
char str[32]でも不可です
867:デフォルトの名無しさん
07/09/15 02:48:22
>>864
> 猫でもわかるC言語プログラミングP.196によると下記のようなプログラムはだめ
> ということですがBCCではコンパイルが通り、実行しても問題は見られませんでした
> char *strではなくchar str[32]なら可とのこと
問題が無かったのは str の指す先が*偶然*致命的な場所で無かっただけで
予期しない場所が書き換えられています
str が指す先がちゃんと確保されている場合には問題は無いです
868:デフォルトの名無しさん
07/09/15 03:05:22
>>864
その本には、なぜダメかってのは書いてないのか。
869:デフォルトの名無しさん
07/09/15 04:39:20
scanfとprintfの関数の違いと働きを教えてください。お願いします。
870:デフォルトの名無しさん
07/09/15 04:41:45
URLリンク(ja.wikipedia.org)
URLリンク(ja.wikipedia.org)
871:デフォルトの名無しさん
07/09/15 04:48:43
>>869
scanf - scan with format
printf - print with format
872:デフォルトの名無しさん
07/09/15 14:13:04
さすが猫ですね
873:デフォルトの名無しさん
07/09/16 00:32:08
データが1個増えるたびにreallocしてることが発覚しましたw
バカすぎますか?
874:デフォルトの名無しさん
07/09/16 00:34:36
はい
875:デフォルトの名無しさん
07/09/16 00:34:40
データが増える間隔とデータ量による
876:デフォルトの名無しさん
07/09/16 00:38:15
>>873
実装が楽なので使い捨てコードのときにはそうします
877:デフォルトの名無しさん
07/09/16 00:42:30
>>873
一個ごとでも、まったくOK。
データの複数個ずつぶんのメモリを確保しても、ほとんどの場合は、
スピードアップしません。
878:デフォルトの名無しさん
07/09/16 00:48:01
vectorとかでも中では一回ごとにrealloc的なことしてるんだっけ?
879:デフォルトの名無しさん
07/09/16 01:24:37
>>878
ここは C のスレですぜ
> vector
ってなに?
880:デフォルトの名無しさん
07/09/16 01:34:48
ここは東京だぜ
881:デフォルトの名無しさん
07/09/16 02:19:19
読み込んだ数式を逆ポーランド記法に変換しようとしてるんですが、
1+(3+(4-2)+1)*4
のようにすると、1342-+1+4*-という式になってしまいます。
else if(source[i] == ')'){
while( now > 0 && stack[now -1] != '('){
rpn[r++] = stack[--now];
}
--now;
}
原因がわかりません。教えてください。
できれば解決策もm(_ _)m
882:864
07/09/16 02:45:34
レスありがとうございます
>>865
確かに%cとすると一文字だけですが表示されます
JavaをかじってたこともあってString型がCにもあると思い込み,いわゆる文字列がポインタであることを理解していませんでした
pritf("%d",i);のようにカンマの後には変数名を書けばよいと思っていましたが
%sの場合は例外でポインタを書かないといけないのですね
確かにそうすると表記上はすべて変数名のように見えて綺麗ですから、そのためにそのような設計になったのでしょうか…
>>866
31文字以上は入力しないという前提でも不可なのでしょうか?
>>867
char *str ではポインタ(アドレス変数)が確保されただけでその中身については未定義で
さらに、その中身のアドレスの後ろが他のことに使われていないという保証もないから不可で
char str[32]なら31文字分については安全な場所が確保されるからOKという理解で正しいでしょうか
>>869
本文をそのまま引用すると
『strはchar型へのポインタですね。ということはアドレスを格納する変数なのです。これではだめですね。』
とのことです。
しかし、scanfやstrlenについては、渡すべきものはアドレスであり間違えているようには考えられず
printfについても%sにはポインタを渡すのであっているようなので理由が私にはわかりませんでした。
883:デフォルトの名無しさん
07/09/16 03:18:00
適当な本だな
884:デフォルトの名無しさん
07/09/16 03:34:24
渡すべきものはアドレスだが、その渡しているアドレスの値が適切なのかどうかということだ。
scanfは、渡されたアドレスが示すメモリ領域を書き換えるのだから、適当なアドレスを渡してはいけない。
特に、初期化してないポインタ (どのアドレスを指してるか不定) を渡すなんて、もってのほか。
書き換えられても安全な領域 (char[32]とか) を用意して、そのアドレスを渡す必要がある。
885:881
07/09/16 04:01:59
すみません自己解決しましたm(_ _)m
886:デフォルトの名無しさん
07/09/16 04:12:05
1+(3+(4-2)+1)*4 は逆ポーランド記法で
4 2 - 3 + 1 + 4 * 1 + で合ってますか?
887:デフォルトの名無しさん
07/09/16 04:22:14
車輪の再開発は止めましょう
その程度の計算なら電卓でできます。
暗算でもできるでしょ?
作る意味無いよ
888:デフォルトの名無しさん
07/09/16 04:28:51
∩_
〈〈〈 ヽ
〈⊃ }
∩___∩ | |
| ノ ヽ ! !
/ ● ● | /
| ( _●_) ミ/ <こいつ最高にアホ
彡、 |∪| /
/ __ ヽノ /
(___) /
889:デフォルトの名無しさん
07/09/16 04:58:38
∩___∩
| ノ ヽ !
/ ● ● | こいつも最高にアホ
| ( _●_) ミ
彡、 |∪| / .\
/ __ ヽノ / \ ...\
(___) / .│ ..│
/ ヽ
l..lUUU
.U
890:デフォルトの名無しさん
07/09/16 05:19:03
そんな餌に俺様が釣られクマーー
891:デフォルトの名無しさん
07/09/16 06:42:36
>>886
1342-+1+4*+ かな。
892:デフォルトの名無しさん
07/09/16 08:17:49
>>886
適当に作ってみた。
やっぱり 1342-+1+4*+ になる。
URLリンク(sund1.sakura.ne.jp)
893:デフォルトの名無しさん
07/09/16 09:03:32
>>886
1+(2+3) と 2+3+1 が同じだというならそれでも合ってる
894:デフォルトの名無しさん
07/09/16 12:10:01
>>873-879
おれの居る現場の既存のコードでは、
最終的に300~400MBのメモリを確保するのに、reallocを繰り返して、
延べ 2.5GBぶんコピーを繰り返している事が分かったよ。
DBのテーブルのデータを一度メモリーに全部取り出すんだ...orz
895:デフォルトの名無しさん
07/09/16 12:12:34
>>894
それだとDBの意味ががが
元からなさそうな感じではあるけど
896:デフォルトの名無しさん
07/09/16 12:32:44
realloc()を使うと、毎回確保し直すと思っている馬鹿が多いのか?
自分でわざわざ回数まとめてからrealloc()するようなコード書くより、
毎回realloc()する方が速いかもしれないぞw
897:デフォルトの名無しさん
07/09/16 12:39:00
そんな当たり前の事言われても。
898:894
07/09/16 13:03:07
>>895
まあ100%無意味って訳じゃないんだけどね。一応SQLの恩恵は受けているから。
でもバッチ系が全部、「始めてプログラムを組んだんじゃないか?」ってレベルなんだ。
>>894のコードも基本的に集計するだけだから、DBの設計さえ良ければ単純なSQLで済むはずなのになー。
ハッ、ここは愚痴スレじゃなかったなスマソ。
899:デフォルトの名無しさん
07/09/16 13:10:10
気づいたんなら送信するな
900:894
07/09/16 13:16:21
>>896
その話は聞いたことあるが、そういうレベルじゃない。
reallocその物を使わないで済ませられるような場面でやってるだよ。
901:デフォルトの名無しさん
07/09/16 15:00:29
realloc()って新たに確保した場所にそれ以前のものをコピーするんじゃなかったっけ?
毎回やっているかは知らんが
902:デフォルトの名無しさん
07/09/16 15:06:55
>>901
元の領域に連続した領域を確保できれば、単純な拡張でよいので、
コピーは省略出来る。
903:デフォルトの名無しさん
07/09/16 15:09:04
>>901
#include <stdio.h>
#include <stdlib.h>
int main(int argc, char *argv[]){
void *ptr=NULL, *new_ptr;
int i, count=0;
for(i=1;i<=1000;i++){
new_ptr=realloc(ptr, i*100);
if(ptr!=new_ptr){
fprintf(stderr, "pointer changed. [%d]\n", i);
ptr=new_ptr;
count++;
}
}
printf("change count : %d\n", count);
free(ptr);
return 0;
}
904:デフォルトの名無しさん
07/09/16 18:10:12
巨大な配列を宣言時に同じ値で初期化したいんですけどこういう場合に簡略化する書き方とかないですかね
void func()
{
static int array[3000] = { 0, .. ,0};
}
的な…
905:デフォルトの名無しさん
07/09/16 18:20:31
{0}
っていうかstaticって自動的に0で初期化されなかったっけ?
906:デフォルトの名無しさん
07/09/16 18:33:31
サンクス。うまくいきますた。
907:デフォルトの名無しさん
07/09/16 18:43:25
グローバル変数、静的変数は宣言時に全ての要素が 0 で初期化される。
ローカルな配列は、宣言時に1つ(1要素)でも初期化を行うと残りが全て 0 で初期化される。
int a[3000]; // a[0]~a[2999] まで全て 0
int b[3000] = {1, 2, 3}; // b[0]=1, b[1]=2, b[2]=3, b[3]~b[2999]=0
int c[3000] = {1}; // c[0]=1, c[1]~c[2999]=0
main(){
int d[3000]; // d[0]~d[2999] まで全て不定値(適当な値)
static int e[3000]; // a と同じ
int f[3000] = {1, 2}; // bとかcと同じ
}
よく、ローカルな配列を 0 で初期化するために array[256] = {0}; とか書くが、
1要素でも初期化すると残りが 0 で初期化されることを利用しているだけ。
array[256] = {1}; と書いて全ての要素が 1 で初期化されると誤解するやつが多い。
任意の値で初期化させたければ、n次元の配列はn重のループを普通に書く。
C++ならalgorithmのfillなんかを使えばいい。
908:デフォルトの名無しさん
07/09/16 20:37:21
>>904
staticなら自動的に0で初期化される。
関数内staticにするなら、他の値は難しいな。
呼び出しの都度初期化でいいならmemsetとかでも良いだろうけど。
909:デフォルトの名無しさん
07/09/16 20:39:25
複数ファイルにソースを書くときのお作法を知りたいんだけど、わかりやすいところないかな
910:デフォルトの名無しさん
07/09/17 01:00:33
>>909
ヘッダファイルから書き始める
911:デフォルトの名無しさん
07/09/17 02:30:43
新しくコード書くとき
既存のファイルに加えるか
新しくファイル作成するか迷うんだけど
どういう基準でやったらいいですか?
912:デフォルトの名無しさん
07/09/17 10:25:01
設計上モジュールが分かれてたらファイルを分ける。
CUnit使うなら1ファイルに1関数。
913: ◆7qRx8xrwgo
07/09/17 11:51:39
質問させていただきます。
円記号を表示します。 :\
アポストロフィを表示します。:\
と、出力したくて
#include <stdio.h>
int main(void)
{
printf("円記号を表示します。 :%c\n", '\\');
printf("アポストロフィを表示します。:%c\n", '\'');
return 0;
}
でコンパイルしてみたのですが、
Sample5.c:5:12: warning: unknown escape sequence: '\216'
Sample5.c:6:12: warning: unknown escape sequence: '\216'
とエラーが出たのですが、どうすればエラーが表示されなくなりますか?
914:デフォルトの名無しさん
07/09/17 11:53:04
>>913
表示
↓
出力
915:デフォルトの名無しさん
07/09/17 11:55:23
「表」の後ろに¥を入れれば直るかも。
916:デフォルトの名無しさん
07/09/17 11:59:13
OSとコンパイラは何?
917:デフォルトの名無しさん
07/09/17 12:03:44
>>913
文字コード Shift-Jis の時
[表示] = 0x95 0x5C 0x8E 0xA6
0x5C = '\\'
0x8E = 0216 <- 8進数
\216 を解釈しようとして、そんなエスケープシーケンスがないという
*警告*がでているだけ
日本語対応しているコンパイラを使うほうが楽
918:913 ◆7qRx8xrwgo
07/09/17 12:16:57
>>914
本に表示と書いてありました
>>915
失礼ながら半信半疑で試したところ、仰るとおり直りました。
>>916
OS:Wndows XP HE SP2
コンパイラ: gcc(Cygwin)
>>917
解説ありがとうございます。今はコンパイラを変えたくないのでこのままでいこうと思います。
もしよろしければ、「表示」のように、気をつけた方がいい単語が他にもありましたら教えてください。
919:デフォルトの名無しさん
07/09/17 12:22:35
>>918
―ソЫⅨ噂浬欺圭構蚕十申曾箪貼能表暴予禄兔喀媾彌拿杤歃
920:デフォルトの名無しさん
07/09/17 12:26:19
gcc に --input-charset=cp932 --exec-charset=cp932 オプションをつけてみ
921:デフォルトの名無しさん
07/09/17 12:32:32
>>920 thx
MinGW (GCC.EXE (GCC) 3.4.2 (mingw-special)) でもいけたよ
さっそく CFLAGS に追加しておいた
922:918 ◆7qRx8xrwgo
07/09/17 12:36:56
>>920
仰るとおりに実行した所エラーが表示されることも無くコンパイルできました。感謝です。
923:デフォルトの名無しさん
07/09/17 12:41:51
皆さん、実際にC言語でどのようなソフトを書かれているんですか?
924:デフォルトの名無しさん
07/09/17 12:51:00
OS書いていますけど?
925:デフォルトの名無しさん
07/09/17 12:53:14
通信プロトコル。
OSIでデータリンクからセッションぐらいまで
926:デフォルトの名無しさん
07/09/17 12:55:28
どこにもしようしているおえすめいかいてない
あおえすをしいでかいてるのか
すごいなおまえ
927:デフォルトの名無しさん
07/09/17 13:01:33
C言語は学校の授業や課題でしか使わんな
普段使うのはVC++かJavaかC#
928:デフォルトの名無しさん
07/09/17 14:43:27
>>923
去年、一年くらい、10年くらい前に作られたシステムの保守要員やらされて、辟易した。
929:デフォルトの名無しさん
07/09/17 16:20:36
保守ってどんなことやるの?
930:デフォルトの名無しさん
07/09/17 16:40:25
>>929
お客さんとこのシステムの構成が変わったりなんか要望があったら、それにあわせてコードを書き換えたりとか。
新規のお客さんもあったけど、すでにあるコードから必要なコードをコピペして、ちょっといじって
もって行ったりとかするだけ。
931:デフォルトの名無しさん
07/09/17 16:45:13
ものすごくつまんなそうな仕事ですね
932:デフォルトの名無しさん
07/09/17 16:57:41
つまらないうえに、すごいつらかった。
基本的にソースコードぐちゃぐちゃだし。
933:デフォルトの名無しさん
07/09/17 17:06:15
今の現場、つまらないうえに、すごいつらい。
基本的にソースぐちゃぐちゃだし。
934:デフォルトの名無しさん
07/09/17 18:32:30
既存のファイルのファイルスコープにある変数や関数を使いたい、
っていうんじゃないんだろうから、迷ったら別ファイルでいいんじゃないでしょうか?
ファイルを分ける弊害って、なにかあるでしょうか?
935:934
07/09/17 18:35:31
リロードわすれてたっはっは~
936:デフォルトの名無しさん
07/09/17 21:35:29
>>933
でも、大事な仕事だよ。
今後はC言語でも保守の仕事が増えるんじゃないか!?
COBOLはすでにそうなっている。
しっかりとしたコーディング規約があって、その通りに作られていればいいんだが、
Cでの開発プロジェクトにはコーディング規約がないくて、各自各様のスタイルでコーディング
していることが多い。最近はそうでもないかもしれないけどね。
937:933
07/09/17 22:09:47
>>934は>>911に対するレス?
>>936
スタイル云々以前の問題でね、多分プログラミング自体の経験が無い人か、
少なくとも、スコープを分かってない人が書いたプログラムで、それが原因のバグとかもある。
おそらくテストもマトモにしてないと思われるよ。orz
>>911
で、「分ける分けない」て話は、スコープとも関わる話なのでスコープを理解すること。
関連性が強い物、似たような機能のものを集めるという分け方もある。
「モジュール強度 結合度 独立性」という言葉を調べると何かわかるかも。