[表示 : 全て 最新50 1-99 101- 201- 301- 401- 501- 601- 701- 801- 901- 2chのread.cgiへ]
Update time : 05/09 18:47 / Filesize : 239 KB / Number-of Response : 921
[このスレッドの書き込みを削除する]
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧] [類似スレッド一覧]


↑キャッシュ検索、類似スレ動作を修正しました、ご迷惑をお掛けしました

C統合・質問スレッド



1 名前:デフォルトの名無しさん mailto:sage [03/11/09 15:37]
いろんなスレが乱立していますが、統合的なスレッドがないので立てました。
質問もOK

関連スレ
C#って死滅する理由がないよね! Part4
pc2.2ch.net/test/read.cgi/tech/1042464104/
C#最強伝説
pc2.2ch.net/test/read.cgi/tech/1061208152/
C#とJava、どっちをおぼえればいいの?
pc2.2ch.net/test/read.cgi/tech/1006715468/
C#Builder Professional 質問箱
pc2.2ch.net/test/read.cgi/tech/1062433418/

関連リンク
dir.yahoo.co.jp/Computers_and_Internet/Software/Programming_Tools/Programming_Languages/C_Sharp/


357 名前:デフォルトの名無しさん [2005/04/03(日) 14:07:55 ]
配列同士の数値の比較をしたいのですが、下記のようだとうまくいきません。
どのようにすればよいのでしょうか?
for(i=0;i<5;i++)
for(j=0; j<5; j++)
if(group[i] == group[j] && i != j) count[i]++;

358 名前:デフォルトの名無しさん mailto:sage [2005/04/03(日) 15:10:03 ]
>>357
j = i

359 名前:デフォルトの名無しさん mailto:sage [2005/04/03(日) 15:22:36 ]
>>357
配列の同じインデックスを持つ要素同士を比較したいのであれば、単純な(一重の)ループでいい。
つーか、>357では日本語の説明が足りんし、コードがおかしいし、何がしたいのか判らんのだが。

360 名前:デフォルトの名無しさん mailto:sage [2005/04/04(月) 00:24:27 ]
すみません。初歩的な質問をさせていただきます。

char *func1(){
 return "a";
}

char *func2(){
 char *s = "a";
 return s;
}

こんな2つの関数があったとして、これらが関数の呼び出し元に返ってきた際に
戻り値のポインタが正しい場所を指し示すことはどこまで(いつまで)保障できるんでしょうか?
func1は保障できる、func2はできる、それとも両方できない/できる、どこまでなのか…等。
また、私の勉強不足のせいで、両者のメモリ上での違いがいまいちはっきりしてません。

一応どちらでも動作するにはするんですが、いつか不正な参照とかで
落ちちゃうんじゃないかと気になって怖くて夜も眠れません。

参考になるサイトを教えていただけるだけでも結構ですのでよろしくお願いします。

361 名前:デフォルトの名無しさん mailto:sage [2005/04/04(月) 01:05:29 ]
規格ではどうか忘れたけど、たいがいいけるはず。
どうしても心配ならstatic const char ret_str[] = "a";とかすれば?
あとchar *じゃなくてconst char *を使え。

362 名前:デフォルトの名無しさん mailto:sage [2005/04/04(月) 01:08:07 ]
>>360
定数(リテラル)の寿命はプログラムの開始から終了まで。
関数内で宣言されたauto変数の寿命は、関数の開始から終了まで。

char *func1(){
 return "a"; /* "a" を指すポインタを返している */
}
char *func2(){
 char *s = "a"; /* ポインタ s を "a" を指すポインタで初期化 */
 return s; /* ポインタ s の値、つまり "a" を指すポインタを返している */
}

つまり、どっちも同じ。
リテラルはいつでもどこからでも参照出来るので、戻り値を使ってても大丈夫。

363 名前:360 mailto:sage [2005/04/04(月) 02:05:28 ]
>>361-362
ありがとうございます!だいぶスッキリしました。
リテラルに関しては参照先が不正な値になるんじゃないかとかいう
心配は無用なわけですね。逆の場合(変数、関数のポインタ)は気をつけろと。

