const char* const kickYourAss( const string& str ) const
みたいな関数にアクセスしたくない。
そうだね
言われなくても削除依頼くらいだせ
今日はウンコスレが乱立するね。
今日は暑いからしょうがないね。
5 :
デフォルトの名無しさん:04/07/07 18:34
>>1 甘いよ。
const string& const kickYourAss( const string& src, const string& dst = string()) const
throw()
{
〜略〜
return dst;
}
いや、ここはクラスのメソッドを厳密にconstでもって定義している奴が自慢し、そしてオレが彼を称えるスレであって、3杯飯を食うスレではない。
virtual const string& const kickYourAss( const string& src, const string& dst = string()) const = 0
純粋仮想関数の"=0"ってどういうセンス?
っていうクソスレも立てたかったんだけどね。
#define PURE =0
でいいだろとか言われて、だったら言語仕様としてなんで"pure"としなかったんだ?
という反論に、「確かにそうだ」という皆の見解一致で終わりそうだったのでやめたんだから感謝しる。
このスレ的にはWinMain逝ってよしだね
const int WINAPI WinMain(const HINSTRANCE hInst, const HINSTRANCE hPrevInst, const LPSTR lpszCmdLine, const int nCmdShow)
まではできるけどLPSTRをLPCSTRにはできない(windows.hの中でWinMainのプロトタイプがあるから)
なんでmain最高
const int main(const int iArgc, const char *const *const ppszArgv)
>>9 >LPSTRをLPCSTRにはできない
ブー、出来ます
>>10 本当だ。拡張子をcからcppにしたら動いた。
と思ったらただのオーバーロードじゃねーか、リンクできねーぞヽ(`Д´)ノ
windows.hをインクルードしなければ……。(フフフ
extern "C"つけねーとダメだぞ
>>15 つけたら、オーバーロード関数群の中の 1 つだけしか "C" にできないって言われる。
そしてこれも無理。
#undef __cplusplus
#include<windows.h>
どうしてもやるんだったら、こんなこと考えてないでwinuser.hの中のプロトタイプを書き換えればいいんだろうけど。
LP??? っていうマクロうざくね?Win16時代の汚物だよな。
オレ死んでも使わない。ポインタは*がついてなければポインタじゃない。
こういうマクロは使うけどね。
typedef vector< hogetype* > Hogepo_vec;
typedefはマクロと違う
19 :
デフォルトの名無しさん:04/07/10 18:32
20 :
デフォルトの名無しさん:04/07/10 18:34
なぜLPFLOATがないんだぁっ
LP○○を使うのが好きなのにぃっ
ときどきLPしかないやつがあって統一できないのが鬱
LPSTRがchar*なのはおかしい、char=STRか?
LPSTRならchar**だ。
>>20 あるじゃないか。
って危うく言うところだった。俺のK2Editorでは間違えて強調表示されるようになっていたもんで。
>>23 16ビット時代にはサイズが16ビットのnearポインタとサイズが32ビットのfarポインタがあって、
nearポインタがただのP、farポインタがLPって区別していたんだよ。LはLongのL。
WinMainのLPSTRはホントに書き換わる可能性があるから
LPCSTRにしたらだめだって聞いたことがあるんだが。
CreateProcessに渡す引数のほうだったかな
29 :
デフォルトの名無しさん:04/11/10 11:15:59
override
30 :
デフォルトの名無しさん:04/11/10 18:00:52
WinExec
とか
ShellExecute
とか種類多杉。
CreateProcess
引数多杉。
さらにセキュリティからExeからExeを起動するような時代は終わった。
とりあえずはSEだろ
>>1 厳格と厳密を履き違えんなよ。
しかもコピーが返される戻り値をconst指定しても意味ないし。
>>33 厳格と厳密ってどう違うの?
いや、言葉の意味じゃなくてさ。
言葉の意味以外に何が違うってんだ?
文字が違うとか言って欲しいのか?
たていすかんなにらせ
hoge
Private Function StripTabs (ByVal MyStr)
Do While InStr(MyStr, vbTab) <> 0
MyStr = Right(MyStr, Len(MyStr) - InStr(MyStr, vbTab))
Loop
StripTabs = Trim(MyStr)
End Function
Private Function StripCmnt (ByVal MyStr)
s = 1
while s <> 0
s = InStr(MyStr,"/*")
if s <> 0 Then
e = InStr(MyStr,"*/") '見つかると仮定
MyStr = Left(MyStr,s-1) + Right(MyStr, Len(MyStr) - e - 1)
MsgBox MyStr
end if
wend
StripCmnt = MyStr
End Function
Sub unko()
TAB2 = vbTab + vbTab
ActiveDocument.Selection.SelectLine
Header = ActiveDocument.Selection
Header = StripCmnt(Header)
'Check if a there is a selection"
If InStr(Header, "") = 0 Then
exit Sub
End If
Header = StripTabs(Trim(Header))
'Get the function return type.
Reti = InStr(Header, " ")
Loc = InStr(Header, "(")
if Reti < Loc Then
RetTp = Left(Header, Reti)
Header = Right(Header, Len(Header) - Reti)
End If
'Get the function name.
Loc = InStr(Header, "(") - 1
Loc2 = InStr(Header, ")")
if Loc > 0 And Loc2 > 0 then 'make sure there is a '(' and a ')'
fcName = Left(Header, Loc)
Header = Right(Header, Len(Header) - Len(fcName))
'Do we have storage type on the return type?
Trim (fcName)
If InStr(fcName," ") <> 0 Then
retTp = retTp + Left(fcName,InStr (fcName," "))
fcName = Right(fcName, Len(fcName) - InStr(fcName," "))
End If
'Get the function parameters.
iPrm = 0
iPrmA = 0
prms = Header
'Count the number of parameters.
Do While InStr(prms, ",") <> 0
iPrm = iPrm + 1
prms = Right(prms, Len(prms) - InStr(prms, ","))
Loop
'Store the parameter list in the array.
If iPrm > 0 Then ' If multiple params.
iPrm = iPrm + 1
iPrmA = iPrm
Redim ParamArr(iPrm)
Do While InStr(header, ",") <> 0
ParamArr(iPrm) = Left(Header, InStr (Header, ",") - 1)
'Remove brace from first parameter.
If InStr(ParamArr(iPrm), " (") <> 0 Then
ParamArr(iPrm) = Right(ParamArr(iPrm), _
Len(ParamArr(iPrm))-InStr(ParamArr(iPrm)," ("))
Trim(ParamArr(iPrm))
End If
Header = Right(Header, Len(Header) - InStr(Header,","))
iPrm = iPrm - 1
Loop
ParamArr(iPrm) = Header
'Remove trailing brace from last parameter.
If InStr(ParamArr(iPrm), ")") <> 0 Then
ParamArr(iPrm) = Left(ParamArr(iPrm), _
InStr(ParamArr(iPrm), ")") - 1)
InStr(ParamArr(iPrm), ")") - 1)
Trim(ParamArr(iPrm))
End If
Else 'Possibly one param.
Redim ParamArr(1)
Header = Right(Header, Len(Header) - 1) ' Strip the first brace.
Trim(Header)
ParamArr(1) = StripTabs(Header)
If InStr(ParamArr(1), ")") <> 1 Then
ParamArr(1) = Left(ParamArr(1), InStr(ParamArr(1), ")") - 1)
Trim(ParamArr(1))
iPrmA = 1
End If
End If
'set the cursor one line above the selected text.
ActiveDocument.Selection.LineUp
ActiveDocument.Selection = vbLf
Descr = Offset + "/**" + vbLf + " *" + vbTab + "@brief" + TAB2 + vbLf + " *" + vbLf
'Print the parameter list.
Last = iPrmA
Do While iPrmA <> 0
'Remove a line feed from any of the arguments.
If InStr(ParamArr(iPrmA), vbLf) <> 0 Then
ParamArr(iPrmA) = Right(ParamArr(iPrmA), _
(Len(ParamArr(iPrmA)) - _
InStr(ParamArr(iPrmA), vbLf)))
Trim(ParamArr(iPrmA))
End If
ParamArr(iPrmA) = StripTabs(ParamArr(iPrmA))
'If there are 2+ parameters, the first parameter will
'have a '(' prepended to it, remove it here:
if iPrmA = Last AND Last <> 1 then
ParamArr(iPrmA) = Right(ParamArr(iPrmA), Len(ParamArr(iPrmA)) - 1)
End If
idx = InStrRev( ParamArr(iPrmA), " ", -1, 1)
if 0 <> idx Then
ParamArr(iPrmA) = Mid( ParamArr(iPrmA), idx+1)
End If
Descr = Descr + " *" + vbTab + "@param" + TAB2 + ParamArr(iPrmA) + vbLf
iPrmA = iPrmA - 1
Loop
idx = InStr( RetTp, " ")
if 0 <> idx Then
RetTp = Left( RetTp, idx)
End If
RetTp = Trim(RetTp)
if RetTp <> "void" then
Descr = Descr + " *" + vbTab + "@return"+ TAB2 + RetTp + vbLf
end if
ActiveDocument.Selection = Descr + "*/"
End If
End Sub
44 :
デフォルトの名無しさん:2005/03/25(金) 09:16:57
C++でvolatileを厳密に使っている奴=神
45 :
デフォルトの名無しさん:2005/03/25(金) 11:02:43
throw(hoge1, hoge2) とか、きっちり指定している奴は神
変数宣言にいちいち auto 書いている人は?
クソ
なんだと
auto かいてんの?
50 :
デフォルトの名無しさん:2005/03/26(土) 06:57:13
auroかわいいよauto
51 :
デフォルトの名無しさん:2005/03/26(土) 08:36:13
アウト!
52 :
デフォルトの名無しさん:2005/03/26(土) 08:36:42
アウト
嘔吐はもれの魂。
絶対にゆずれねー。
それなら俺はテンプレートクラスのメンバ関数すべてに inline を付ける事にしよう。
俺はスタンフォーダー、
スタンフォード大学のフレッシュマンだ。
みんなよろしくな。
なんで暗黙でその効果が得られる指定子とconstを同列に扱っているんだー!
registerは無視?
volatile int n;
volatile int *vp = &n;
int *p = const_cast<int *>(vp)
const = 紺色ストッキング
61 :
デフォルトの名無しさん:2005/07/25(月) 09:15:12
Java、C#、D、みんなconstな参照・constメンバ関数がないなんて糞だ。
まあ確かに困るよな。なんでないんだろう?
BOOL IS_SJIS_LEAD(char c) {
int i = 0xff & c;
if ( ((0x81 <= i) && (i <= 0x9F)) ) {
return TRUE;
}
if ( ((0xE0 <= i) && (i <= 0xEF)) ) {
return TRUE;
}
return FALSE;
}
BOOL MyReplace(CString& str) {
char *c = str.GetBuffer(str.GetLength());
char *p = c;
while (*p) {
if (!IS_SJIS_LEAD(*p)) {
p++;
continue;
}
if ( (0xff & *p) == 0x81 && (0xff & *(p+1)) == 0x40) {
*p = 0x20;
*(p+1) = 0x20;
}
p += 2;
}
return TRUE;
}