すみません。あとここからもう一段階お願いします。
実は言うと今、Unix系ソフトの移植作業をやってまして
こいつらと同等の動作をするものを作りました。

char *dirname(char *path);
char *basename(char *path);

basename()はパス名からディレクトリを除いた部分(ファイル名)を返せばいいので
引数のポインタをそのまま使い回してreturn path+pos;のようにして返してます。

dirname()の方は引数で与えられたパス名からファイル名を除いたものを返すものなので、
関数内でdir[MAX_PATH]のように宣言した配列に、引数の文字列からファイル名部分を
除いたものをstrncpyでコピーなどして、最後にdir(先頭アドレス)を戻り値にしてます。
(ちなみにさっきの質問は"."「カレントディレクトリ」を返す場合でした。)

長すぎるのでまとめると、
・basename()の戻り値は呼び出し先のローカル変数とは無関係である。
・dirname()の戻り値は呼び出し先のローカル変数に依存している。

この場合だと、dirで確保していたアドレスは戻り先で参照しても安全なのでしょうか?
ちゃんと動くし、自分でも大丈夫だと思ってたのに警告が出たので不安になりました。

やたら長くてすみません。何かこれより良い実装方法がもしあればご教授願います。

364 名前:360 mailto:sage [2005/04/04(月) 02:14:47 ]
何度もすみません。つまりさっき私が言ったdirname()の実装は

char *func2(){
 char *s = "a"; /* ポインタ s を "a" を指すポインタで初期化 */
 return s; /* ポインタ s の値、つまり "a" を指すポインタを返している */
}

この場合と同じと考えていいんでしょうか?ってことですね。
私の目には全く同じものに映るのですが、間違いありませんでしょうか。

365 名前:デフォルトの名無しさん [2005/04/04(月) 02:15:23 ]
floatがもてる最大値はどのように調べればよいのでしょうか?



366 名前:デフォルトの名無しさん mailto:sage [2005/04/04(月) 02:30:48 ]
>>363-364
const char *func3(void){
const char s[] = "a";
return s; /* ローカルな配列 s へのポインタを返す */
}

const char *p;
p = func(); /* 0, func() の s へのポインタを受け取る */
printf("%p\n", p); /* 1, これは構わない */
printf("%s\n", p); /* 2, これは駄目 */

0 は何ら構わない。戻ってきたアドレスをコピーしているだけ。
1 も何ら構わない。コピーしたアドレスを表示しているだけ。

2 は駄目。アドレスの先を参照してしまっているから。
何故参照してはいけなかというと、アドレスの先にある func3() の s の寿命は、
func3() を抜けた時点で既に尽きてしまっているから。

func2(), func3() は全然違う関数。

367 名前:デフォルトの名無しさん mailto:sage [2005/04/04(月) 02:35:17 ]
>>365
float.h にある FLT_MAX マクロで定義されてる。

#include <stdio.h>
#include <float.h>
int main(void)
{
 printf("%f\n", FLT_MAX);
 return 0;
}

368 名前:デフォルトの名無しさん mailto:sage [2005/04/04(月) 02:50:42 ]
>364
ダメ。変数の寿命について学んでください。

1.関数の引数を変える。
void dirname(char *dest,int dest_size,const char *path)

2.静的に保持する。使用に若干注意が加わる
static char dir[]

3.動的に確保する。呼び出し側に解放義務が発生する
char *dir = malloc()

369 名前:デフォルトの名無しさん [2005/04/04(月) 03:05:49 ]
>>367
thx
limit.hしか知らなかった

370 名前:360 mailto:sage [2005/04/04(月) 03:13:01 ]
そのまま貼っちゃいます。今はこんな状態です。

char* dirname(char* path)
{
  int pos = strlen(path)-1;
  int lastPathSepFoundPos = -1;
  static dir[MAX_PATH]="";
  while(pos >= 0) {
    if (path[pos] == '/' || path[pos] == '\\') {
      lastPathSepFoundPos = pos;
      break;
    }
    else pos--;
  }
  if (lastPathSepFoundPos == -1) return "."; // current dir
  else{
    strncpy(dir,path,lastPathSepFoundPos);
    dir[lastPathSepFoundPos] = 0;
    return dir;
  }
}

static dir[MAX_PATH]="";をchar dir[MAX_PATH]にすると
→警告「ローカル変数またはテンポラリのアドレスを返します」
となってました。今考えてみれば当然ですよね。。

>>368
どうもです。ちょうど昨日、その2を回避策としてやってみてたとこでした。
その注意というのは関数へのアクセスが同時に起こるような場合でしょうか?

条件コンパイル(#ifdef-#endif)等が面倒になりそうですが、
1の方法が一番簡単そうなので、その方向でやってみることにします。

371 名前:デフォルトの名無しさん mailto:sage [2005/04/04(月) 03:14:54 ]
↑static char dir[MAX_PATH]="";の間違いです。

372 名前:デフォルトの名無しさん mailto:sage [2005/04/04(月) 12:12:39 ]
strrchr 使えば簡単にみえるな・・・

373 名前:デフォルトの名無しさん mailto:sage [2005/04/04(月) 16:49:40 ]
すみません最近C++触ったばかしですみませんが

class auのコントラクタ関数
au(string s) : enr(s) {}について
文字列をsに代入し enrを生成する時にsを代入すると読めるのですが
なぜ au(string s) { enr(s); }とできないんですか?

個人的に関数内容 { }内 は動作命令のみの記述と解釈すれば
au(string s) { enr = s; }
はenr = s;という動作命令であるから適応であるが
{ enr(s); }・・・であるから不適と思ってしまうのですが・・

書いててよくわからなくなってきた・・
au (string s) : enr(s) {}について
なぜ : で区切るのかと enr(s)はなぜ{}内に記述してはいけないのかについて詳しくお願いします

374 名前:デフォルトの名無しさん mailto:sage [2005/04/04(月) 17:09:15 ]
>>373
:の後は初期化。{}の中だとメンバ変数への代入になってしまう。

例えば、
class foo {
const int bar;
foo() : bar(0) {}
};
とした場合、この例のように初期化はできるが、
class foo {
const int bar;
foo() {bar = 0;}
};
このような代入はできない。

375 名前:デフォルトの名無しさん mailto:sage [2005/04/04(月) 17:33:16 ]
>>374
全て解決できました。
どうもありがとです



376 名前:デフォルトの名無しさん mailto:sage [2005/04/19(火) 19:50:11 ]
共用体ってどういうときに使うんですか?
また利点とかあるんですか?

377 名前:デフォルトの名無しさん mailto:sage [2005/04/20(水) 00:05:37 ]
すみません。教えてください。
下記のようなプログラムを書くと、結果に必ず0.0が混ざってしまい、困っています。
乱数を3つ表示させたいのですが、0.0を含まないようにするにはどうしたらよいのでしょうか?

#include <stdio.h>
#include <stdlib.h>
#include<time.h>
#define N 3
int main(void)
{ int i,j=0,check;
double data[N],dia[N],tmp;
srand((unsigned)time(NULL));
printf("\n乱数のつもり:\n");
for (i=1; i<=N; i++)
{data[i]=rand()%100+(double)rand()/32768.0;}
/* 並替えの計算 */
for (i = 1; i < N - 1; i++)
for (j = i + 1; j < N; j++)
if (data[j] < data[i]) /* <: 昇順, >: 降順 */
{ tmp = data[i];
data[i] = data[j];
data[j] = tmp;};
for (i = 0; i < N; i++)
printf("%.1f ", data[i]); /*並替えデータの表示*/
}

378 名前:デフォルトの名無しさん [2005/04/20(水) 00:47:24 ]
>>376

それくらい調べろよ。

379 名前:デフォルトの名無しさん mailto:sage [2005/04/20(水) 01:25:42 ]
>>376
メモリの節約
同じメモリブロックを複数の型として解釈したい時

380 名前:デフォルトの名無しさん mailto:sage [2005/04/20(水) 11:52:18 ]
>>377
取り敢えず落ち着け。
深呼吸でもした後、data[] の添え字の範囲が
0〜N-1 だと言うことを思い出せ。

381 名前:デフォルトの名無しさん mailto:sage [2005/04/20(水) 13:25:48 ]
>>376
通信などで、整数型や実数型をバイト列と相互変換したい場合、
ポートアクセスなどでビットフィールドとバイト列を相互変換したい場合などに使う。
メリットは、他の方法に較べて簡便に書けること。
デメリットとしてよく言われる非互換性については、元々汎用的でないコードを書く場合には無視できる。
#勿論、それ相応のコメントは必要。

382 名前:デフォルトの名無しさん [2005/04/23(土) 00:09:57 ]
C、C++ある程度覚えるまで、どのくらい掛かった?今から、勉強しようと思うのですが、C→C++→C#か、Javaって感じに逝こうかと思うのですが、C++から移行した人、する人は、C#か、Javaどっち盗ります?←煮たスレあるけどノリで…ゴメソ

383 名前:デフォルトの名無しさん mailto:sage [2005/04/23(土) 00:19:39 ]
>>382
無意味なアンケートするな。

384 名前:デフォルトの名無しさん mailto:sage [2005/04/23(土) 10:31:57 ]
無意味っていいよね。
まぁ答えてやんなよ。発想の無い、IT土方プログラマーの行く末までを……ハァー 


385 名前:デフォルトの名無しさん mailto:sage [2005/04/23(土) 12:04:48 ]
なんでこう勉強する前にウダウダ人に聞くやつが多いんだろう



386 名前:デフォルトの名無しさん [2005/04/23(土) 12:20:20 ]
>何でこう勉強する前にウダウダ人にきく奴が、多いのだろう 
って、自分も聞いてるじゃんWWW プギャー、と云ってみたくなる。まあ、オイラは聞かなかった、お陰でプログラマーなんかになってしまった訳だが…ハァー

387 名前:デフォルトの名無しさん mailto:sage [2005/04/23(土) 12:23:43 ]
ageんなやボケがあああああ、と自分に云ってみるテst
すまんです

388 名前:デフォルトの名無しさん [2005/04/26(火) 11:13:11 ]
  ∧_∧
 ( ´∀`) < ぬるぽ

389 名前:デフォルトの名無しさん [2005/04/27(水) 10:54:11 ]
1+2+3+・・・+N を計算する関数を作成せよ。

390 名前:デフォルトの名無しさん mailto:sage [2005/04/27(水) 11:48:18 ]
>>389
int f(int N){return((1+N)*N/2);}

391 名前:デフォルトの名無しさん [2005/04/27(水) 11:57:21 ]
1/2/3/・・・/N を計算する関数を作成せよ。

392 名前:デフォルトの名無しさん mailto:sage [2005/04/27(水) 12:05:48 ]
>>391
int f(int N){return0;}

393 名前:デフォルトの名無しさん [2005/04/27(水) 12:45:24 ]
>>390
感動した
>>392
ワロタ

394 名前:デフォルトの名無しさん mailto:sage [2005/04/28(木) 04:36:53 ]
>>391
double f(int N){double x=1.0;if(N>1)while(N)x*=(double)N--;return 1.0/x;}

395 名前:394 mailto:sage [2005/04/28(木) 04:42:40 ]
あんま変わらんけど、こっちの方が良かったかな…?
double f(int N){double x;for(x=1.0;N>1;N--)x*=(double)N;return 1.0/x;}



396 名前:デフォルトの名無しさん [2005/05/04(水) 18:36:51 ]
ttp://ex10.2ch.net/test/read.cgi/news4vip/1115125763/18
↑exitするならfcloseもfreeもしなくていいんだけど
  ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄
ってあるんですが、そうなんですか?
ファイルディスクリプタはプログラム終了時に閉じられるとしても
メモリリークっすよねコレ

397 名前:デフォルトの名無しさん [2005/05/04(水) 19:00:23 ]
>>28
ガッ

398 名前:デフォルトの名無しさん mailto:sage [2005/05/04(水) 19:58:54 ]
>>396
大丈夫。真っ当なOSならアプリケーション終了時にきちんと開放する。

399 名前:デフォルトの名無しさん mailto:sage [2005/05/04(水) 20:06:09 ]
>真っ当なOSなら


400 名前:デフォルトの名無しさん mailto:sage [2005/05/04(水) 22:08:18 ]
OSが真っ当かどうかに関わらず真っ当な規格合致処理系なら、
exit()を呼んでいなくてもmain()からreturnすればファイルは閉じられる。
main()でのreturnはexit()の呼び出しと等価とも書かれている。(他の関数からmain()を呼んだ場合は別だが)

しかしfree()の方にはそのような記述は見当たらない。
(free()を呼ばないで終了するとどうなるかということは書いていない)

401 名前:デフォルトの名無しさん mailto:sage [2005/05/04(水) 22:14:15 ]
>>400
>(free()を呼ばないで終了するとどうなるかということは書いていない)

free() を読んで終了すればどうなるかということも書いていないけどな。


402 名前:デフォルトの名無しさん mailto:sage [2005/05/04(水) 22:23:14 ]
またこの話題か
好きにすれ

403 名前:デフォルトの名無しさん mailto:sage [2005/05/04(水) 22:31:48 ]
gotoを使うのは不味いのでしょうか?
どなたかおすえてください

404 名前:デフォルトの名無しさん mailto:sage [2005/05/04(水) 22:57:09 ]
Cで質問です。
変数nの値が??のとき、filename??という名前のファイルを開きたい
という場合に、fopenの第1引数にはどのように記述すればよいでしょうか?
先にsprintfを使えばできるようですが
直接引数の部分に記述して何とかする方法がないかと思いまして。

405 名前:デフォルトの名無しさん mailto:sage [2005/05/04(水) 23:19:00 ]
>>404
char *filename(int n) { static char buf[100]; sprintf(buf, "filename%d", n); return buf; }

fopen(filename(n), ... )





406 名前:デフォルトの名無しさん mailto:sage [2005/05/04(水) 23:26:43 ]
>>405
なるほど!その手がありましたか!
おめでとうございます!ありがとうございます!


(ノ´Д`)ノ 彡┻┻

407 名前:デフォルトの名無しさん mailto:sage [2005/05/05(木) 19:22:25 ]
次にこんなことをしてハマると見た。
rename( filename(1), filename(2) ); // filename.1 を filename.2 にバックアップ

408 名前:デフォルトの名無しさん mailto:sage [2005/05/05(木) 23:19:39 ]
>fopenの第1引数
そもそもパスとか編集しなくていいのか?

素直に
>先にsprintfを使え

409 名前:デフォルトの名無しさん mailto:sage [2005/05/05(木) 23:28:04 ]
そこでC++ですよ。
std::string filename(int n) {return "filename" + boost::lexcal_cast<std::string>(n);}

410 名前:デフォルトの名無しさん [2005/05/09(月) 09:50:14 ]
C言語をはじめたばかりであまりわからないのですが、
ビットシフトはなんの役に立つのでしょうか?

411 名前:デフォルトの名無しさん [2005/05/09(月) 09:51:19 ]
p6222ed.kyotac00.ap.so-net.ne.jp/

うはっwwwwwwwwwwwwwww

っうぇwwwwww
っうぇうぇwww
wおkwwwwうはっwww
おkwww

っwwwwww

うぇwww


412 名前:デフォルトの名無しさん [2005/05/09(月) 10:07:08 ]
ttp://EAOcf-526p83.ppp15.odn.ne.jp/
おkwwwwwwwwwwwwおkうぇおkwwwwww
うはっwwwwwwwwwwwwwwwwwwwwwwwwwwwww
うはっうはっwwwwwwwwwwwwwww
wwwwwwwwwwwwっっうぇうぇ
うはっ

413 名前:デフォルトの名無しさん [2005/05/09(月) 10:14:46 ]
pdf791d.tokynt01.ap.so-net.ne.jp/

wwwおkwwwwwwうぇwwwwwwwwwっうぇ

おkwwwっうぇうはっwwwwうぇwww

wっうぇうはっwwwwwwwwwwwwwwwwww

414 名前:デフォルトの名無しさん mailto:sage [2005/05/10(火) 16:35:01 ]
>>410
ビットシフトしたいときに役に立つ

415 名前:デフォルトの名無しさん mailto:sage [2005/05/10(火) 18:01:05 ]
あと、2進数の桁をずらしたいときにも役に立つね。



416 名前:デフォルトの名無しさん mailto:sage [2005/05/10(火) 18:29:55 ]
>>410
任意の上位Nビットを取り出したいとかその逆をしたいときとかに。
DWORD dw = 0x12345678;
WORD wHigh = dw >> 16; // 0x1234
WORD wLow = dw & 0xffff // 0x5678
DWORD dw2 = dw << 16 | wLow // 0x12345678


417 名前:デフォルトの名無しさん mailto:sage [2005/05/11(水) 18:16:54 ]
<質問>
ピクチャポックに表示した画像をマウスドラッグで範囲選択します。
その選択範囲をマウスのドラッグ中、リアルタイムに枠線で囲みたいのですが
どういう処理が一般的でしょうか?

DrawLineで線を書いたり消したりとかは、おかしいですよね?

418 名前:デフォルトの名無しさん mailto:sage [2005/05/11(水) 18:53:11 ]
>>417
>>1-10 を見ろ。
回答が欲しければ Windows 系のスレに行くんだな。

419 名前:デフォルトの名無しさん mailto:sage [2005/05/11(水) 20:15:27 ]
XOR

420 名前:417 mailto:sage [2005/05/11(水) 23:15:27 ]
すまそん。
他で聞いてきます・・・。(・・`)

421 名前:417 mailto:sage [2005/05/12(木) 00:23:25 ]
>419
もしかして、私へのヒント?
そうだったら、ありがとうございます。

ビット反転させたらいいのかなー。
とりあえず、C#の過去ログ見てます。


422 名前:デフォルトの名無しさん mailto:sage [2005/05/12(木) 10:11:02 ]
int main(void)
{
double i;

for(i=1.0; (int)i<=9; i=i+0.1) {
printf("%d", (int)i);
printf("%lf ", i);
}

return 0;
}
iが5.000000のとき(int)iがなぜ4になるのか分かりません。
小数部を切り捨てて5になると思うのですが。

423 名前:デフォルトの名無しさん mailto:sage [2005/05/12(木) 11:35:49 ]
>>422
誤差の累積。誤差について調べられたし。

424 名前:デフォルトの名無しさん mailto:sage [2005/05/13(金) 16:14:34 ]
>>417
まさしくそれ向けの関数がMFCにあった気がする。

425 名前:デフォルトの名無しさん mailto:sage [2005/05/13(金) 16:21:49 ]
MFCつーか、、、APIであるけど
今はもうXORの時代じゃないのかもなあ



426 名前:デフォルトの名無しさん mailto:sage [2005/05/13(金) 16:26:18 ]
いちおー書いておくか
APIなら
DrawForcusRect
MFCだと
CDC::DrawForcusRect

それよりも、CRectTracker クラス使ったほうがいいかも

427 名前:426 mailto:sage [2005/05/13(金) 16:39:17 ]
ってここC#のスレだった・・・
スレタイで半角#使ったのか・・・

428 名前:デフォルトの名無しさん mailto:sage [2005/05/14(土) 07:08:29 ]
>>427
気にするな
ごみスレだ

429 名前:デフォルトの名無しさん mailto:sage [2005/06/28(火) 09:16:29 ]
LSI C-86でコンパイルしてるんですが
unknown dimensionっていうエラーは
どんな間違いをしてる可能性があるんですか?

430 名前:デフォルトの名無しさん mailto:sage [2005/06/28(火) 09:45:41 ]
>>429
>どんな間違いをしてる
コンパイラの選択。

まぁ、恐らくは二重以上の配列で、要素数の指定が漏れているんだろうけど。
int func(int a[][]);
とかね。

431 名前:デフォルトの名無しさん mailto:sage [2005/06/28(火) 10:21:35 ]
二次元と表現せずに二重と表現するのが
Cらしいなw

432 名前:デフォルトの名無しさん mailto:sage [2005/07/05(火) 16:40:43 ]
クラス継承で教えて
class AandB : public A , public B
{

}
というのを作ろうとしたら
Aのメンバー関数で
A::data()

Bのメンバー変数で
char * B;;data
と名前が衝突していた.

B::dataのみにアクセスするにはどうすればいいの?

433 名前:デフォルトの名無しさん mailto:sage [2005/07/05(火) 17:26:48 ]
>>432
B::dataでダメなら、using

434 名前:デフォルトの名無しさん mailto:sage [2005/07/05(火) 21:16:22 ]
うまくいった
class AandB : public A , public B
{
AandB(){
this -> B::data
}
}
でアクセスできた

もうひとつ疑問が
class AandB : public A , public B
{
class B *pB;
AandB(): pB(&B)
{
}
}
pBにポインターの値を代入したいんだけどできない

435 名前:デフォルトの名無しさん mailto:sage [2005/07/05(火) 22:17:22 ]
>>434
class AandB : public A , public B
{
  class B *pB;
  AandB(): pB(static_cast<B *>(this))
  {
  }
};
キャストは要らないが一応書いておいた。



436 名前:デフォルトの名無しさん [2005/07/10(日) 11:50:07 ]
namespace your {
  struct girlfriend {
    void lips();
  };
}

namespace my {
  struct girlfriend {
    static void lips();
  };
  class wife : your::girlfriend {
  public:
    void kiss() { girlfriend::lips(); }
  };
}

さて、wife::kiss() するとgirlfriend::lips()によって
奪われるのは基底クラスの your::girlfriend::lips() か、
はたまた同じnamespaceにある my::girlfriend::lips() なのか?

VC7, gcc3.1 では基底クラス your:girlfriend::lips() で、
BCC564では 名前空間を優先して my::girlfriend::lips() でした。

どっちがせーかいでしょう? 
雰囲気からして基底クラスを採るのがスジっぽいけど。 


437 名前:デフォルトの名無しさん [2005/07/10(日) 14:17:24 ]
みなさん、コンパイラなどする時はコマンドプロントからやっていますか?
それとも編集もまとめて出来るフリーツールなど使ってらっしゃいますか?

まだプログラミング始めたばかりなんですが、コマンドプロントの方法もやはり覚えといた方がいいんですかね?

438 名前:デフォルトの名無しさん mailto:sage [2005/07/10(日) 14:31:47 ]
プログラムを学習する目的が限定されていて、コマンドプロンプトを使わなくて済むなら、
覚える必要はない。
授業でどうしてもやらなきゃいけないとか。

プログラミング全般に詳しくなりたいなら、覚えておいた方がいい。


439 名前:デフォルトの名無しさん [2005/07/10(日) 19:03:07 ]
学習目的でプログラムを組む際、教科書によってはコマンドプロンプトを前提としているものがある。
だから、教科書しだいかな。
個人的には、ツールを組み合わせることが楽なので、覚えるといいとおもう。

440 名前:デフォルトの名無しさん mailto:sage [2005/07/10(日) 20:20:05 ]
簡単な、初級プログラムというのはどうしても、コマンドラインを使った処理、
入出力になるからな。憶えるべきというか、憶えないと学習効率が悪いと思うぞ。
世の中に出ている初級者用のC言語情報なんて、ほとんどがコマンドラインを
前提としているからな。

441 名前:デフォルトの名無しさん mailto:sage [2005/07/10(日) 22:20:27 ]
やはりそうですか
分かりました、ありがとうございました。

442 名前:デフォルトの名無しさん mailto:sage [2005/07/11(月) 23:02:56 ]
IDEかmakeかって話だろ。
そんなの当面どうだっていいだろ。

443 名前:デフォルトの名無しさん mailto:sage [2005/07/16(土) 19:15:31 ]
質問
int a = 1;
if ( a == (int)0) {
...
}
のように、キャストした方がいいの?

444 名前:デフォルトの名無しさん mailto:sage [2005/07/16(土) 21:53:36 ]
いらない

445 名前:デフォルトの名無しさん mailto:sage [2005/07/16(土) 22:06:14 ]
>>443
ただの整数は元からint型。



446 名前:デフォルトの名無しさん mailto:sage [2005/07/20(水) 17:02:19 ]
この速度ならぬるぽ

447 名前:デフォルトの名無しさん [2005/08/09(火) 01:41:05 ]
Cを使った開発で質問させて頂きたいのですが

ありがちなDBを使った業務システムを開発するときに
MFCと.netフレームワークを比べると
どちらの開発効率が上でしょうか。

漠然とした質問ですが
主観等々で構いませんので、ご意見いただけますでしょうか。

448 名前:デフォルトの名無しさん mailto:sage [2005/08/09(火) 01:59:47 ]
MFCも.netもCじゃなくC++だが。

449 名前:デフォルトの名無しさん mailto:sage [2005/08/09(火) 02:00:46 ]
ありがちなDBを使った業務システムは開発効率より優先する
ものがあるんでねぇ?
oo4o+vbに1票

450 名前:デフォルトの名無しさん mailto:sage [2005/08/09(火) 09:50:43 ]
スレ違いだったらすみません。
自分用にデバグしやすいmalloc/realloc/freeを実装してみようと
思っていますが何を参考にすればいいかわかりません。
シンプルで小さい実装のソースがあったらURLを教えて下さい。


451 名前:デフォルトの名無しさん mailto:sage [2005/08/09(火) 11:50:46 ]
void *my_malloc(size_t size) {
  void *p = malloc(size);
  ...hoge
  ...fuga
  return p;
}
みたいのじゃだめなのか。
メモリアロケーションを実装するのは大変だと思うが。

452 名前:デフォルトの名無しさん mailto:sage [2005/08/09(火) 13:21:22 ]
#define malloc my_malloc

453 名前:デフォルトの名無しさん mailto:sage [2005/08/09(火) 14:20:45 ]
すみません、質問が悪かったですね。
端的に、mmap を実装してみたいんです。
ある組込の環境で、malloc がかなり遅い
環境があるんですが、自分で実装してみたら
それを速くできるのか、それとも自分だともっと
遅くなってしまうのか、興味があったのです。



454 名前:デフォルトの名無しさん mailto:sage [2005/08/09(火) 16:08:50 ]
mmapの実装って環境依存じゃないだろうか。ソースならunix系オープンソースosのを
見ればいいだろうけど、参考にはならないような。それはそのままハードorOSの性能
くさいし。欲しいのは多分メモリプールだろうからやるとしてもmallocをラップして
プールするのがいいんじゃないかと。
おもろい文章
www-6.ibm.com/jp/developerworks/linux/041217/j_l-memory.html

455 名前:デフォルトの名無しさん mailto:sage [2005/08/09(火) 19:51:06 ]
>>453
www.uclibc.org/
あたりの実装は参考になるんじゃないかな。 MMUあり、無しの両方に対応する実装がある。




456 名前:デフォルトの名無しさん mailto:sage [2005/08/15(月) 12:17:32 ]
あるファイルが存在するかどうかを確認するにはどうしたらよいのでしょうか?
出来るだけ環境に依存しない方法がよいのですが

457 名前:デフォルトの名無しさん mailto:sage [2005/08/15(月) 13:06:53 ]
>>456
環境依存しないと言うことなら、存在する≒読めるということで
fopen(targetFile, "r")が成功するかどうかで判断するのが無難。

まぁ、大抵の環境でaccess()かstat()はあると思うがな。
#某環境では、access()がfopen()で実装されているのは内緒。






[ 続きを読む ] / [ 携帯版 ]

前100 次100 最新50 [ このスレをブックマーク! 携帯に送る ] 2chのread.cgiへ
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧]( ´∀`)<239KB

read.cgi ver5.27 [feat.BBS2 +1.6] / e.0.2 (02/09/03) / eucaly.net products.
担当:undef