1 :
デフォルトの名無しさん :
2007/06/12(火) 19:59:25 スレ立てるまでもない、Win32APIのついての質問はこちらへどうぞ。
やさしいお兄さんやお姉さんたちが答えてくれるかも。
過去スレ、関連リンクは
>>2-5 くらい。
■注意
・質問する前にMSDNライブラリやPlatformSDK、Google等で検索しましょう。
・日本語版MSDN Online Libraryは不完全です。英語版(
http://msdn.microsoft.com/library/ )の利用推奨。
・APIフックなど高度な事をしたい場合はできるだけAdvenced Windowsを読みましょう。
・言語特有の問題やIDE、MFCやVCLなどの質問はそれぞれの言語や開発環境スレで
2 :
デフォルトの名無しさん :2007/06/12(火) 20:00:44
俺乙
華麗なスレ建て乙華麗
win32apiの関数だけで2Dのゲームを作るのとdirectXを使ってwindowタイプの2Dのゲームを作るのとではやはりdirectXの方が描画が明らかに早いですか
でもまあたいがいはDirectXのが早い
Vistaもあるし,D3Dで書いた方がいいんでね?
"12345678" ==> 0x12345678 に変換するWin32APIがあったら教えてください
"0x123" -> 0x123 shlwapi.lib StrToIntEx()
sscanfじゃいかんの?
スレ違いです
>>14 の質問の意図は「数字を数値化する方法」じゃなくて
「数字を数値化するAPIをおれによこせ おれはかみになるんだ」ってことだしな
>>14 文字列を数値に変換したいけど
CRT使いたくないからAPI教えてって事なら
>>15 10進数の文字列を値の違う16進数の数値に変換って事なら
答えは、ない
0x12345678 = 305419896 だから
"12345678" -> 12345678 -> 305419896 か
"12345678" -> "0x12345678" -> 0x12345678
この処理が必要になる
20 :
デフォルトの名無しさん :2007/06/13(水) 09:13:22
このwpeproみたく、socketの盗み見、編集をするためのAPIの名前のヒントをください。
dllのinjectionで割り込むのがスジでしょうか。
http://wpepro.net/
21 :
20 :2007/06/13(水) 09:30:41
>>14 はstrtol()を知らないだけなんじゃないかと思う
24 :
20 :2007/06/13(水) 09:48:23
参照はioctlsocketにSIO_RCVALLでできるのまでわかっています。 でも、これだと編集はできないです。
25 :
20 :2007/06/13(水) 09:52:25
>>23 ありがとう、過去ログ呼んで、聞いてみます。
WPARAM とか LPARAM の 頭文字、W Lは何の略なのでしょうか? あとlpsCmdLineのlps LR_DEFAULTSIZEのLR nCmdShowのnが 何なのか 気になっております。
WとLは、WORDとLONG、昔はWORD型とLONG型だった LRは知らない nは駆逐されつつあるシステムハンガリアンでint型を表す接頭辞
何で駆逐されつつあるんでしょうか?
LPARAM Long長のパラメータ(旧)。今はLONG_PTR長のパラメータのこと。 #if defined(_WIN64) typedef __int64 LONG_PTR; #else typedef long LONG_PTR; #endif WPARAM WORD長のパラメータ(旧)。今はUINT_PTR長のパラメータのこと。 #if defined(_WIN64) typedef unsigned __int64 UINT_PTR; #else typedef unsigned int UINT_PTR; #endif LR_DEFAULTSIZEのLRはLoad Resourceの頭だと思われ。 nCmdShowのnは符号付整数として、Numericのnかな?←自信ない
33 :
26 :2007/06/13(水) 21:38:21
ありがとうございます。 lpsCmdLineは分かりませんか? LongPointerでしょうか… でもsがそれだと変だしなぁ...
なんなんだ、このやり取りは? アホくさ
LPSTR lpsCmdLineでしょ
うはw Excel、Word作ったヤツが、ハンガリアン記法はじめたんかいな
lpszじゃないのか? 16ビットのころのfarポインタのASCIZ文字列だったけな
long pointer string zero terminated ってかこれAPIってよりC言語のお話じゃないの?
まあAPIそのものがCだったからな。CDECLじゃなくてPASCALだったけど
ちなみにlpszプリフィックスは Large Pointer to String terminated by Zeroの略称で、終端にNULLを置くようですね。
>>22 知らないで自前で作っちゃったよ・・・orz
43 :
デフォルトの名無しさん :2007/06/15(金) 09:50:58
最高にわろた
>>41 なるほど。
元々のハンガリアン記法は常識的なものだったんだな。
>>41 なるほど。
元々のハンガリアン記法は常識的なものだったんだな。
46 :
デフォルトの名無しさん :2007/06/15(金) 18:18:43
一行文字入力ダイアログボックスってどうやって出すの?
>>46 意味がわからん。例えばどれのことだ?
普通にダイアログ作って1行入力して受け取るんじゃダメなのか。
MessageBoxの逆みたいのないんですか? if(InputBox(handle, text, caption, buf, sizeof(buf))) printf("%s\n", buf); みたいに使えるようなの。
作ってみ。そんな手間じゃないぞ。
ハンガリアン記法か・・・。 他のスレにも書いたネタで恐縮だが、 typedef int HEIGHT ; typedef int WEIGHT ; HEIGHT h = 170 ; WEIGHT w = h ; これがコンパイラによってハネられないために、生まれたものだと思う。 C/C++のtypedefは、 新しく型を定義するのではなく、既存の型に別名を付ける という代物で、 なんでtypealiasじゃないんだよ! という困ったチャン。 構造体やクラスでラップすれば、型が違うのでダメよとハネてくれるんだけど、なんだかなぁ。
Delphi とか、C++ Builder にはあるな>InputBox
フルパスから拡張子を除いたファイル名取得するAPIってないですか? 今はPathFindFileName()→PathRemoveExtension()でやってるんですけど
>>52 パスだけ、ファイル名だけ、の2つを
つなげればいい。APIはなんだっけか
>>42 最近のヤツはマルチスレッドで利用してもたいてい問題無いようにはなってるけど、
C++の規格としてそれが保障されてるわけじゃないから自作モノにも意味があるよ。
また妄想で適当なことをほざく馬鹿が湧く。 もう春はとっくに終わったぞ。
夏の方が長い
文字列変換関数なんて普通に作ったらリエントラントだろ マルチスレッドがどうとか意味不明すぎる
>>55-57 知ったかぶった馬鹿どもがこんなにいるとは思わんかった。
>>58 負け犬の独り言はチラシの裏にでも書いておけ。
strtok はスレッドセーフじゃないな。明らかに。
62 :
54 :2007/06/16(土) 01:10:51
>>60 /\___/ヽ
/'''''' '''''':::::::\
.| (◯), 、(◯)、.::|:
.| " ,,ノ(、_, )ヽ、,,"".:::|:
.| ´,rェェェ、` .:::::::::|:
-\ |,r-r-| .:::::/…
ヾ`ニニ´ / ̄"''''ヽ:
僕ハッカー
Win32APIに64bitなGetTickCountってないの?
ない
何も考えずに対策無しに実装したらって話だろ
69 :
54 :2007/06/16(土) 12:45:02
自己解決しました。
>>60 にカチンときたので、コンパがあっても教えません。
バーカ!
解決も何も、元々質問じゃねーだろ 騙るならもうちょっとスレ読んでからなw
>>65 長い時間をはかるのに使うような代物じゃない。
オーバーフロー対策は、
DWORD dwElapsed ;
if (dwStart <= dwEnd) {
dwElapsed = dwEnd - dwStart ;
} else {
dwElapsed = dwStart - dwEnd ;
}
これでいいんじゃない?
START=DWORD_MAX-10で、 END=20のとき、 ELAPSEDは、DWORD_MAX-30になるのか? 何も考えずに、 DWORD dwElapesed = dwEnd - dwStart; でいいんじゃないのか?
以前"ファイルハンドルを開きっぱなしでそのファイルを削除しようとすると、 「ファイルまたはフォルダの削除エラー」がでます。 " ということを質問させてもらいました。 削除に関しては、CreateFileにFILE_SHARE_DELETEのフラグをつけることで エラーが出なくなり解決しましたが、 リネーム時に「ファイルまたはフォルダの変更エラー」が 出てしまいます。 今はFILE_SHARE_READ,FILE_SHARE_WRITE,FILE_SHARE_DELETEのフラグを 立てています。 ファイルハンドルを開きっぱなしのファイルがリネームされるときに エラーにならなくなる方法がありましたら教えてください。 またファイルがリネームされるタイミングを知ることができれば、 ファイルハンドルを解放できますが、そういう方法もありますか?
CreateEventとかCriticalSection
その代わりスレッドWaitForSingleObject
普通にCreateFileでハンドル閉じる前にリネームできるけどな またどうせ変なことでもやってんじゃないの?
オレも変だなあと思ってリネームしてみたけどエラー出なかった
>>74 根本的に何か変な雰囲気を感じる。
まず、「」でくくられたエラーメッセージが、
GetLastError()の返す値をFormatMessage()したものとは違うっぽい。
次に、
対症療法的に目先のことばっかり考えていて、
もっと基本的な部分を見落としているような気配がする。
そして、
ファイルを開いていても、ファイル名を変更することはできるのだけど、
それができないと言ってるあたりに、何か重大なことを隠している予感がする。
80 :
74 :2007/06/16(土) 17:20:10
すいません。原因がわかりました。 CreateFileしているファイルはログをCSV形式で出力するもので、 あるバイナリエディタでも開いており、それが悪さをしていたようです。 つまらない原因で申し訳ありません。 > まず、「」でくくられたエラーメッセージが、 > GetLastError()の返す値をFormatMessage()したものとは違うっぽい。 エラー時のダイアログのタイトル部分です。
>エラー時のダイアログのタイトル部分 こんなのを手がかりにするべきではない やるならFormatMessageなりエラー値なり、 ちゃんとAPIのドキュメント読んで、エラーコード等を取得すべきだし、 それを手がかりにして検索なり質問なりすべき
プログラム側のエラーじゃなくて、リネームをエクスプローラかなんかでやって出た エラーだったんだろう。
文字列変換をANSIからTCHARに変換するAPIってないのですか? プロジェクトの文字セットがunicodeなら、MultiByteToWideCharして マルチバイトなら無変換
const char str[] = "ほげほげ"; TCHAR buf[sizeof str]; _stprintf(buf, "%hs", str); というのはどうだろう。 ロケール指定は必要になると思うが。
よく意味のわからない質問に答えられるな
C++でATLを使ってよければATL::CA2Tとか楽
#ifdef UNICODE できればいいんじゃね?
APIにはない inline とか#ifdef つかって手前で作れって話かと
皆さん、有難うございます。83です。無いのですか、orz
TEXT(" ")マクロのAPI版を期待しんだすが...
>>84 と
>>87 の方法を検討したいとおもいます。
>>86 ATLは使ったことがありません。
>TEXT(" ")マクロのAPI版を期待しんだすが...
なぜ
>>83 でそう書かないのか理解に苦しむ
>>80 > エラー時のダイアログのタイトル部分です。
そのダイアログは誰が出したもの?
>>82 の予想通りっぽいけどさ。
変な雰囲気を感じたのは、
主語的なものが抜けていたからだったんだな。
>>83 Win32APIには、TCHARやLPTSTRやLPCTSTRを受け渡しするものは、ない!
(いや、例外的に何かあったような気もする・・・)
そんなものを渡されても、判別、つかないっしょ。
>>84 オーバーヘッドが問題にならないなら、
それはいいアイデアだ。
_stprintf(buf, _T("%hs"), str);
にすれば使えるね。
93 :
デフォルトの名無しさん :2007/06/16(土) 22:50:41
【派遣ネガティブ根性チェック】 3つ以上、チェックがつけばアナタの性格はひん曲がっており、 ネガティブ負け組派遣人生を歩んでいます。 □派遣先正社員の作った糞開発ツールはたとえバグだらけでも苦労して使うべきだ □派遣先の人事権のある社員の意見はたとえ間違っていてもマンセーする □昼食は必ず派遣先の社員と行くべきだ □派遣先から「いつまでもここで仕事してくださいね(安い金でw)」と言われて嬉しい □自社で仕事なんてできるわけがない □派遣労働の問題点の話題が出ると感情剥き出しにして反論する □派遣労働の問題を指摘する人は嫌いだ □派遣先には仕事だけでなくプライベートについてもグイグイ引っ張って欲しい □奢ってくれる派遣先正社員を尊敬する □自分の月額金額を知らないのは当然だ、単金を聞いてはいけない □派遣先正社員より自分の生涯収入が低いのは当然だ □派遣先に尻尾を振り、かわいがってもらうことが大切だ □チビは派遣先にかわいがってもらいやすから派遣には有利だ
>>89 > TEXT(" ")マクロのAPI版
意味が分からない。
マクロはコンパイル時に、ANSIかUnicodeか決まっちゃうのよ。
GetVersionExというAPIをVB6 EXEから使用していますが、 作成したEXEをプロパティで互換モード(Win95、Win2000等)に設定しても 戻り値(OSのVer番号)は、実行環境のOSのVer値となります。 この現象は、「WinXpSp2」「WinVista」にて確認しましたが、 ①互換モードで実行されているか否か ②どのOSの互換モードに設定されているか を知る方法を、ご存じの方は教えてください。
>>95 ちゃんと変わるけどなぁ(XP SP2で確認)
97 :
95 :2007/06/17(日) 02:05:14
>>97 VBでビルドする度にEXEが新しくなって設定がリセットされている
とか、
VBでEXEを作ってはいるが、VB上から実行していて、EXEを使ってない
とか、
そういうところに盲点あったりしないか?
99 :
95 :2007/06/17(日) 02:56:06
>>98 そのミスはないです。
ちなみに互換モード設定はEXE更新後も保持されるようです。
Visual C++ 6.0で作成したEXEを、互換モード設定し起動したところ、
設定したOSのVerが、ちゃんとかえってきました。
DLLにしてVBからコールしようと思います。
使用する言語によって動作が変わるAPIがあったら今頃大騒ぎになってるだろ・・・
Explorerのファイルサイズの1.23GBみたいに書式化してくれる関数教えてください。
そのぐらい自分で作れよ。
>>101 MSDNライブラリ
→Win32 and COM Development
→User Interface
→Windows Shell
→Shell Reference
→Shell Lightweight Utility Functions
→String Functions
→関数名の一覧から自分の目で探せ
自分の妄想した通りのプログラムが出来る関数教えてください。
そのぐらい自分で妄想しろよ。
>>104 自分の妄想した通りのプログラムは、自分の妄想の中で実行すれば、いいんじゃね?
やあ、
>>89 =83です。
こんな風にしたんだが良いと思う?
一様win98SE(マルチバイト)とXP(uni.)で正常に動作するのが出来た。
//char -> TCHAR変換
char str[X];
TCHAR buf[X];
_stprintf( buf,
#ifdef UNICODE
_T("%hs"),
#else
_T("%s"),
#endif
str);
>>104 std::string mousou(std::string nounai) {
//ここにコードを書いてください
}
>>107 _stprintfはスレ違いだな。このスレ的にはwsprintf。
>>107 なんでOSによってANSIとUnicodeを切り替えるの?
XPでもANSIでいいじゃない。
うっさいはげ
>>107 なんで#ifdef UNICODEするの?
_stprintf(buf, _T("%hs"), str) ;
これ一発でOKじゃんか。
%sにhを付けると、strを常にANSIとして扱うという意味だよ?
113 :
107 :2007/06/17(日) 16:28:21
>>112 熱烈感謝あげ
>%sにhを付けると、strを常にANSIとして扱うという意味だよ?
知らなかったよ、orz
h付でchar->UNI、hなしでchar->charと妄想した。
>>110 いや、あれよ、やっぱNT系OS用はuni.使わないとかっこわるいじゃない。
MSLUぶち込めばWin9xでもUnicodeAPI使えなかったっけ?
> かっこわるいじゃない お前は何を言っているんだ? 複雑なコード書くほうがよっぽどカッコ悪い。 # で、文字列操作関連でバグ出して、もっとカッコ悪くなるんだろうな。
>>113 >NT系OS用はuni.使わないとかっこわるいじゃない
なんとなく気持ちは解るけど、それはミスディレクション
基本は keep it simple、だよ
NT系以外もターゲットにするなら、Unicodeは極力利用しないのがベター
無用な複雑性こそ憎むべきだよ
117 :
デフォルトの名無しさん :2007/06/17(日) 16:46:55
Windows Vista にて 普通のサーバープログラムを sexe でサービスに入れたのですが 通知領域(タスクトレイ)にアイコンが表示されません。 サーバー機能は問題なく動作しているようです。 もちろん「ディスクトップとの対話をサービスに許可」していますし Shell_NotifyIcon のタイムアウト処理も行い msgTaskBarRestart によるタスクトレイ再登録も行っています。 直接の原因は Shell_NotifyIcon が ERROR_FILE_NOT_FOUND に なってしまっていることのようです。 何のファイルが見つからないんだ??? さっぱりわからん。 対応策はあるのでしょうか? やはり サービスプロジェクトで書き換えるしかない?
sex ではチンポ入れるんだよ
119 :
デフォルトの名無しさん :2007/06/17(日) 16:49:42
↑のコメントをした者ですが、 ちなみにサービス起動しない場合はちゃんとアイコンは表示されます。
120 :
デフォルトの名無しさん :2007/06/17(日) 16:51:53
119のコメントは117のコメントに対するものです。
>116 NT以外って何?CEのこと?3.1のこと?
>>120 Vista以外だとどうなの?
それからVistaでの変更の影響は調べたの?
セッション0の分離とか大規模な変更が行われたので、
互換性に関する資料がMSから大量に出されてたと思うけど。
125 :
デフォルトの名無しさん :2007/06/17(日) 17:34:33
>>122 WindowsXP の場合は、タスクバーにアイコンは表示されて
サーバー機能も問題なく動作します。
ただ、何故かサービスのくせにひとたびログインしてログオフすると
プロセスが死にます。この辺はまだ未調査です。
>>124 ありがとうございます。調査します。
126 :
デフォルトの名無しさん :2007/06/17(日) 17:41:44
>>WindowsXP の場合は、タスクバーにアイコンは表示されて タスクバー→タスクトレイの間違いです。すみません。
ボロ出し過ぎ
128 :
デフォルトの名無しさん :2007/06/17(日) 19:43:20
整理すると、sexe でサービス登録した場合、以下の現象になっている。 1)Windows XP の場合は、ログオフでサービス停止になる。 タスクトレイアイコンは表示される。 2)Windows Vistaの場合は、タスクトレイにアイコンが出ない。 ログオフしてもサービス停止にはならない。
>>113 MSDNライブラリでprintfの書式化文字列のところくらい見ろヨ
>>116 バイナリもテストも2重になっちゃうものね。
>>125 プロセスが死ぬのは、お前の書いたコードのバグで、例外か何かで落ちてるんだろ。
Drワトソンとか使ってチェックしる!
そもそも、
ユーザーのデスクトップのタスクトレイに、サービスが直接アイコンを出す
というのは、あんまりよくないと思う。
サービスのプロセスとは別に、
タスクトレイにアイコンを表示したりする、サービスのクライアントのプロセスを用意したほうがいい。
それをAll Usersのスタートアップに突っ込んでおけばいい。
>>95 どうせVB6.EXEのほうの設定(してない)が適用されてるとかいうオチだろ
132 :
デフォルトの名無しさん :2007/06/17(日) 21:36:37
>>130 >プロセスが死ぬのは、お前の書いたコードのバグで、例外か何かで落ちてるんだろ。
>Drワトソンとか使ってチェックしる!
バグかもしれないが、CFrameWnd::OnDestroy() が呼び出されて正常終了している
ところまでは解っている。
>そもそも、
>ユーザーのデスクトップのタスクトレイに、サービスが直接アイコンを出す
>というのは、あんまりよくないと思う。
そうなのですか。了解。
>CFrameWnd::OnDestroy() が呼び出されて正常終了している そりゃログアウトしたらウィンドウはクローズするよ サービスなんだからウィンドウが無くても動き続けるように作らなくちゃ
134 :
デフォルトの名無しさん :2007/06/17(日) 21:48:36
>そりゃログアウトしたらウィンドウはクローズするよ >サービスなんだからウィンドウが無くても動き続けるように作らなくちゃ ウインドウは通常 ShowWindow( SW_HIDE ) していて、タスクトレイの アイコンからのメニューで表示できるようなプログラムになっています。 それでどうしてもタスクトレイにアイコン表示したかった。 ウインドウがあるから当然なのかなとも思ったのですが、Vista では サービス停止にならなかったので???と思ったしだいです。
セッション0隔離でググれ
136 :
デフォルトの名無しさん :2007/06/17(日) 21:59:22
>>セッション0隔離でググれ 了解。ありがとうございます。
>>131 >>98 が指摘しているけど、違うらしいぞ。
何を指摘されているのか理解していないのかもしれないが。
>>132 トップレベル・ウィンドウに終了しる! っていうメッセージが来て、
はいはい、わかりました
といって終了するようにプログラムしたのは、おまえ自身だろ?
そりゃぁ終了するわな、当然。
サービスなんだから、そういうメッセージが来てもシカトしろよ。
サービスとして起動されている場合だけシカトするのでもいいよ。
ていうか、
ただのアプリとして作ったものをsexeを使ってサービスとして走らせるのに、
タスクトレイにアイコンだしたり、ユーザとの対話をするというのが、おかしい。
そもそも、sexeを使おうという時点で、間違ってるよ。 自分でサービスのためのAPIを使おうとすれば、自ずと理解することが、すっぱり抜けてる。
サービスにすると嫌われるよ
140 :
デフォルトの名無しさん :2007/06/17(日) 22:33:12
sexe はちょっと試してみただけです。 いろいろと勉強になりました。 ありがとうございました。
sex はちょっと試してみただけです。 いろいろと勉強になりました。 ありがとうございました。
143 :
デフォルトの名無しさん :2007/06/17(日) 23:41:45
ついでにさらに教えてほしいのですが、 サーバープログラムもサーバーとしての機能設定を行ったり、 クライアントの情報をリアルタイムで確認したりという GUIがあった方が良いケースもあると思いますが、 こういうプログラムはサービスにする必要はありますでしょうか?
>>143 普通はサーバプログロムのみをサービスにしてGUI系は別プロセスにするんじゃないか?
145 :
デフォルトの名無しさん :2007/06/17(日) 23:55:06
>>144 そうするとリアルタイムという部分が若干のタイムラグとなりますが、
やっぱりその実装ですかね...
146 :
デフォルトの名無しさん :2007/06/17(日) 23:58:49
>>144 そうするとリアルタイムという部分が若干のタイムラグとなりますが、
やはりその実装ですかね...
>>145 143の文章も意味が不明瞭だが、
もうちょっと、他人にわかりやすく、端折らずに書いてよ。
タイムラグを気にしているけど、
サービスと、
稼働状況をモニターするクライアントとの間は、
どうやって情報を受け渡ししようと考えてるの?
148 :
デフォルトの名無しさん :2007/06/18(月) 00:09:45
>タイムラグを気にしているけど、 >サービスと、 >稼働状況をモニターするクライアントとの間は、 >どうやって情報を受け渡ししようと考えてるの? TCP/IP による通信です。 タイムラグはさほど気にすることはありませんが...
じゃあ解決だね
150 :
デフォルトの名無しさん :2007/06/18(月) 00:13:10
解決です。ありがとうございます。
>>148 なんだよ。
気にしないものを、気にしてたのかよ。
馬鹿馬鹿しい。
で、
同一プロセスの次が、いきなりTCP/IPかよ。
タイムラグを気にしてるから、共有メモリと同期を使うのかと思ったぞ。
152 :
デフォルトの名無しさん :2007/06/18(月) 00:25:42
>>151 TCP/IPはクライアントとの通信です。
モニターはサーバーPCのみでOKということです。
同一プロセスならばリアルタイムですが、プロセスを分けると
共有メモリにしろ周期的にチェックする必要があるので
タイムラグが若干発生するけどまあ気にするほどでもないかと
いうことです。失礼しました。
>>152 文章が不明瞭だと思ってたけど、日本語が通じなんだな、おい。
154 :
デフォルトの名無しさん :2007/06/18(月) 00:49:50
>>153 単なる誤解でしょ。
>>稼働状況をモニターするクライアント
をモニター=クライアントと解釈するかどうかですよね。
そうだとすると通じてなかった。
>>154 それ以外の解釈は、ないだろ。
誤解するかもしれないので、
「稼働状況をモニターする」
と書いたのに。
だいたい、お前が作っているサービスが何をする代物なのか、言ってないだろ。
156 :
デフォルトの名無しさん :2007/06/18(月) 00:59:21
>>155 >お前が作っているサービスが何をする代物なのか、言ってないだろ。
ここで議論することでもないですので、これで終わりにしましょう。
ありがとうございました。
> 同一プロセスならばリアルタイムですが、プロセスを分けると > 共有メモリにしろ周期的にチェックする必要がある 同一プロセスだからといってリアルタイムとは限らないし、 プロセスを分けることで、周期的にチェックするしか出来ないわけでもない。
>>134 ・Vistaではサービスは別のセッションで動くように変更された
・あるセッションで動いているウィンドウは別セッションでは表示されない
・Windowsが終了(ログオフ含む)時に閉じようとするのは、ログオンしているセッションに属しているウィンドウのみ
・WM_DESTROYの応答でPostQuitMessageしていたらウィンドウ閉じるときにプロセスが終わってしまう
この4点で「なぜVistaではトレイアイコンが出ないか」「なぜXPではログオフでプロセスが終わってしまうか」
の両者の理由が理解できるかと。
まあ、サービスをシステム権限で動かしてデスクトップとの対話を有効にすると 大きな穴になる可能性があるからなあ。 昔、その場限りでアドミン権限で実行させるためだけのサービスとか作って遊んでたっけ・・・
>>159 >昔、その場限りでアドミン権限で実行させるためだけのサービスとか作って遊んでたっけ・・・
まあ実際RunAsってサービス使って実装されてるしね。
ttp://www.atmarkit.co.jp/fwin2k/win2ktips/059execau/execau.html >なおこの機能は、Windows 2000では「RunAs」というサービス、
>Windows XPでは「Secondary Logon」というサービスを使って実現されている。
>Windows 2000/XPでは、デフォルトでこのサービスが組み込まれ、
>システム起動時に自動的に起動されるようになっているが、
>何らかの理由からこのサービスが起動されていないと、
>[別ユーザーとして実行]は利用できない。
>>159 そんなサービス作らずとも、
標準のatコマンドで直近の時間を指定するか、soonコマンドを入れるかすれば、
管理者権限をもったプロセスを普通のユーザが起動できたぞ。
>>160 話が唐突に飛んでる
>>161 >話が唐突に飛んでる
スマソ。
>>159 が作っていたのが「いわゆるデスクトップでその場限りでアドミン権限で実行させるため」
のものだと誤解していたようだ。
しかしあれだけの文章から
>>159 が作っていたのが
「別のウィンドウステーションでその場限りでアドミン権限で実行させるため」のものと
よく確信できたね。
じつは
>>159 ==
>>161 ?
163 :
161 :2007/06/18(月) 16:43:49
>>162 NT4.0時代では常套手段だったから。
>>158 への対策として「別セッション上のデスクトップのウィンドウを操作したい」ってのは可能なの?
別セッションのHDESKに接続できれば何とかなりそうな気もするけどAPIが見あたらない・・・
>>163 それはatを実行する権限を持ったやつが必要だしなあ
fileman.exeをadminで実行してしまえばそこから起動するやつはみなadminだったっけな
VSのインテリセンスのような小窓?はどうやって実装しているんでしょうか。 解説しているサイトか取っ掛かりになるようなキーワードを教えてください。
ToolTipじゃねーの?
アクティブにしないフラグつっこんでShowWindowとかSetWindowPosしてるだけじゃね? と考えるおれは素人 しかしToolTipを間違ってクリックするとフォアグラウンド奪う実装は なんとかしてほしい
CD-Rソフトのように、アプリケーションの起動中のみ、 CDやUSBメモリのようなメディアを接続しても オートランを働かせないようにするにはどうしたら良いでしょうか?
R焼きソフトを起動中にオートランが起動しないのは、 CDドライブを握ってる副作用みたいなもん。 USBメモリは差し込む前にデバイスを握ることができないので 機能として実装するのは難しかったはず。
一時的にオートランの設定をOFFにする。 問題はアプリが異常終了したとき、OFFのままになる。
プログラムが異常終了していないか監視するプログラムを作る。
OSが終了しないとも限らない OSの監視も必要だ
OSごと異常終了することへの対策は、 アプリが起動したら、 レジストリの自動実行に、オートランの設定を元に戻すプログラムを登録し、 アプリが正常終了したら、その登録を消すようにすればいい。 元に戻すプログラムは実行されたら、自分で自動実行の登録を消すのも忘れずに。
autoun関係のレジストリって、変更後再起動しないと explorerが認識してくれないこと無い?
Win95を無視するなら RegisterWindowMessage(TEXT("QueryCancelAutoPlay")) をどうぞ
178 :
デフォルトの名無しさん :2007/06/19(火) 10:24:04
マルチポストあんましたくないんですが、すみません、このスレでいいのか迷うんですが、 Windows2000やXP、Vistaで、アプリからサービスを一時的に停止したり 開始したりする方法を教えて下さい。 宜しくお願いします。
やばい機能に使えそうだから教えない
net start/stop呼んどけ
マルチは嫌い。
>>178 >マルチポストあんましたくないんですが
ふざけんな阿呆。
PC一般板にでも逝け。
そして二度と来るな。
183 :
デフォルトの名無しさん :2007/06/19(火) 13:57:40
静的ライブラリにリソースファイル (.res) を入れました。 このライブラリを別のプログラムからリンクした場合、 リソースがリンクされないようなのですが、どうしてでしょうか。 解決策はないでしょうか。
.libにリソースは入れられない
ええ?でも VC8 でビルドすると自然に入りますよ。
入る?DLLとかじゃなくて? libってのは、objファイルを集めたもので、リンク時に使われてる関数が含まれてる objファイルを取り出してリンクするためのものだから、resが入ってても困ると思うんだが。
>>186 入るよ。 lib.exe /LIST Some.lib とかコマンド打つと、.res が入っている。
.obj も .res も link.exe への入力になるんだから、
そのまま .res もリンクしてくれればいいのだけど、
どうもしてくれないみたい。何かオプションがいるのかな。
いや、、そのresは名前をつけられるの?
そりゃ、静的ライブラリを作るプロジェクトの リソースコンパイラの設定でできるよ。
borlandなりgccなりvcなりしかるべき処理系のスレにいったほうが幸せになれると思うよ
VC8じゃstaticライブラリのプロジェクト設定にはリソースコンパイラ用のページが現れないな。 ファイルを混入させることはできても、リソースとしてリンクさせることはできないんだろう。
>>192 別セッション上のデスクトップのハンドルって取得できるの?
ライブラリにリソースを入れるのはいいとして、 ライブラリの中身全てがリンクされるわけじゃないぞ。 参照しているものだけがリンクされるんだ。 だから、リソースをライブラリに入れただけでは、リンクされないぞ。 ちゃんと、そのリソースを参照しないとな。
195 :
SEX :2007/06/20(水) 04:21:18
WNDCLAS"SEX" INITCOMMONCONTROL"SEX"
こういう事って可能でしょうか? A.EXEからB.DLLのエクスポート関数を呼び出したのを監視するプログラムを作る。 可能であれば方法を教えて下さい。
Bの方に通知機能を入れておけ
198 :
196 :2007/06/20(水) 08:06:04
それがA.EXE、B.DLLともソース閲覧のみで変更は許されてないんです。 関数はB.DLLのリストビューウィンドウを呼び出すもので負荷の少ない通知メッセージを探しているんですけど。
つ[Spy++]
200 :
20 :2007/06/20(水) 08:30:59
>>196 APIフック。AdvancedWindowsの弟4部 DLL を読めば解決すると思います。
201 :
196 :2007/06/20(水) 09:08:51
>>199 とりあえず、WM_CREATEで作れました。
>>200 アッー!APIフックですかぁ。確かにできますね。
AdvancedWindows買うつもりですが高いですね。
ありがとうございました。
202 :
デフォルトの名無しさん :2007/06/20(水) 09:13:54
>>191 > VC8じゃstaticライブラリのプロジェクト設定にはリソースコンパイラ用のページが現れないな。
> ファイルを混入させることはできても、リソースとしてリンクさせることはできないんだろう。
ページはあるよ。ちゃんとやってみた?
リソースはデフォルトでライブラリに含まれるようになっている。
>>194 > ちゃんと、そのリソースを参照しないとな
どうやって参照するの?
リソースIDで参照しても参照したことにならないよね?
>>202 >どうやって参照するの?
だから名前付けられるのかって聞いたんだよ
意味が無いということを説明したいのに反論ばかりして
人の言うこと聞く気も無いだろ、キミ
それ以前にスレ違いだ
>>203 ああ、そういことね。了解。すんません。
workgroup の 自分のマシン名を得るのはどのようにすればよいのでしょうか?
>>206 Windowsの正規の呼び方ではない、
「マシン名」なんていう言い方をするから、
わからんのですよ。
正しい呼び方は、コンピュータ名。
MSDNライブラリで、GetComupterまで入力すれば、候補のリストに
GetComputerName
GetComputerNameEx
あたりが見つかるでしょう。
208 :
206 :2007/06/20(水) 18:08:49
>>207 ありがとうございます。できました。
ついでに環境変数にもいっぱいあったのでそれも参考にします。
>>207 × コンピュータ名
○ NetBIOS名
>>193 調べてないけどターミナルサービス関係のAPIで何とかなったりしない?
Vistaでは常にセッションが分かれるけどXPでも高速ユーザー切り替えや
リモートデスクトップ使っているときは意識する必要があるはずだから
>>209 マイコンピュータのプロパティを開いて、タブの一覧を見よ。
「コンピュータ名」と書かれているから。
212 :
209 :2007/06/21(木) 00:08:15
>>212 GetComputerNameをMSDNライブラリで引いてみなよ。
NetBIOS名を取得するって書いてある。
とはいえ、
GetNetBIOSなんとか
ではないんだよ。
あくまでも、
GetComputerNameなの。
どうでもいい
215 :
209 :2007/06/21(木) 00:36:58
もうバカはほっとけよ
>>215 コンピュータ名 = NetBIOS名もしくはDNS名
ドメインコントローラがActiveDirectoryの場合は、NetBIOS名にならない。
>>215 その英文から「NetBIOS名」という超訳をひねりだせる脳味噌に感激
NetBIOS or DNS name だからNetBIOS名かDNS名だろ
NetBIOS無くてもFQDNでアクセスできるからなあ
>>217 その内容については知っている
>>206 に「workgroupの~」って付けて発言しているから
DNS HOST名を包括しているコンピュータ名という用語を
>>207 で
使用するのは正しくないと
>>209 でいいたかっただけ
FDQN
223 :
デフォルトの名無しさん :2007/06/22(金) 13:44:36
特定のプロセスIDの所有するすべてのスレッドIDを取得したいんだけどどのAPIでやりますか? スレッドIDで過去ログGrepしたけどないんで教えてください。 後、フックを入れてフォアグラウンドになったときをつかまえてスレッドID取得というのは無しの方向で。
Tool Helpでも使えば
Tool Helpだな
226 :
デフォルトの名無しさん :2007/06/22(金) 14:27:17
>>224 >>225 ありがとう。AdvancedWindowsのProcessInfoアプリケーションがサンプルになりました。
SystemParametersInfo()の電力管理フラグ、 スクリーンの低消費電力モードとスクリーンの電力停止モードはどう違うのでしょうか? どちらも同じ値が返ってきますが。
文字通りなんじゃねーか? コンパネの電源管理には電源を切る時間しか出てないから実際には使われてないのかも
マウスとキーボードが10分間放置されたときに自動的に終了するアプリを作りたいんだけど、 マウスのほうは定期的に座標を調べれば動いてるかどうかわかるが、 キーボードの無操作を検知するにはどうしたらいい? 自プロセスはタスクトレイに入っているのみ。
スクリーンセーバーにしろw
普通に考えたらジャーナルフックとかじゃないのか
>>229 普通にKEY_DOWN捕まえるだけじゃねぇか
バカじゃねぇのプtゥtw
フックが嫌ならGetAsyncKeyStateとかで
無操作を検知するのにKEY_DOWNとな!
234 :
デフォルトの名無しさん :2007/06/22(金) 21:14:34
235 :
デフォルトの名無しさん :2007/06/23(土) 00:05:34
>定期的に座標を調べれば動いてるかどうかわかるが そもそもなんでこれでマウスが操作されてないかどうか解るんだ? 走査頻度にもよるが、同じ位置に戻ってたら動いてるかどうか解らないのでは? 移動せずにボタンだけ使ってるとかも解らない気がするし
フックでキーとマウスのイベントを取得して、 イベント発生ごとにタイマーをリセットすればいい。
なんという頭の良さ まるで天才ではないか
初めからそう言ってるじゃねぇか
最初の質問からして初心者過ぎるAPI以前の問題 下手なアプリ作ってPC壊さないようにね
240 :
229 :2007/06/23(土) 02:03:56
フック限定ですか? アッパーとかでは無理でしょうか?
ハートブレイクショットならいけるかも
瞬獄殺ならおk
>>240 フックもできないお前にアッパーは無理だろ
ドライバ書いた事有るのか?
ブルースクリーン直行が落ちだろうな。 悪いこと言わないから、スタンバイか休止状態で妥協しとけ。
WindowsでおよそのLoad Averageを計算したいのですが、処理待ちのプロセス数はどうやって求められますか?
246 :
229 :2007/06/23(土) 14:12:18
KEY_DOWNを使ったのですが 自分のウィンドウがアクティブじゃなかったので 取れませんでした 騙したわね!!
自分のウインドウしかとらないように作れば当たり前だろ。 なんでそんなに頭が悪いんだ?
だから教えるだけ無駄 親切に教えてやっても騙されたと思うんだぜ
マウスカーソルの下にある文字列を取得する方法ってない?
ある
ないあるよ
>>245 パフォーマンスカウンタ。
ThreadオブジェクトのThread Stateカウンタにスレッドの状態が出るから、
自分で全スレッドのインスタンスに対して状態をチェックして集計しる!
LISTBOXにADDSTRINGする場合、文字列のデータはWindowsがコピーして管理してくれるんですか?
MSDN見ろよ…
∩___∩ |
| ノ\ ヽ |
/ ●゛ ● | |
| ∪ ( _●_) ミ j
彡、 |∪| | J
/ ∩ノ ⊃ ヽ
>>253 ( \ / _ノ | |
.\ “ /__| |
\ /___ /
256 :
249 :2007/06/23(土) 17:26:03
HWND既知のあるウィンドウが閉じられるときそのWM_DESTROYを取得するために、
サブクラス化というのを使えば出来そうだという所までは分かりましたが書式が分からないので
このページのサンプル
ttp://www.wisdomsoft.jp/dev/api/windows/064 LRESULT CALLBACK WndProc()内 の rect_box = CreateWindow{......}; の部分を
rect_box = FindWindow("Notepad",NULL); //メモ帳のハンドル
と書き換え
LRESULT CALLBACK StaticProc() のswitch内に case WM_DESTROY: と追加しても
メモ帳終了時のWM_DESTROYが取得できていないようです。
どのようにすれば正常に動くのでしょうか?
それ別プロセスのは無理よ
ファイルにNTFS圧縮かけるAPIってある? EFS暗号化ならあるのに、こっちがわからん。
261 :
258 :2007/06/23(土) 21:08:59
>>259 あのサンプルでは出来ないんですか。
サブクラス化するという手段自体が間違ってますか?
間違ってはない フック使えばサブクラス化でもできる
>>260 FSCTL_SET_COMPRESSION しらべれ
ねーねー ほかのプロセスが開いてロックしているファイルを 横から開くにはどうすればいいのん?
それ可能なのか?そんなことできるならロックの意味がないような・・
プロセスを終了させる
リードだけなら出来たりしないのかな? 試しにエディタで開いてみたら 書き込めませんよーってエラー出たけど開くのだけは出来たよ
そのプロセスが FILE_SHARE_READ でファイルを開いてたんだろ。 0 だと読み取りも書きこみも禁止される。
つかCreateFileの引数の解説読んでれば想像付くけどな
それようのモードがあったのか ありがと^^
271 :
デフォルトの名無しさん :2007/06/24(日) 15:05:41
ちょい質問。 Win2000、XPで Windows+M押下時と違って Windows+Dを押した時何かのフラグが立ったみたいで なんとかforeground();関数で ウィンドウを最前面にもってこれないんだけど 方法わかる方いたら教えてください。。 よろしくです。
せっかくしまったのに余計なことをしないでください。
ウィンドウズ乙
WinXPにおけるメモリマップドファイルについて質問なのですが、 ・HDDのファイルがメモリに複写されているわけではなく、あくまで仮想的なアドレスをファイルに割り振っているだけ。 よって、メモリにマッピングした直後はメモリはそれほど消費しない。 ・マッピングされたファイルを書き換えた情報は一端メモリに蓄積され、マッピング終了時にHDDのファイルへ反映される。 なので、マッピングされたファイルにデータを書き込めば書き込むほどメモリの使用量が増えていく。 という解釈であっているのでしょうか?
読み込むだけでも消費した気がする
>>274 基本的にはそんな理解でいいと思う
細かい動作はページングファイルと同じように考えればいいはず
メモリが足りなくなってくればHDDへ書き出される(読み取りしか行っていないなら捨てられる)
メモリが余ってくれば読み込まれてゆく
自前のコンソール画面を作りたいのですが、 APIで簡単に作る方法ってありますか?
AllocConsoleじゃなくて自前で一から作りたいって事?
eclipseのコンソール見たいのが作りたいです
エディットコントロールにでも流せばいいじゃない
WM_SETTEXTですか?
エディットコントロールの追記なら最後尾にカーソル移動してEM_REPLACESELを投げる 背景を変えたければ親でWM_CTLCOLOREDITを受ける
printfでエディットコントロールに書き込めるようにはできませんか?
stdoutを受け取って回送させるか、バッファに入れてから再度送りつけるか好きなようにやれ。
できますがスレ違いですね。 汎用化でも目指しているんですか? それともコーディング能力不足ですか。
printf使いたいってのはコーディングする側の問題だろ sprintfした文字列をエディットコントロールに追加すればいいじゃん
printfの出力先を変えられればコンソール・ウィンドウ両対応が簡単かなと思ったんですが やっぱりそこまでは無理ですか…
だから無理じゃないってば API以前に言語の勉強をしなさい。
その(頭の)現状では無理だな
>>288 stdoutをAllocConsole使う時見たく変えるってことですか?
何を指定すればエディットに流せるか分からないのはやっぱ知識不足なのかorz
もしかしてEM_STREAMOUTが関係ありですか?
Windowsプログラミングなんてバッドノウハウの数が技量に直結するから 「これかっ?」っと思ったことは片っ端から試してみるのも自分のためになると思うぜ
と言ってもfreopen以外に変える方法知らないんですけど…
メモリマップファイルは使いにくいね。 1つは、 SetProcessWorkingSetSize()で最大ワーキングセットサイズを設定しても、多量にメモリを食って、他のプロセスに優しくない。 かといって、SetProcessWorkingSetSize(,-1,-1)を頻繁に呼ぶのも美しくなく、 かといって、リンカに/WS:AGGRESSIVE付けても、なんだかなぁ、と。 もう1つは、 いまどきのハードディスクはシーケンシャルにアクセスしないと速度が出ないため、 メモリマップして任意にメモリアクセスすると、ランダムアクセスになってしまうこと。 結局、シーケンシャルスキャンのヒント付けて、各ページの先頭を触って、 予めメモリに読みこんでおくという作業が必要になってしまう。
今時メモリの消費量とかHDDの消費量を考えるのは不毛な気がする リークで不安定になるとかだったら分かるが
勘違いしてる人がもう一人
ぐぐっても6件… MSDN引くか… 俺のチラ裏にしちゃってもいいけどAPI一つでできることならそれだけ教えてくれるとありがたい
誰お前
SetStdHandleか!
>>299 ここは、お前のための、チャット会議室じゃないんだぞ。
>>296 > 今時メモリの消費量とかHDDの消費量を考えるのは不毛な気がする
そう思っていた時期も(AA略
パフォーマンスに無頓着なプログラムは、ハードウェアがどんどん速くなっても、その恩恵を受けられないことが多い。
というのも、ハードウェアの速くならない部分の性能に依存してるから。
MSDNにVistaのAPIが続々追加されてる ほとんどVista専用で邪魔だ 言語フィルタみたいにOSでフィルタリングしてくれないかな
Vista以前のOSにしがみついてる奴らをフィルタリングすればいいんじゃね?
そんな子としたら儲からない
307 :
デフォルトの名無しさん :2007/06/25(月) 08:27:20
SetWindowsHookExでとれるHHOOKをGetWindowsHookExみたいなのでとれないですか。 ThreadIdから自分にかけられているHOOKとか人にかかっているHOOKとかを知りたいです。
SetWindowssHookExをAPI-Hookしろ
お前ら、フック大好きなんだな。
彼女フック出来ないからAPIフックして憂さ晴らしてると思われ。
何この流れ。これが月曜の流れか
314 :
229 :2007/06/25(月) 16:40:07
229です。 ちなみに240は僕じゃありませんがそれはさておき。 ご意見参考になりました、ありがとうございます。 グローバルフックでWH_MOUSEとWH_KEYBOARDを定期的にチェックし、 システムタイマを取得して更新するみたいな感じですかね。 OSがスクリーンセーバを起動するのには同様の処理をしてるのかな。 それに使ってる「最終操作時刻」みたいのがどっかから取得できれば、 グローバルフック使わなくて済むんですが。 無いかなあ。。。
だから「最終操作時刻」を提供する側になれ それとは別に、試しにスクリーンセーバー作ってみ
316 :
229 :2007/06/25(月) 16:57:01
>>315 なんか勝手に初心者扱いされてますが、システムフックを書こうと思えば書けますよ。
ただ、OSが知ってるはずの「最終操作時刻」をとる方法、
もしくは無操作タイムアウトイベントみたいのを取得する方法が無かろうかと思って
最初に書いたようなプリミティヴな質問をしたわけです。
>>316 初心者ではないのなら、
最初から適切な質問のしかたをしろよ!
相変わらずノイズの多いスレだな。 初心者は回答しなくていいんだぞ。
ていうかさ、MSDNライブラリ(またはPlatformSDK)のヘルプ見てから質問してるんか? ちょっと古い版で恐縮だが、 Platform SDKドキュメント →User Interface Services →Windows User Interface →User Input →Keyboard Input →Keyboard Input Reference →Keyboard Input Functions →GetLastInputInfo ここまで、迷うところは、ないぞ。
途中で俺が229の振りしてなごませたのに やっぱりこうなったか まさかアッパーなんて専門用語があるとは思わなかったがw
322 :
229 :2007/06/25(月) 17:18:22
>>317 >>320 探してたのはそれです。僕が初心者でしたすいませんでした。
本当にありがとうございます。
これにて一件落着めでたしめでたし。 なんか逆転裁判おもいだした
アッパーワロタ
鬼の首を取ったかの様に
しかしおまえら、 ママンとフックが好きだなw
初歩的な質問させてください。 クライアント領域のサイズが640*480のウィンドウを作る場合、 WindowCreate関数の第6、第7引数を 640 + GetSystemMetrics(SM_CXDLGFRAME)*2 480 + GetSystemMetrics(SM_CYDLGFRAME)*2 + GetSystemMetrics(CYCAPTION) とすればいいんですか?(メニューやステータスバーはないものとする) というか、GetSystemMetricsの引数に SM_CXBORDERをいれた場合とSM_CXEDGEを入れた場合とSM_CXDLGFRAMEを入れた場合で ウィンドウのどの部分のサイズを指しているのかよくわかりません。 MSDNみても違いがわかりません。教えてください・・・
そういう用途では、AdjustWindowRectを使え、と昔 どっかで誰かが言ってたのを聞いた希ガス
状況によってサイズが異なるので、適正なサイズになるまでリサイズを繰り返すしかない。 一発で計算するのは無理。
いや普通にAdjustWindowRect使えよ
AdjustWindowRectはメニューが2段になると縦のサイズが 合わなくなるが、縦を調節し直せば無問題。
AdjustWindowRectを使っても、メニューバーの折り返しの分までは 面倒を見てくれないとかそういう話かな?
334 :
328 :2007/06/26(火) 01:16:09
なるほど、素直にAdjustWindowRect使えばよかったんですね。 無理してGetSystemMetrics関数を使うのはやめます。 ありがとうございました。
>>322 調節し直す必要があるかどうか判断できないんとちゃう?
判断するにはメニューに表示される文字列が必要だけどAdjustWindowRectは
MENUの有無をBOOL型で渡すだけでHMENUを渡す設計になってない
>>335 AdjustWindowRectで使ったクライアント領域(A)
サイズ調整後にGetClientRectで取得したクライアント領域(B)
A>Bならメニューが複数行って判定できるんじゃね?
思いつきだが
337 :
307 :2007/06/26(火) 08:21:21
>>308 回答、ありがとうございます。
SetWindowsHookExとSetWindowsHookにAPIHOOKをかける方法だとすでにフックがかけられている場合、みつけられないです。
フックを見つけてどうするの?
339 :
307 :2007/06/26(火) 10:42:24
UnHookするとか情報を表示するとか。。。etc。 勉強中です。具体的には、dwThreadId = 0でフックをかけて、仕込んだHookDLLのアタッチで別のDLLを呼んで、 呼んだDLLにフックした処理を渡したりしてるんですが、 UnHookしてもなんでかデタッチが実行されておらず、デスクトップをフリーズみたいな状態にしてしまうんで、 Hookを仕掛けた状態とかを見たいとかいろいろです。 dwThreadIdに特定のスレッドを渡すとデタッチが起こるんで、調べる参考にしたいと。
グローバルフック登録時に SetWindowHookEx完了時から帰り値のHHOOKを共有メモリに格納する一瞬の間に コンテクストスイッチが発生しHHOOK格納前にフック関数が呼び出されるという可能性に対して とういった対策が可能でしょうか 現在のPSDKのドキュメントだとCallNextHookExの第一引数は無視される仕様に変わったようなので気にしなくてもいいのでしょうか?
ハンドルからリストボックスなのかコンボボックスなのか 判断するには、、どうやるのですか?
GetClassName
>>345 みたいな馬鹿は迷惑だからプログラムを書くな。
>>340 第一引数が無視になってるとは知らなかった・・・
確かに
>>Windows NT/XP/2003: Ignored.
となってる。
ってことはNT系限定なら別に共有領域にハンドル置いといたりしなくてもいいのか?
>>345-346 「そんな事態は滅多に起こらないから無視していい」とかいうなら論外だが、実際MSの
ドキュメントやサンプルでもそのような排他制御を組み込んでいないから、「そのタイミ
ングでフック割り込みが発生することはない」という仕様になっているということは?
SetWindowsHookExでWH_CALLWNDPROCをインストールした次の行でSendMessage
してもフックは呼ばれるから、ほんとに一瞬しか待たないとは思うけど。
サンプルなんて手抜きに決まっているだろうに
じゃあ発生させてみろよm9(´Д`)プギャー
>>347 2000が抜けてるのが謎だな、どういう分類なんだろう
HHOOKを、無視されるCallNextHookExに渡すためだけなら むーてっくす張るコストが限りなく無駄じゃあないの?
>>348 > SetWindowsHookExでWH_CALLWNDPROCをインストールした次の行でSendMessage
> してもフックは呼ばれる
それは当たり前だと思う。
SendMessageなんだから。
ところでさ、
SendNotifyMessage
ttp://msdn2.microsoft.com/en-us/library/ms644953.aspx に、
WM_USERより下のメッセージを送るときはスタック上のポインタを渡すな
OSが引数のマーシャリングしてやるのは0~WM_USERだけだぞ
というようなことが書いてあって、矛盾してるぞ! と思ったのだが・・・
WM_USERより下というのは、
0~WM_USER-1
WM_USER~0x7FFF
WM_APP~0xBFFF
0xC000~0xFFFF
という並びで書いたときの、下、っていう意味なんだな・・・orz
>>356 プログラム書く前にネットワークの勉強をしろ。
話はそれからだ。
>>356 ネットワークプログラミング相談室に来たら相手してもらえるかも
360 :
デフォルトの名無しさん :2007/06/26(火) 22:43:33
いまさら聞けないインターネット入門とかみましたが SMTP,POPの仕組みとか広すぎてわけがわかりません><
>>360 結論だけ言ってしまうとグローバルIPが手に入らないと外部との通信は無理
やっぱりそうなんですか・・・orz 入門のとこ読んでるうちに WAN側のIPはグローバルらしいのでいけるかもって思ったのですが
WAN側ってISPのIPだろ。つーかスレ違い
>>357 いやいや、日本語の勉強をしたほうがいいと思う。
> winsockを利用してチャットの様に通信するソフトを試したのですが
ソフト?
何か不安になる言い方。
> ソースほぼここのサンプルまんまと考えてください
ソースはほぼここのサンプルのまま
と言わないのは、
ソースはほぼここのサンプルのまま
ではないからなんだろうか。
もしや、他人が作ったソフトの話をしているのではあるまいな?
ちなみに、
サンプルから変えた場所に問題があることも考えうるので、
普通は、どこをどう変えたのか書くか、
短いのだから全部をコピペして示したほうがいいことが多い。
>>356 > 自分のPC内で通信は成功したのですが
> ネットにでようとするとつながりません
ネットって何だ。
インターネットのことか? なら、インターネットと書け。
切り分けとして、
同一PC上
同一LAN上
インターネット越し
の3段階があるわけで、
まずは同一LAN上を試したのかな、と。
>>356 > WAN側のIPを指定してみましたが
何の「WAN側のIP」なんだ?
通信する相手は、どこにいるんだ?
止めろお前らwwww
最後まで責任持つつもりで弄ってるのか
369 :
デフォルトの名無しさん :2007/06/26(火) 23:18:28
通信相手というか
IPなどを確認できるHPから入手した自分のIPをいれて
自分のPC→インターネット→自分のPCといった経路を試したかっただけです
確かに読み直すとわかりにくかったですね。
日本は世界でも一番難しい言語なのでお許しください
>>363 さんの意見が正解みたいですね
ありがとうございました
>日本は世界でも一番難しい言語なので なるほど、あんたにとっては日本語さえまともに使えないと言うわけだ。
絡むなよ。長くなるだろ
>>369 君、香ばしいね。結構気に入ったよ、チュッ。またおいでね。
NATループバックとかいう、御節介をしてくれるルーターもあるけど、まぁあれだ。
>>369 本当にインターネットを介した通信のテストが必要なのかと小一時間。
その程度のプログラムなら、
LAN上の2台のPC(VirtualPC等でもいいよ)でテストすれば十分だ。
ていうか、場合によっては人様に迷惑をかけることにもなるので、
よくわからないうちはインターネットでテストしちゃいかん!
本当にインターネットでテストしないといけない場合は、
NTTのフレッツ系と、異なる2つのプロバイダを契約するとかしてだな・・・(以下略
育ってきた環境が違うから~スレ違いはしょうがない~♪
>>377 トラブルシューティング系の質問の基本を叩き込んでおかないと。
>ソフト? >何か不安になる言い方。 これはないだろこれはw
EM_STREAMIN メッセージをリッチエディットに送信するときに GetStdHandleを渡してもコンソールの内容を読めないのはなんでだろ(´・ω・`)
382 :
デフォルトの名無しさん :2007/06/27(水) 01:10:48
EM_STREAMINは標準ストリームから入力するわけじゃないから
もう少し詳しく書くと EM_STREAMINってのはリッチエディットコントロールのウィンドウプロシージャから アプリケーション定義の関数をコールさせてデータをストリーム入力するメッセージ 入力データはアプリケーション定義の関数内で自分で用意しなければならない 標準入力は全然関係ないよ
IStream と FILE *が混ざってるのだろうか?
385 :
デフォルトの名無しさん :2007/06/27(水) 08:44:39
ウインドウハンドルからスレッドIDとプロセスIDはGetWindow~で取得できるのですが、 スレッドIDから作成したウインドウハンドルを取得するAPIはありますか? 今はプロセスIDから取得したスレッドID、または、スレッドIDをEnumWindowで取得したスレッドIDと比較して 該当がないかどうか探しています。
GetWindowHandle
387 :
デフォルトの名無しさん :2007/06/27(水) 08:58:10
ああスレッドIDからか。じゃあシラネ
EnumThreadWindows?
GetGUIThreadInfo?
そのものズバリ、が無いのは1つとは限らないからだ
392 :
デフォルトの名無しさん :2007/06/27(水) 09:55:53
>>389 これですよこれ。
そのものずばりですね。ありがとうございました。
Enumは自分でもあげてるじゃん
EnumWindowがわかってて気がつかないってことは、 EnumWindowも人に聞いたんだろ。
IMEコンポジションウィンドウは使いたいが、IMEパッドは 使わせたくないという場合、パッドの起動を抑制する手段は あるでしょうか?
>>343 Mutexなどで待機した場合
SetWindowsHookExの内部実装次第でデッドロックしますよね?
397 :
デフォルトの名無しさん :2007/06/27(水) 12:14:01
398 :
デフォルトの名無しさん :2007/06/27(水) 12:16:52
いや、Windowsの開発関係者だろう
399 :
デフォルトの名無しさん :2007/06/27(水) 12:36:51
そんなことより396
そんなことより400(σ・∀・)σゲッツ
401 :
デフォルトの名無しさん :2007/06/27(水) 12:46:05
目くそ鼻くそを洗う
402 :
デフォルトの名無しさん :2007/06/27(水) 12:48:50
いいことじゃん
>>394 すぐ隣に並んでいるんだから、普通は、気がつくよな。
404 :
デフォルトの名無しさん :2007/06/27(水) 13:04:07
俺はすぐ隣に並んでいるあいつの気持ちさえ気がつかなかったよ
405 :
デフォルトの名無しさん :2007/06/27(水) 13:18:16
>>394 おっしゃるとおり、EnumWindowsもGoogle先生に聞きました。
以後はMSDNの周辺等も調べてみます。
406 :
デフォルトの名無しさん :2007/06/27(水) 14:58:12
プロセスIDからそのプログラムが どのような引数(CommandLine?)で動いてるか知る方法はありますか? WMIの「Win32_Process」で取れるのですが この方法だと「CommandLine」プロパティを見るのですが Windows Server 2000ではサポートされてないんです。 (Windows Server 2003以降、Windows XP以降でサポートらしいです) 諦めかけてたんですが「ProcessExplorer」ってソフトで CommandLineが見れるのでAPIで何とかなるのかと思い 質問しました。 よろしくお願いします。
フックで進入してGetCommandLineすればいいんじゃまいか?
>>406 ProcessExplorerはドライバまで使って色々やってるようだから、真似するのは大変よ。
プロセスのコマンドライン引数などの情報は、
プロセスのメモリ空間の決まった場所に格納されているので、
それをReadProcessMemoryで読んでしまうのがいいと思う。
どのアドレスに格納されているのかは、覚えてない。
NT系限定ならフックよりCreateRemoteThreadでのDLL注入のほうがローコストかもね 対象プロセスにウィンドウ無くてもいいし
>395 もお願いしますよ
コンポジションウィンドウって何だ?
>>396 例えば、どんな内部実装だとデッドロックすると思うの?
X Window SystemのLeaveNotifyイベントみたいな マウスカーソルがウィンドウから出た というのは、WM_* でいうと何に当たるんでしょうか?
>>413 WM_MOUSELEAVE
詳細はググって調べてくれ。普通は飛んでこないメッセージだから。
>>414 サンクス。流し読みした感じでは、自力で座標取得した方がいいかなこれは。
自力って、、、スレッドでループでもさせんのか マウスキャプチャーしてるなら、こんな質問しないだろうしなあ
>>416 いや、古い環境では無理なんじゃないか?って意味。
95とかNT3.1とか相手にしてるの? 大変だね
>>417 そういう意味か。
気にするほど最近の話でも無いみたいだけど、
昔はそういう目的にはキャプチャーだったなあ
>>418 それは古すぎw
95はともかく、NTは3.51あたりで
変動する数値をアイコンに反映させたい場合どうすればいいでしょうか? HBITMAPをHICON型に変換すればできそうなんですが、 方法も分からずもっと簡単な方法がありましたら教えて下さい。
>>420 そもそもそのアイコンはどこにどんな状態で表示するもの?
>>420 CreateIconで作るしかないんでない?
ありがとうございます。
>>421 タスクトレイのアイコンに数値でCPU使用率とか表示してるアプリがありますよね?
あんな感じで変動する数値を表示できたら便利だと思ったのです。
>>423 その方法も調べたのですがビットパターンがよく分からなくて一度諦めました。
CreateIconIndirectするか、イメージリストに追加してImageList_ExtractIcon
>>411 IME使った時に文字がフロートする部分ね。
要はIMEは使いたいがその時MEパッドは起動してほしくないと。
ちょっとお舞ら win32アピを利用して丸を描くプログラムを作ったんですよ ほかのウインドウが被ってしまったんだけど そしたらその部分が空白になっちゃったんだよ ウインドウの状態も保持しないてどんな仕様してんだよ 不良品じゃね?
おまえが描画したい状態を保存しとけばいいんじゃね? んでWM_PAINTが来たらまた描けばいいんじゃね?
430 :
427 :2007/06/28(木) 23:28:00
諦める これで解決
>>430 お前が記憶するわけではないのだからお前の記憶力などどうでもいい。
そのためのコンピュータではないか。メモリはたんまりとある。
>>423 ビットパターンって、普通にビットマップのはずだが
ANDマスクは透過部分が1、透過しない部分が0のピクセルあたり1ビットのモノクロビットマップ
XORマスクは透過部分が0、他は普通になカラービットマップ
436 :
デフォルトの名無しさん :2007/06/29(金) 07:28:45
このスレ的に一人前とはどの程度? ヴぁかにされたくない。
>>436 馬鹿にされても怯まず開き直れたら君も立派な一人前だ
>>434 カラーはDDBなんでそう単純には行かないのだよ
>>439 すまんね、アンカーなかったから気付かなかったよ
まぁ参考ってことで
442 :
デフォルトの名無しさん :2007/06/29(金) 13:04:54
開き直りたくないんです。 ヤラレル前にヤラレナイような一人前はどの程度?
444 :
デフォルトの名無しさん :2007/06/29(金) 14:36:20
「~以外の程度」という単語に強烈な違和感を覚える。
446 :
デフォルトの名無しさん :2007/06/29(金) 15:08:16
442と443以外の程度の以外の程度の以外の程度 確かに・・・
以上以下じゃなくて以外だからなあ・・・
448 :
デフォルトの名無しさん :2007/06/29(金) 15:12:50
442以外が一人前で442のみが一人前でないという意味か! ほんとうにありがとうございました
>>436 MSDNライブラリに載っていることくらい、質問しないで自分で解決できる程度。
ようするに、このスレが必要ない程度。
タスクトレイに表示されている他のアプリのアイコンのハンドルを 取得するかして、アイコンの画像を得たいのですが、できるでしょうか? 最悪タスクトレイ部分のビットマップでもいいです。
できますよ
特定のファイルが存在するか確認したいんですが、 自動的に環境変数のパスを検索してくれる関数はないでしょうか?
>>452 環境変数のパスってPATHのこと?
もしそうなら検索するファイルって実行ファイル?
だったらFindExecutableとか
>>452 EnvironmentStrings系のAPIでも使って自分で検索して下さい
っと、実行ファイルそのものの検索なら SearchPath() だったな
456 :
デフォルトの名無しさん :2007/06/29(金) 16:53:06
変な人がいるので再投稿しますね… タスクトレイに表示されている他のアプリのアイコンのハンドルを 取得するかして、アイコンの画像を得たいのですが、できるでしょうか? 最悪タスクトレイ部分のビットマップでもいいです。 やり方を教えてください。
457 :
デフォルトの名無しさん :2007/06/29(金) 16:55:02
変な人? ググれば見つかるのに何を言ってるんだ低脳
>>453-455 ありがとうございました。
SearchPath()で戻り値がファイル名より長ければとしました。
>IMEの使用はそのままで、IMEパッドのみ起動を抑制する まったくレスが付きませんが、これは結局無理なんでしょうかね?
461 :
デフォルトの名無しさん :2007/06/29(金) 18:12:40
最近のUACとかよくわかんないしうざいんだなー
>>459 多分無理だと思うが、そもそも何でそんなことがしたいんだ?
IMEの変換ウィンドウなんか出さずにすべて自前描画しているような
ゲームでさえ、IMEパッドは使えてしまうからなぁ。
IMEを自作しないと駄目だと思う。
SendMessage で WM_KEYDOWN/UP 送るときに、 VK_LBUTTON って送れない?
>>462 フルスクリーン時にフォーカスが移るのが
イヤだったので、抑制したかったんですよね。
やっぱ無理なんでしょうね。
>>456 ゴルァ
1回の質問で複数のことを聞くな。
変な人がいるので再投稿しますね…
>>456 トレイのハンドル取ってDC取得してコピー
これで分からないならこのスレではもう相手にされないよ
--------終了----------
タスクバーを自動的に隠す設定にしている 俺への挑戦だな。受けて立とう。ちょんわちょんわ。
関係ないよ
なんでこんな高圧的なんですか? 琴線に触れてしまいましたか・・・
誰だお前
琴線の使い方間違ってる。
逆鱗と勘違いしてんだろうな。リア中かも名。
俺の金銭に触れたら大逆鱗だぜ。
逆鱗は小さいと思うんだ。
ぎゃくりんで変換されないんですけど本当はなんて読むんですか
ぎゃくうろこ
>>477 「逆鱗」で検索すれば判ると思いますよ。
>>477 メモ帳にコピペして「変換」キーを押せば分かる。
C#をつかってます。 ユーザーさんからあるAPIでEntryPointNotFoundExceptionがでるって報告があがりました。 まあぶっちゃけILCreateFromPath なわけなんですが MSDNには Minimum operating systems Windows 2000 とあって、そのユーザーさんはスクショからみるにXPなんです。 うちのXPでは動いてるんですが、ありえるんでしょうかこんなこと。 私がしでかした間抜けで不可解な未知のバグの可能性と、 その人のshell32.dllがぶっこわれてる可能性と どっちが高いでしょうか?
ジャンクション(フォルダへのシンボリックリンク)内にあるファイルの実体のpathを 取得する方法を教えてください。
僕ハッカー
Win98でもXPに見せることはできる
>>482 DeviceIoControl使えば取得できる。
486 :
デフォルトの名無しさん :2007/06/30(土) 15:06:27
PROCESS_INFORMATIONの、dwProcessIdか、dwThreadIdからウィンドウハンドルを求めたいんですが、 方法ありますでしょうか、情報ありましたらよろしくお願いします。
ものすごくありふれた情報だけどググったの?
488 :
デフォルトの名無しさん :2007/06/30(土) 15:55:36
スレも検索してないだろ。昨日か一昨日見たぞ
489 :
486 :2007/06/30(土) 17:59:00
コメントありがとう御座います。 ひととおり検索はしてみたのですが情報が多く期待した情報が見つけることが出来ませんでした。 できましたら、検索キーワードだけでも教えていただけないでしょうか。 よろしくお願いします。
具体的に何で何を検索したのか言ってみろよ
385じゃね
>>489 なんでお前の代わりに俺がスレを読み直さないといけないんだ?
やることはわかってんのに、なんで自分でやらないの?
無知の無知に愛の鞭
>>485 どうもありがとうございます。これから調べてみます。
>>481 エントリポイント名を ILCreateFromPathW に変えてみる、とか。
家のXP SP2のshell32.dllはA、W、無し(=W)と3つエクスポートされてるけどなあ。
498 :
486 :2007/06/30(土) 21:29:04
さくっと、検索キーワード教えて頂けませんでしょうか。
PID2HWND これでぐぐればおkじゃん?
うぜーから放置で
501 :
デフォルトの名無しさん :2007/07/01(日) 09:39:03
DllMain の DLL_PROCESS_ATTACH でLoadLibraryしたら× DllMain の DLL_PROCESS_DETACH でFreeLibraryしたら× とMSDNにあります。 Dllの利用元に処理をしてもらうわけでなく、何かの関数を呼んでもらうわけでなく、 DllのATTACH時に別のDllを動的にLoadLibrary~初期処理、DETACH時にそのLoadしたDllを終了処理~FreeLibrary する実装の代替案ってどういうふうに書いたらいいですか? 設定ファイルにかかれたDllファイル名からを動的にDllから読み込んで、 前処理しておいて、設定毎に処理を変更する動作をつくりたいんです。 いまのところATTACH時にLoadLibraryして、DETACH時にFreeLibraryするのを作ったんですが 問題がでてないんですけど、MSDNにすんなってかいてあるんで・・・。 初めてDLLのなにかの関数が呼ばれたときにLoadLibrary~前処理するってのは無しで。
502 :
デフォルトの名無しさん :2007/07/01(日) 09:55:13
やっぱ初めてDLLのなにかの関数が呼ばれたときにLoadLibrary~前処理するってのは有りで。
確か他のDLLが初期化途中だとループする可能性があるから駄目なんだったかな A初期化中にBをロード→B初期化中にCをロード→C初期化中にAをロード→・・・ みたいな DLL_PROCCESS_ATTACHが処理を返してからなら参照カウンタが増える (カウンタが1以上ならDLL_PROCCESS_ATTACHは投げられない)からループしない
質問なんですけどダイアログで使えるコントロール(タブとかシークバー)を自前のWindowで使いたい場合はどうすればいいのでしょうか? CreateWindowで作れるコントロールの中には無いっぽいのでどうすればいいか困ってます。
commctrl.h
>>501 CoInitialize/CoUninitializeみたいに別途初期化・終了処理の関数を用意したり、
暗黙的リンク(必要に応じて遅延読み込み)したり。
Microsoft Platform SDKとはなんですか? これだけでほかの開発環境なくてもプログラミングできるのでしょうか
>>507 Windowsアプリを作るうえで必要になるライブラリ群。
ライブラリなので、当然これだけでは何も作れない。
ここは既にプログラミングの環境が構築できてる、 あるいはできるという条件の元でWin32APIについて質問するスレです。 環境の構築ができてないレベルだと、>507の質問に回答が出ても理解できないかもしれないが そこまで面倒見れない
そうですか WIN32APIとはまた違ったものなんですね
まあでもWin32 APIを使うためのヘッダやインポートライブラリと、 ドキュメント・サンプル・ツールなんかが入っているセットと言えばいいかな。 でも、今はWindows SDKになったが。
>>507 百聞は一見に如かず
無償でダウンロードできる代物なのだから、
とりあえずインストールしてみて、
HDDにコピーされたファイル群を眺めてみれ。
必要かどうか分からないなら、とりあえず、
潰してもいい環境にインストールすりゃいい。
潰してもいい環境を用意できないようなら、
HDDに十分な空き容量とVirtualPCを。
Windows SDKはコンパイラ・リンカが付いてくるよ。
Windows SDKのコンパイラは /analyze が付いてるよ。
ファイルをドラッグ&ドロップして起動した時に、 そのドロップされたファイルを読み込ませたいのですが、 lpCmdLineを引数にfopenしてもオープンできません。 どうすれば読み込ませられますか?
それでできないことはないはず。 まずは試しにlpCmdLineを表示させてみな。
517 :
515 :2007/07/01(日) 16:23:37
表示してみました。 "C:\Documents and Settings\~中略~\aa.mp3" 正しいパスが表示されてるっぽいです。
「"」を取り除け
519 :
501 :2007/07/01(日) 16:42:33
IDないと502にみたいな偽者がでてくるのか・・・
>>503 そうなんですよ。でも別の代替の処理を考えつかないんです。
>>506 暗黙的に行うと、DLLのパスが設定ファイルから渡して動的ロードできないので使ってないです。
CoInitialize/CoUninitializeはなんで制約がないのか調べて見ます。
520 :
515 :2007/07/01(日) 16:57:26
いけました。本当にありがとう。
>>519 すみません、代替処理見つからないなんて釣りだと思いました。
>>514 マジですか。お得ですね。
VSのコンパイラをSDKのものに差し替えたくなりますな。
>>519 CoInitialize/CoUninitializeの話は、
DLL_PROCESS_ATTACHでLoadLibraryするのではなく、
そのDLL特有の、LoadLibraryなどの初期化処理を行う関数をExportして、
それをDLLを使う側に呼んでもらうことにする
ってことかと。
>>517 CommandLineToArgvW
とか使ってパースしる!
ANSI考慮するなら__argc,__argv。 標準ライブラリが必要だけど
>>519 プログラム側でロードが終わった時点で初期処理すればいいだけのような気がするんだけど
CreateでロードしてんならLoadLibraryが処理返してから初期処理とやらをすれば良いじゃん
>>514 まじで?!
70万だして買っちまったよ・・・
まじだよ。/? すると -CODE ANALYSIS- /analyze[:WX-] enable code analysis WX- - code analysis warnings should not be treated as errors even if /WX is invoked って出る。バージョンとかは同じだけど、付属のバイナリ群はdiffとるとどれもちがうっぽい。 まあ使い方わかんないし、最近Cやってないから必死こいて調べないし、スレ違いだけど
529 :
デフォルトの名無しさん :2007/07/01(日) 22:19:48
>>523 >>526 そのやりかただとフックとかしかけたときにそのDLLの
アタッチ時に別のDLLを呼べない。
というわけで初めてCALLBACKされたときに初期化するしかなくなる。
>>529 >というわけで初めてCALLBACKされたときに初期化するしかなくなる。
これが正しいんだと思うが
適当にメッセージ投げろよ
>そのやりかただとフックとかしかけたときにそのDLLの
>アタッチ時に別のDLLを呼べない。
グローバルにフック仕掛けてたら必要ないプロセスに無駄なDLLロードすることになるじゃん
お前ら。 DLL作るときは、ロードアドレス、ちゃんと設定しとけよな。 VCとかのデフォルト値のままだと、リロケートすることになるし、仮想メモリ空間をぶった切ることになるぞ。
どっちにしろ、デフォルト1000:0000でグローバルフックする ような連中もいるんだから無駄 仮想メモリがぶった切られるったって、MS純正のDLLとしてが 4000:0000とかに存在する現状では寂しい限り。
64bitいや128bitの時代はまだか
128bitになるころは画面はホログラムになってますか?
>>532 行儀が悪い輩がいるからといって、自分まで行儀悪くしてどうするよ。
人様が作った行儀が悪いDLLはReBaseでベースアドレスを変更しちまえ。
どのへんに置いとくのが適切なのかわからん
>>536 MSDNライブラリ等で
ReBaseImage
のところに説明がある。
Comboboxのedit controlを取得するのってGetWindow(コンボのハンドル, GW_CHILD)しかない? ComboboxexならCBEM_GETEDITCONTROLがあるんだけど、、 Comboboxで安全にeditを取得する方法があるのなら、知ってる人いませんか?
CB_GETCOMBOBOXINFO
>>539 ずばりのもの、ありがとう。解決しました。
MSDNをみるとCB_GETCOMBOBOXINFOはXp、
windows2000では、GetComboBoxInfoが使えますね。
>>528 Windows2000環境にインストールしようとして断られた・・・orz
ちなみに、どのバージョンのWindowsSDKなのか教えてもらえると助かります。
/analyzeというか、PREfastには2種類ある。 先にDDKで提供されていたドライバ開発者向けと、 後からVCの上位版に提供されたアプリ開発者向けが。 Windows SDK付属のコンパイラで使えるのは前者だけだったりしてね。
>>543 ちょっと試してみたけど、VSTS付属のものと同じ出力だった。
Windows SDKの方はコマンドラインからしか試してないけどVS連携はまあきつそうか。
以下テストコード。タブを全角に変換してるので注意ね。
#include <CodeAnalysis/SourceAnnotations.h>
#include <windows.h>
[returnvalue:SA_Post(MustCheck=SA_Yes)]
double CalcSum ([SA_Pre( Null=SA_No )] double* source,unsigned int size);
double CalcSum (double* source, unsigned int size)
{
double sum = 0;
for( int i = 0; i < size; ++i ) sum += *source;
return sum;
}
int f()
{
double buf[100];
for (int i = 100; i >= 0; i++) buf[i] = i;
CalcSum(buf, 99);
return (int) 1;
}
int main()
{
wchar_t buf[255];
GetEnvironmentVariableW(L"PATH", buf, 256);
return f();
}
545 :
544 :2007/07/02(月) 14:10:04
続き。 上のコードのコンパイル結果。 c:\test>cl test.cpp /analyze Microsoft (R) 32-bit C/C++ Optimizing Compiler Version 14.00.50727.762 for 80x86 Copyright (C) Microsoft Corporation. All rights reserved. test.cpp c:\test\test.cpp(14) : warning C6292: Ill-defined for-loop: counts up from maximum c:\test\test.cpp(14) : warning C6201: Index '100' is out of valid index range '0' to '99' for possibly stack allocated buffer 'buf' c:\test\test.cpp(15) : warning C6031: Return value ignored: 'CalcSum' c:\test\test.cpp(14) : warning C6386: Buffer overrun: accessing 'buf', the writable size is '800' bytes, but '808' bytes might be written: Lines: 13, 14 c:\test\test.cpp(21) : warning C6202: Buffer overrun for 'buf', which is possibly stack allocated, in call to 'GetEnvironmentVariableW': length '512' exceeds buffer size '510' c:\test\test.cpp(21) : warning C6386: Buffer overrun: accessing 'argument 2', the writable size is '510' bytes, but '512' bytes might be written: Lines: 20, 21 Microsoft (R) Incremental Linker Version 8.00.50727.762 Copyright (C) Microsoft Corporation. All rights reserved. /out:test.exe test.obj
?
>>545 これって、VCProのcl.exe関連を差し替えて、SDK付属のCodeAnalysis関連ヘッダもコピーしてやればIDE上で使えるんだろか
ファイル差し替えなくてもディレクトリ設定変えてやればいんじゃね? IDE上での設定UIは無いだろうから手動でclのパラメータ追加しないとだめだろうが。
549 :
544 :2007/07/02(月) 16:12:09
>>547 すまんがVC++Proはすぐに使えるところにないのでその辺の検証は誰かやってちょ。
あとはまあコード分析とかそんなにしょっちゅう使わなくても
たまにとかリポジトリにコミット前にとか自動テスト前とかでもいいんじゃね? とか。
vcbuild.exeをうまいこと使うと自動化できるんじゃなかろかと。
VC++Proの場合。 VC++ディレクトリの「実行ファイル」に C:\Program Files\Microsoft SDKs\Windows\v6.0\VC\Bin を追加し、これを優先度一番上に。 (x64なら...\v6.0\VC\Bin\x86_x64) 同じく「インクルードファイル」に C:\Program Files\Microsoft SDKs\Windows\v6.0\VC\INCLUDE を追加し一番上に。 あとはプロジェクトオプションで「構成プロパティ」-「C/C++」-「コマンドライン」で 「追加のオプション」に「/analyze」を記述してやればいい。 本格的なアノテーションまではチェックしてないが、簡単なバッファオーバーラン検出 程度は動作しているのを確認。 ちなみにこれDebugビルドでは使えるがReleaseビルドでは使えないという認識でOK? 厳密にはAPIの話題ではないが、Win32 APIの引数や戻り値チェックもしてくれるのでとりあえず。
551 :
501 :2007/07/02(月) 19:35:00
Analysisってそんなにすごいものなの? 70万もだしたというひとがいたが
>>552 Analysisだけに70万ではないし、
プロ用の開発ツールが高価なのは普通のことだから。
RationalのPurifyとか、
CompuwareのDevPartnerStudioとか、
かなりの金額するでしょ。
たとえ趣味でもつぎ込む人はつぎ込むしね
脱力
>>555 FindWindowEx使って力業で探せ
何でもAPI一つで出来ると思うな
普通IWebBrowser2使うだろ
>>559 IEとは言ってない。
意地悪な解釈ではあるがな。
つーか >現在開いてるページのURLとタイトルを取得したいのですが、 >そのような関数がございましたらご教授下さい。 この質問通りに答えるなら「無い」が正解
>>560 「現在開いてる」というのを詳しく。
何が、誰が、
そういう情報がゴッソリ欠落しているぞ。
>>560 どういうわけか、
インタフェースとしてではなく、クラスを指してIWebBrowser2という人達が多いのです。
IEそのものや、既存のIEコンポーネントを使ったプログラムに対してではなく、
タイトルを取得するためだけに、新たにIEコンポーネントを使い、
URLのドキュメントを取ってこさせ、タイトルを取得するという手もなくはないです。
ダイアログベースのアプリで、キーリピートのときに鳴り続ける警告音を消したいのですが どうしたらよいのでしょうか。
もっと詳しく書かないと。
WM_KEYDOWNのLPARAM見てリピートが1より大きかったらメッセージ潰せばいいんじゃね
そのダイアログのせいで鳴ってるの? キューいっぱいとか。キーメッセージ握りつぶしてる?
メッセージポンプを自分で止めている可能性もあるな。
>>561 IE6まではDDE使って取得できたんだがな、IE7以降これが動作しなくなった
しかしFirefoxやOpera等使われていたら動かないわけで。
2chスレに限って言えば専ブラ使われていたらだめなわけで。
570 :
562 :2007/07/03(火) 12:33:58
571 :
デフォルトの名無しさん :2007/07/03(火) 13:16:38
そんくれーわかるっつの
>>550 ちょwww
俺のPro版、なんかアナライズしてるww
IEでグーグル開いたときに検索窓でますよね あそこに文字列をいれるのにいい方法ってありますか? キーダウンで擬似的にキーボードおされた状態ってのはうまくいったのですが たまに失敗したり、一文字ごとにウェイトいれないとだめなのでちょっと・・・ セットウインドウテキストが良さげなので 全てのIEの子ウインドウハンドルに送ってみたのですがまったく反応ありませんでした
フォームに入力するのVBのサンプルならいっぱいある
Google限定なら別のアプローチのがよさげ
どうでもいいけど「キーダウン」とか「セットなんとか」とか 強烈に読みづらいから素直にアルファベット表記してくれ。 あとIEのテキストフォームはデザインがWindowsと同じってだけで IE独自の実装してるからテキストボックスに見えて テキストボックスじゃない。 API通していじるのは諦めた方がよさげ。
577 :
573 :2007/07/04(水) 09:32:47
あ、ウインドウのタイトルが変わりましたw これ面白いですね そうなんですかどうりで反応しないわけだ VB覚えようかな
1.クリップボードに好きな単語を入れる 2.C-V を送る でいいじゃん? 俺だったらそんな面倒くさいことせずに、 検索語を別の窓から入力させて、結果をIEで開くように作るが。
あ、クリップボードも試してみたのですが 効かなかったから・・・ハッ!Σ(゚□゚;)!! その貼り付けたには気づかなかったorz 別窓のは技術が高くないと無理かと
IE上のコントロールはドロップダウンリスト以外は全部ウィンドウハンドル持たないIEの独自描画。
別窓作って文字入力 入力文字をURLエンコードして連結 シェルに渡す
_人人人人人人人人人人人人人人_ > な なんだってー!! <  ̄^Y^Y^Y^Y^Y^Y^Y^Y^Y^Y^Y^Y^Y^ ̄ 試行錯誤したのが馬鹿みたいだ
そうだね。
試行錯誤すること自体は無駄じゃないよ
質問の仕方がわるいんだからしょうがない。
>>576 読みづらい以前に、
特別なキーワードを、
言い換え可能な普通の言葉で書いたら、
わけわかんないよ。
WM_KEYDOWNではなく、他のものかもしれないと気をつけて読まないといけないから。
>>577 VBでやると簡単だが、VBでしかできないわけじゃない。
Win32APIには、Cスタイルのものと、COMのものがある。
VBはCOMを扱うのが楽。VCだと慣れるまで面倒。
VB6ならともかく、VB.NETでやるくらいならC#でやりなされ。
いやあ日本人なのでカタカナの方が読みやすいかなと思ってw しかし天才がいるもんですね cgiとかってのに直接送ってるみたいなもんでしょ?驚きました
>>590 日本語版のMSDN に 「WM_KEYDOWN」 が 「キーダウン」 と書かれたらすげー迷惑
発音しているものが動作を指しているのか、特定のキーワードなのかを即座に区別できねーじゃん
プログラムの定数的なのは、別に英語でもそのまま定数で書くよw
ダブリューエム_キーダウンと書くかWM_KEYDOWNとするかは 翻訳者の自由だぁ~~!! 予約語いずフリーダム♪ ハイ一緒に!
消えろ
キーダウンと書いたのを見て、実際にキーを押した事だと思ったよ・・・
こんにちは、ちょっとした疑問の解決作を教えてください。 エディタをサブクラッシングしようと思い、以下のコードを書きました。 WNDPROC OldEditProc; LRESULT CALLBACK EditSubProc(HWND,UINT,WPARAM,LPARAM); ... OldEditProc=(WNDPROC)SetWindowLong(hEdit,GWL_WNDPROC,(LONG)EditSubProc); しかし、これだとデフォルトの警告レベルで、warningが2つもでるんですよね・・・。 ( 『LRESULTからLONGに切り詰めます』 というのと、『LONGからWNDPROCへ変換します』 というもの ) これ、どうにかしてwarningを取る方法は無いでしょうか? ご教授御願いいたします。 環境はWinXPPro-sp2 ,VC++.NET です。
何故warningになるのか考え、それの対処を調べるんだ ヒント:64bit
599 :
596 :2007/07/05(木) 00:32:56
おぉ~凄いっ! 教えていただいた通りにやってみると、warningが出ないです~っ!! 大変参考になりました。 本当にありがとうございました。 m(。-_-。)m
int APIENTRY WinMain(HINSTANCE, HINSTANCE, LPSTR, int); これを int APIENTRY WinMain(); こういう風にしたんですが、できませんか?
できません
できます
できますん
つかわないんならなくてもいいだろ
できます
APIENTRYだから、できませんね。 __cdeclならできるんだけど。
できます
608 :
デフォルトの名無しさん :2007/07/05(木) 13:34:51
あぴえんとりー
キチガイが住み付いてるな。
自己紹介乙
自分で分かってるなら大丈夫だから安心していいよ
ワレワレハ、ウチュウジンダ
そういえば言語言ってなかった・・・ C言語なんですがやっぱ無理かったです 本当にありがとうございました
プログマーが日本語おかしいのはヤバイ 数学より国語的な能力が必要だとおもう
プログマー
釣られるプロだクマー
プラグマー
>>617 差し替えで簡単に置きかえられるプログラマー?
#pragmar
プギャー
まるで動物園だな、ここは
人間だって動物さ
マ板は釣り易いことで有名くま
プラモデルみたいなプラグラマ
>>624 語源は両方ともギリシア語だけど、出所が違うの。
スレ違いだからほどほどに。
プログマー笑ったwwwwwwwwwwwwwww
面白くない。いい加減にしとけ
ウィンドウのタイトルバー上のホイール操作で ウィンドウを半透明にできるユーティリティを作りたいんだが システムフックしてDLL上でコードを長々と書いて一応できることはわかった。 だけどexe側で処理させたいのだが、なにかよい方法はないだろうか? exeに、呼び出されたDllのインスタンスハンドルを送ってそこで明示的な関数ロードとかやったけどできなかったよ
今市意味が分からないんだけど ホイール操作を捕まえて半透明化するサブクラス化用のプロシージャを書いて フックを入れてからサブクラス化すればいいと思う
>>628 そういう機能のWindowTPというソフトがあるが、自分で作りたいだけ?
>>629 おk、サブクラス化試してみるわ
ありがと
>>630 今作ってる奴の機能の一部として搭載予定。
まぁ自己満足だけどね
ありがとー
632 :
628 :2007/07/06(金) 03:28:14
Dllから呼び出したダイアログにXPスタイルが効かないんだけどなんでだかわかる? manifestやらcomctl32やらをexeの設定方法でやってんのがダメなのか…。 わかんなくて頭爆発しそうなのでそろそろ米国行きの飛行機に乗りに行きます。
どうぞ。
そのDLLを呼んでるEXEの設定はどうなのよ
637 :
634 :2007/07/06(金) 15:08:31
>>636 最終的に写真屋のフィルタ(8bf)にするDLLなんでナカミはよぅわからんのです。
ただ、さっき「猫でも~」の外部DLLからダイアログ呼ぶプログラムでも
試してみたけどコレもダメだったので
写真屋のAPIの問題っつーより私の問題らしいです。
>>634 ISOLATION_AWARE_ENABLEDについて調べるんだ
639 :
634 :2007/07/06(金) 21:29:52
うおおおおおおおおおお!
プリプロセッサにISOLATION_AWARE_ENABLED書いただけで
うまくいきましたッ!
>>638 ありがとーーーーーーー!
愛してるッ!
きんもー☆
任意のプロセスがCreateFileしたファイルのパス、それを取得する方法て何かないですか? 使用OSはVistaです フィルタドライバ書かなきゃいけないんでしょうか?…
CreateFileのAPIフッ(ry
DLL側から、呼ばれているプロセスのIDかウインドウハンドルを取得するにはどうすればいいですか? FindWindowでウインドウタイトル指定して取得していたんですが、 多重起動されたらだめじゃんってことに気が付いて・・・・ おしえてくださいm(_ _)m
普通に自分のプロセスIDを取得しろよ。 DLLをなんだと思っているんだ?
>>642 VistaでAPIフックしたら実行時に警告出ませんか?
>>644 普通にプロセスIDを取得する方法を教えてくださいm(_ _)m
GetProcessID()
649 :
デフォルトの名無しさん :2007/07/07(土) 10:44:49
>>646 GetCurrentProcessId()
名前からしてそのものズバリな訳だが
このくらいググれ
>>645 > VistaでAPIフックしたら実行時に警告出ませんか?
そりゃあドライバでも一緒だと思うが?
651 :
デフォルトの名無しさん :2007/07/07(土) 10:56:57
人を利用する事しか頭に無い奴に回答をくれてやるな。
32bitVistaだとドライバの場合ロゴとらないとWindowsの動作自体に制限かかるんだっけ? 64bitだとフックもドライバも現実的じゃないよな
いつも思うんだけど なんでこんなにフックしたい奴が多いんだ
654 :
デフォルトの名無しさん :2007/07/07(土) 12:23:35
フックで躓く奴が多いんだと思われ 別に集まりたくてフックしたい奴らばっかり集まってるわけじゃないでそ
あやしげなソフト作ろうとしてんだろうな
>>649 ググるよりも前に、PlatformSDKのヘルプ、または、MSDNライブラリだろう。
検索してもいいし、普通に目次から辿っても見つけられる。
ていうか、普通に目次から辿って見つけられないのは、よほどのアレだぞ。
>>653 質問のしかたを見ると、厨房くさい
やろうとしていることを見ると、怪しい
>>555 あたりなんかは、
特定のサイトにアクセスしているときだけキーログを取ろうとしている
とも見れるしなぁ。
怪しいプログラムを書くなら、人に聞かずに自力で何とかしろってんだ。
658 :
デフォルトの名無しさん :2007/07/07(土) 15:09:00
するどい人だな。まったく想像できなかったぜ
>>653 そりゃあ2ちゃんだから釣り師が多いんだろ
上手い事言ったつもりかも知れんが面白くない
俺窓プログラム作って初めて実用的なの作ったのはフック使ったネトゲーツールだったな 調べながら実装したし窓プログラムの根本的な概念もそんな理解してなかったから コードはめちゃくちゃ汚かったが勉強にはなったな。 そうこうしながら1年後あたりにAPIフック使ってパケット取得ツールも作ったわ。 APIフックは俺がしょぼいからだろうが4ヶ月かかってやっとできたんだけどなw フックぐらいはちょっと頑張ればすぐできるだろ。 人に聞くのが悪いとは言わないが、フックに関しては 参考サイトいっぱいあるんだから自分で調べようぜ。 特に目的が限りなく黒に近いものを作るんならなおさら。
単なる物臭か根性無しだろ どうせヒマ人が答えるんだしいいじゃねーか別に
オレには真っ黒にしか見えないが、 そういうことをやってる当人には灰色に見えるんだろうな
ためしに検索したらたくさんでてきた しょぼいキーロガー程度ならすぐできるな
665 :
661 :2007/07/07(土) 22:06:04
>>663 まあ真っ黒だわなw
ただ、そういうの作る奴が全部俺みたいな考えだとは思わないが
俺自身はネトゲーツール作って使おうという思考よりも
技術的な勉強をする為にそれを作ろうっていうのが
どっちかって言うと大きかったな。
それの作成にあたっての動機付け(動機があったほうが頑張るから)
が欲しかったからたまたまやってたネトゲーをターゲットにした感じ。
まあ、ここはそういう議論スレじゃないから以降これに関しての発言はしない。
逆だろ。 升ツール作る為に技術的な勉強をする必要があったんだろ。 まぁ一般的な解凍ツールやブラウザとかは既に便利なものを作ってるヤツがいるからな 自分が利用する便利なツールで世の中に出回ってないものしか作ろうとしたら 真っ黒なツールしかねーんだろうけど。
フックが真っ黒ならTClockすら真っ黒だし 悪用できる技術=悪じゃないでしょ スレ違いも程々にしとけ
犯罪幇助にしか使われなくなったら京都府警がUSER32.DLLを取り締まるから無問題。
>>668 京都府警じゃ信用ならん
神奈川県警にしとけ
フックは夢が広がるから困る
いい加減にしろ
いい加減にしろ
どうもありがとうございました。
フックってなんだよ素人の俺に説明しろ
ヒント:船長
ガッツ石松の左
ワロスw
上岡龍太郎
こんな時間に人がいるとは思えないが。。 リソースファイルを使わずにアイコンをロードして使いたい場合 CreateBitmapを使えばいいんでしょうか? それとも他にアイコン専用のAPIがあるんでしょうか?
意味が分からない。 ファイルから読み込むならLoadImage使え。 作るならCreateIcon使え。
LoadIcon
WinAPIを勉強しようと思いWindowsゲームプログラミングという本を読みながら勉強 してるんですが、この本の通り打ち込んでもエラーでコンパイルできないところ があります。 このソースなんですが何故でしょうか?すみませんが教えてください(´・ω・`) ソフトはPlatformSDKをインストールしてVisual C++ 2005でやっています #include <windows.h> int WINAPI WinMain( HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow ) { BYTE * bytes = "BYTE *"; PBYTE pByte = "PBYTE"; LPBYTE lpByte = "LPBYTE"; MessageBox(NULL , bytes , NULL , MB_OK); MessageBox(NULL , pByte , NULL , MB_OK); MessageBox(NULL , lpByte , NULL , MB_OK); return 0; }
ごめんスレ違いだったのか
>>682 たぶん、コンパイラ設定だろうね。
エラーさらしてみ
>>682 まず質問として何のエラーかを明確にしてくれないと困る。
それのソースはCか?C++か?
Cだとしたら値を代入する前に型宣言を最初に全てやってないと
コンパイル時エラーになったと記憶してるが。
BYTE * bytes = "BYTE *";
PBYTE pByte = "PBYTE";
LPBYTE lpByte = "LPBYTE";
BYTE *byte;
PBYTE pByte;
LPBYTE lpByte;
byte = "BYTE *";
pByte = "PBYTE";
lpByte = "LPBYTE";
※但し、実験してないから間違ってるかもしれん(そこまで保証する義理はないが)
環境がVC2005ならMessageBoxの第二引数の型をキャストしないと警告も出ないか?
> Cだとしたら値を代入する前に型宣言を最初に全てやってないと > コンパイル時エラーになったと記憶してるが。 ブロック冒頭の変数宣言時の初期化する/しないは自由です。 /* cでもOK */ void test() { int n1; int n2 = 1; int n3; int n4 = n2; :
688 :
688 :2007/07/08(日) 11:12:17
>>682 マジレスすると拡張子がcじゃなくてcppだから
俺、2冊も買っちゃったし良本だよな
がんがれ
全部見当違い。 2005のデフォルトのオプションを考えれば分かるだろ。 なんでここはこんなに馬鹿しかいないんだ?
>>690 バカ筆頭の人が言うと、
さすがに迫力がありますね
僕バッカー
底の浅い知識すらも持っていないくせに、 確認すらしないで適当を並べる馬鹿は何とかならないのか?
MessageBoxWが呼ばれてるのかなゃ
コンパイルオプションに/J
>>689 ごめんなさい更新する前に書き込んでしまって見てなかった
まさしくそれでした…
.cに変えたらちゃんとコンパイルしてくれました
これからコツコツ勉強して以降と思います。みなさんありがとうございました
書籍のサポートは作者がやるべきだよな
699 :
689 :2007/07/08(日) 11:37:50
いえーいあたった。 お前らジュース一本だ 690はパンも買って来い
なんでcppじゃダメなん? 上位互換じゃないの?
型チェックが厳しくなってるから
2重引用符で囲った文字列はリードオンリーになるので、 constが必要。 また、BYTEはunsigned char型であって、char型とは別物。 const BYTE* bytes = "BYTE *"; なら通る。 MessageBoxA(NULL, reinterpret_cast<char*>(bytes), NULL, MB_OK); なら通る。
ちゃうわぼけ
>>682 エラーが出ます教えてください
という人に限って、
エラーメッセージを読んでない。
しかも、
エラーメッセージをコピペしない。
エラーメッセージによっては難解だったり、
本当の間違いを指していなかったりするが、
少なくとも
>>693 のtxtのエラーメッセージは、
非常に親切で適切なものだから、
エラーメッセージを読めば分かる。
エラーメッセージって 的を得ないことが多いのと 一般的に言っても不親切なのは なんとかなりませんかね?
中に人が入ってるわけじゃないから 文句言うだけ無駄
>>705 的を得ないならいいじゃないか。的を得たら射掛けられちゃうぞ。
>>705 そりゃぁ、お前さんの書いたコードが「的を得てない」からだろう。
コンパイラが、わけわかんねーぞ、というのは、わけわかんないコードを食わせるからだ。
VC++のエラーメッセージなんて随分質が高いと思うけどねぇ まぁC++でテンプレート絡みのエラーメッセージがイミフなのは そういうもんだとあきらめれ
的をもらいました やったね!
まぁ、エラーメッセージは、直訳みたいなので英語でおkみたいなのはあるw
夜店の射的の話。的は人形だったり。
タブコントロールを作ってそれをデバッグ(@err,hr)でみてたら ERROR_NO_IMPERSONATION_TOKEN 現在、クライアントを偽装していないスレッドが・・・・ とかいうエラーが出てくるんですがこれの意味に心当たりがある方は 教えていただけないでしょうか?
714 :
501 :2007/07/08(日) 17:20:57
会社でよくいそうな堅物っぽいやつが 見当違いとか、知識が無いとか、確認してないとか がんがってかっこつけたのに結果をだされてるのにワロタ いいものを見せてもらった
715 :
501 :2007/07/08(日) 17:23:11
俺の質問も相手してくれよ
717 :
デフォルトの名無しさん :2007/07/08(日) 17:44:20
ウインドウにボタンをはっつけて、 ウインドウのWM_PAINTでBeginPaintしてウインドウを真っ黒に塗りつぶしても、 ボタンは塗りつぶされないのですが なんでかチラチラします、これはどういう仕組みでしょうか?
ボタンはゲイツ仕様だから
そういう仕組みだぼけ
実装に興味があるならwineかReactOSがオヌヌメ 後者のほうが詳細まで追えるからオヌヌメ
その前に基本的なことを勉強
>>717 >>717 がボタンも含めてウィンドウを真っ黒に塗りつぶした後、Windowsがボタンを描いているから。
黒く塗ってあとから書き直したら、そらチラチラするわ。
723 :
デフォルトの名無しさん :2007/07/08(日) 19:50:37
ボタンを塗りつぶすとWINDOWS法違反によって逮捕されますから 辞めた方がいいですよ
>>717 そりゃぁ背景を黒く塗っても、手前にあるボタンは塗られないよ。
ボタンまで黒く塗りたければ、ボタンをオーナードローで黒く濡るべし。
つーか、ボタンがチラチラしない方法が知りたいんじゃないの?
ボタンの所だけクリップ領域から外せばいい
WS_CLIPCHILDREN
Enterで通知がくるIDOKを別の定義IDに切り替えたいんですが 何か方法はありますか? 因みにダイアログじゃないです
IDOKが来たら切り替えたい定義IDをSendする
730 :
728 :2007/07/08(日) 23:06:07
>>729 !?
盲点だったそんな簡単なことも気づかなかったのか俺orz
教えてくれてありがとうございます。
731 :
729 :2007/07/09(月) 00:09:55 BE:99304122-2BP(0)
おいw ジョークだよな?
いいえ本気です
「本気」と書いて「マジ」と読む
734 :
デフォルトの名無しさん :2007/07/09(月) 14:22:56
up
ヘルプみたさに プラットフォームSDK入れてみたんだけど hxsファイルってどうやってみればいいんでしょうか?
ドキュメントエクスプローラー、かな? ついてなかった?
さがしてみます。ありがとう
さがしたけどなかった。次は一時間後にさがしに行くです。
普通に入れたら、スタートメニューに登録されるよ。
すみませんさっき気づきました ぐぐったりVCいれたりといろいろってみましたが まさかこれ系がスタートメニューに登録されるとはorz
USBゲームパッドを使いたい場合はwin32apiでは対応できませんか? やっぱダイレクト系しかないんでしょうか
joyGetPos
いいことおもいついた、お前俺のケツのなかにションベンしろ!
ウホスレは間に合ってます
>>742 ありがとうございます
これマルチメディアの欄にあったりして
なかなか見つからない
Windows3.0 MMEを思い出した
>>745 マルチメディアAPIのジョイスティックAPIはゲームポート接続想定した仕様だからおすすめできない。
(認識軸数、ボタン数に制限)
>>747 アナログ6軸、ハットスイッチ1つ、32ボタン対応してるから十分だと思うが。
突然だけどLocalFreeって使わない方がいいのか? LocalFree使うぐらいならHeapAllocとか使った方がいいとか言う 記事があったもんで。それとHeapAllocとVirtualAllocの使いどころは 大体確保するメモリがどのくらいを目安にすればいいのかね。 そういうレス見たこと無いから参考までにお前さん方の意見聞いてみたい。 因みに俺はLocalAllocが簡単に使えるからそっち使ってる。 後mallocに関してはAPIじゃない(最終的にHeapAlloc呼んでるみたいだが) から省いてくれい。
>LocalFree使うぐらいならHeapAllocとか使った方がいいとか言う記事 なんだその腐った記事。
なんとなく気になってCRTのソース読んでみたのだが、 VC2005のリリース版CRTのmallocは、HeapAllocに直結してるのな。 CRT内部で改めて分割して使っていると思い込んでたよ。
754 :
デフォルトの名無しさん :2007/07/12(木) 00:11:18
crt no source ha iduko?
>>754 Visual C++ならVisual C++のフォルダ(bin, include, libなどがあるフォルダ)
にあるcrtというフォルダ。ただし、Expressには付属していない。
GlobalAllocとLocalAllocの違いがわからない
Win16では、nearポインタ・farポインタの違いがあったが、 Win32では違いなし。 もしかしたら9xではだめかもしれないが、 NTでは、GlobalAllocしたものをLocalFreeすることすら可能なはず。
Windows 3.1 SDK のヘルプからコピペしてみた。Win32では殆ど無意味だけど。 Global memory is all memory in the system that has not been allocated by an application or reserved by the system. Local memory is the memory in the data segment of a Windows application.
LocalAllocは内部でHeapAllocと同じ事してるんだろ確か
ぶっちゃけ、何かの理由がない限り、 HeapCreate()の引数dwMaximumSizeには0を指定するわけで、 ということは、HeapAlloc()で巨大なメモリを確保しようとしたら、 自動的にVirtualAllocに飛ばされるわけで、 意識してVirtualAllocを呼ばなくてもいいんじゃないかな。 それどころか、C++ なら 何か理由がない限り、new 一択だろう。 もしヒープの速度がネックになるようなら、 ヒープ上ではなくスタック上に取れるようなアルゴリズムを検討すべき。 自分は遅いプログラムのチューニングをしていて、 ヒープの速度がネックになっているのを見たことがないよ。
762 :
デフォルトの名無しさん :2007/07/12(木) 08:28:40
>>755 thank u. express dakara nakata
Local/GlobalAllocって、戻り値が専用型なもんで、「解放する方法が明確に解る」 って理由で外部にAPI公開するDLLなんかでは採用してる例がある。 確かにポインタだけ返して「解放はVirtualFreeで」とかいう仕様だと勘違いで 他の解放関数に渡してしまうケースが無いともいえない。
>>761 >自分は遅いプログラムのチューニングをしていて、
>ヒープの速度がネックになっているのを見たことがないよ。
漏れもそんなのは見たことないが、malloc/free 系と memcpy 系の
関数を差し替えるのは、ほとんど手間がかからずある程度の効果が
期待できるのでまず手始めにやっちゃうな。
そんな怪しい挙動するくらいなら、解放するAPI用意したほうがいいと思うんだけどなぁ・・・
IMalloc/CoTaskMemAllocはどうよ
COM のときは使うな CoTaskMemAlloc 。
>>761 それはプロファイラに捕捉されてないだけだと思うぞ。
ヒープは頻繁に呼ばれるので、僅かなコストが積もって大きくなる。
InitializeCriticalSectionAndSpinCount()のスピンカウントの説明を読めば片鱗が知れよう。
とはいえ、下手なアルゴリズムやコーディングによる遅さに比べれば、微々たるものだが。
カーソルの影って、APIでオンオフはできるんですけど、そもそもシステムカーソルにしか 適用されませんよね。 とあるアプリで独自のカーソルにも影が付くのがあったんで、リソースを見てみましたけど 元カーソルは影付きではありませんでした。 影を付けるAPIみたいなのはあるんでしょうか?
>>770 gccやglibcにパフォーマンスを要求すること自体が間違ってる。
ポータブルでフリーであることが目的で、ちゃんと動けば十分という代物なんだから。
ついでに言うと、
unixの世界ではプロセスをポコポコforkする文化が長かったし、
フリーのOSはSMP性能が悪いのが普通だった。
パフォーマンスよりも、動くこと、簡単なことが優先されてた。
バグの原因になるのでmallocしたメモリはfreeするな
なんて真顔で言う連中が跋扈していた世界だから。
>>771 過去がどうであれ、今それを真顔で言われてもわりと困るんだが。
要は、Linuxの世界は後発であるが故に遅れている、ということ。 もちろんLinux上で走るからといって、glibcを使う必要はないわけで、 フリーだろうがプロプライエタリだろうが、別のライブラリを使えばいいだけのこと。 ただ、何でもかんでも別のライブラリを使うのが良いとは限らない。 Windowsのバージョンが上がると、 MSVCRTやOSのヒープマネージャが、 より現状のPC環境に向いたものに変るので。
Unixについて言ってるのかLinuxについて言ってるのかはっきりしろと。
ていうかスレ違い
IDEのバスをリセットする(RESET#端子をアサートする)方法を教えてください。 IDEのデバイスに対してDEVICE RESETコマンドを送ることはできたのですが、 いざデバイスがハングアップした状態では、コマンドも受けとってもらえないわけで。
Documents and Settings\ユーザー名\NTUSER.DATとかの OS可動中に開けないファイルを読み込み専用で良いので 開く方法を教えてください。 破壊がないか定期的にチェックをしたいので。
ACPIが有効なPC上で、CPU温度を定期的に取得する方法を教えてください。 以下のvbsを実行すれば温度を取得できるのですが、 一定間隔で実行しても温度に変化がありません。 (OS起動時に一度だけ取得してる様に見える) なんとか更新させるか、別の方法がないか探してます。 cputemp.vbs------------------------------ Set fs = CreateObject("Scripting.FileSystemObject") Set outFile = fs.CreateTextFile("CPUtemp.txt", True) Set wbemServices = GetObject("winmgmts:" & "\\localhost\root\wmi") Set wbemObjectSet = wbemServices.InstancesOf("MSAcpi_ThermalZoneTemperature") For each Item in wbemObjectSet outFile.WriteLine "CPU Temperature: " & (Item.CurrentTemperature - 2732) / 10 & "°C" Next outFile.Close cputemp.vbs------------------------------
779 :
デフォルトの名無しさん :2007/07/12(木) 21:15:07
みんなやたら高度だな
PatchGuardてIATへの書き込みもガードするんですか? カーネル領域でないのにガードされるんですか?(´;ω;`) 教えてエロい人(´・ω・`)
>>777 2003 Server以降なら、シャドー・コピーという手がある。
XPの場合はAPIとして表には出ていないがntbackupが使っている。
ダサい方法だが、ntbackupを子プロセスとしてキックして、
目的のファイルにバックアップ取って、
すぐさまntbackupで別の場所にリストアするという手がある。
ちなみに、
CreateFileでFILE_FLAG_BACKUP_SEMANTICSつけてダメだった?
>>781 色々ありがとうございます。
SE_BACKUP_NAME、SE_RESTORE_NAMEの特権を取得した後、
{ HANDLE h;
h = CreateFile("C:\\Documents and Settings\\user\\NTUSER.DAT"
,GENERIC_READ
,FILE_SHARE_READ
,0
,OPEN_EXISTING
,FILE_FLAG_BACKUP_SEMANTICS // FILE_ATTRIBUTE_NORMAL|
,0
);
if (h != INVALID_HANDLE_VALUE) {
printf("pass\n");
CloseHandle(h);
} else {
printf("ng\n");
}
}
の様にしましたがダメでした。
ntbackupの方法も検討してみます。
ちなみにGetLastErrorのコードは CreateFile 20h:プロセスはファイルにアクセスできません。別のプロセスが使用 中です。 でした。
FILE_SHARE_WRITEとFILE_SHARE_DELETEも付けたほうがいいよ。
FILE_SHARE_WIFEとFILE_SHARE_DAUGHTERもつけたほうがいいよ
786 :
784 :2007/07/12(木) 22:40:26
MSDNライブラリのCreateFileのFILE_SHARE何とかのところには、 "Subsequent open operations"と書かれているけど、 それは自分が一番最初にCreateFileする時の話で誤解がある。 実際には、同時にオープンする他者全員に対しての許可なので、 FILE_SHARE_WRITEを付けない = 許可しない場合には、 すでにWRITE有りでオープンしている人がいると、エラーになる。
>>781 ntbackupでバックアップ/別フォルダへのリストアに成功しました。
コマンドラインオプションから指示を出せる様なので、
この方法でできそうです。
ありがとうございました。
>>784 ,FILE_SHARE_DELETE|FILE_SHARE_WRITE|FILE_SHARE_READ
としましたが同じエラーでした。
>>777 そんなこと聞く人が破壊がないかチェックなんてできるの?
楽勝だよ
791 :
778 :2007/07/12(木) 23:26:06
>>778 お願いします。
できないと死にそうです。
出来ないと死にそうなくらい、ヤバい温度になるのか?
>>789 たぶんレジストリの内容をまとめて盗むスパイウェアでも作ってるんだろう。
>>791 自分だったらACPIではなく、SMBus(I2C)で温度センサーの値を読むが。
794 :
デフォルトの名無しさん :2007/07/12(木) 23:46:24
>>792 部屋が灼熱地獄なんです
熱中症になる前にお願いします
>>761 標準の new は、小さなサイズの要求を大量に行うと、
メモリを無駄に使用してしまう。
数年前でも2GBのメモリ空間はかなり窮屈で
無駄にされるとかなり痛いので、
自前のアロケータを書いたことがある。
>>793 何故ですか?
センサー毎にハードコーティング要るんじゃかったですか?
そんな馬鹿馬鹿しい事やってられません
797 :
793 :2007/07/12(木) 23:56:49
>>796 SpeedFanやEverestなどのメジャーなツールが取っている手段だから。
できるかどうかわからない方法を調べるよりは、
できることがわかっている方法を調べるほうがいいでしょ。
>>793 >SMBus(I2C)で温度センサーの値を読むが。
どのようにするのですか?
なんか、デバドラ作らないと出来ないような気がしますが、
簡単にAPIで値読めるのですか?
>>795 数年前なら、64ビットが選択肢に入ってたろうに。
自分ならまず設計を見直すよ。
大量にnewするオブジェクトたちが、本当に個別に寿命管理が必要なのか、と。
Boost.Pool最強説
801 :
795 :2007/07/13(金) 00:20:51
>>799 漏れは、マシンもOSも調達されてから投入されたので、
64bit化しようとは、流石にいえない。
そもそも、実装されるメモリの量も余裕は無かったし。
個別の寿命管理は確実に必要だったと今振り返っても思うよ。
つーか温度計る手段がいまだに規格化されてないってのがアホだよな
WMIで得られる筈が
>>778 みたいな半端な物で形骸化してるみたいだし
今ではデスクトップPCでさえサスペンド/レジュームする時代なんだぜ
>>787 もしVistaで動かす予定があるならntbackupは廃止されたから
まじめにボリュームシャドウコピーを使う方法も併用する必要がある
>>802 計測ってより計測法でも利権が絡むからね。
>>801 それは、
何かよほどのこと
って奴だったんだよ、たぶん。
ラージアドレス(/3GB)を使ってもアドレス空間が足りないが、
かといってPAEなんて使いたくないという場合には、
いっそのことプロセスを分けてしまうという手もある。
プロセスを跨ぐオーバーヘッドが巨大だけどね。
>>806 強引な荒技もあるよ。
デフラグのAPIを使ってファイルのディスク上の所在を調べて、そこを直に読んでしまうという手もある。
もちろん、そんな行儀の悪いことは、よほどの理由がないとダメだが。
810 :
デフォルトの名無しさん :2007/07/13(金) 17:13:50
CreateProcessでCREATE_SUSPENDEDを利用してNotepad.exeを起動して、 とまってるときのMessageBoxAとMessageBoxWのアドレスと、 その後、ResumeThreadした後のMessageBoxAとMessageBoxWのアドレスが違うような気がするんですけど、 これって気のせいですか?
DefineDosDevice()で、特定のフォルダを新規ドライブとしてマウントできるけど、 そのとき、元のフォルダのほうをACLなりEFSなりで自プロセス以外から見えなくすることは可能?
>>810 CREATE_SUSPENDEDで作成されたプロセスは初期化が完了している保証は無い
むしろ初期化終わってないのが普通じゃない? この段階だとGetModuleFileNameExのようなAPIが失敗するもんで、 どうやってこの初期化だけを完了させるのか知りたかったりする (forでResume/sleep/Suspendを細切れにしてまわしてた)
PEヘッダ解析して、PE.EntryPointのアドレスを書き換えるか、 ブレークポイントをしかけておくってのはどうだい?
CREATE_SUSPENDEDで止まっているときに色々やるのはオススメしない。 Windowsのサービスパックで挙動が変るのならまだしも、 WindowsUpdateで配られるモジュールのアップデートで挙動が変ってしまうから。 安全なのはプロセスのエントリポイントを乗っとること。
なるほど。 こういうことやってるから、環境依存・OS依存で動かなくなるんだな。
そういや、WindowsUpdateしたら動かなくなった、APIフックしてるプログラムがあったな。
再起動したらなおるんじゃないかな
短径の透明の度合いをいじりたいです BitBltで透明度50%なら出来るんですが、 透明の度合いをいじる方法が思いつきません・・・何かありますでしょうか?
DIB使うのが手っ取り早い気がする コピー先とコピー元のビットデータを取得してブレンドしてから元々のコピー先に転送 それが嫌なら255*アルファ値%でグレースケールに塗ったデバイスコンテキストを用意して グレーのDCとコピー元をAndコピー、 グレーのDCを反転してコピー先にAndコピー、 最後にコピー先とコピー元をOrコピー
>>814 サンクス!
ブレーク作るって発想はなかった(ポピュラーな方法らしいね)
これだと向こうのプロセスから自発的に発信してくれるんで、かなりスマートに実装できるんだな
823 :
デフォルトの名無しさん :2007/07/14(土) 07:09:35
コナンキターwすごい推理力だ
そういうことだったのか! なぞが解けてすっきりした。
826 :
デフォルトの名無しさん :2007/07/14(土) 10:26:42
短小包茎なんですがどうしたら直りますか?
直りません
>>815 はじめてしった。
プログラムの先頭でGetProcAddressとかして関数アドレスとってるプログラムとかの
APIフックはプロセス作成した直後ではできないのか。勉強になった。
名探偵コナンだけどなにか質問ある?
>>828 GetProcAddressフックしろ。
すれ違いな気がするが、どこに投稿して良いやらわからないので。 MPEGファイルのフォーマット、特にオーディオがAC3かLayer1~3を 知るためのAPIってありますかね?
832 :
デフォルトの名無しさん :2007/07/14(土) 13:54:50
>>829 どうやって犯人いや
短径トリックを見破ったのですか?
>>830 CreateProcess直後のSupend中だとできないんでないの?
質問です。 AVIのビットレートやピクセルのビット深度を取得するには AVIFileInfoを使用してAVIFILEINFOを取得すればいいのでしょうか?
836 :
835 :2007/07/14(土) 17:14:46
すいません、あと、ARGBなのかRGBなのかも知りたいのですが、 どのAPIを使えばいいでしょうか?
AVIって実態はただのコンテナだから微妙じゃね コーデック無いと再生できないって事は一つの方法では内部データが読めないって事だろ データヘッダは読めてもストリーム内の情報は読めないと思う
>>835 DirectShow
それが面倒だというのなら、真空波動研のDLLでも使いなされ。
>>837 一応再生できる物なのですが…
コンテナの中には格納されていないんですかね?
>>838 DirectShowですか…
今までマネージドコードしかさわったことがないので
いきなりそれは無理かも…
まだこういったことをするには経験が浅すぎるみたいなので
もう少し勉強してから出直してきます。
ありがとうございました。
840 :
デフォルトの名無しさん :2007/07/14(土) 23:30:35
画面のプロパティ-デザイン の中にあるタイトルバーやメニューやスクロールバーのサイズなどはどこに保存されているのでしょうか? プログラムで参照したくて、ググったりしけど一向に出てくる気配がないので質問しました。 レジストリ内のどこかだと思うのですが・・・。 かなり基本的な質問で申し訳ないですが教えてやってくださいませ。
とあるプログラムでA.DLLとB.DLLを使っていてB.DLLからA.DLLを使っています そのプログラムの終了時にA.DLL、B.DLLの順に開放されるようで B.DLLのデタッチ時にA.DLLのリソースを使おうとしたときに A.DLLはすでに開放されているのでアクセスエラーになります 動的にロードして動的に開放順をきめれば問題が解決できるのですが それができない場合でプロセス終了時のDLLの開放順を決めるAPIとか方法はありますか
HKEY_CURRENT_USER\Control Panel\Desktop\WindowMetrics いまどきじゃVisualStyleファイルの中の場合もあるけど
>>841 そんな都合の良いAPIがあるかどうかは知らんが、
Advanced Windows改訂第4版の「22.9 APIフック: 例」にそれと全く同じ状況の話が載っている。
著者Jeffrey RichterはAPIフックを使ってExitProcessをフックして解決したそうな。
>>841 B が A を import してるんなら開放されることは無いんじゃない?
dll の書き方がまずいよ。
>>840 SystemParametersInfo
GetSystemMetrics
GetSysColor
>>843 呼んでみました。似たような状況です
解決法として自分でLoadLibraryしてFreeLibraryする順を制御するか
GetModuleHandleして既にいなくなっているかどうかを確認する方法をつかっていますが
自分で都合よく制御できる方法はないかなぁと
>>844 BはAをLoadLibraryしてGetProcAddressで関数ポインタを保存して呼んでいます
しかしながらプロセス終了時にはAから先に開放されてしまっています
何度やっても一緒でした=なにか法則がある=その法則を変更できるかなぁとおもっています
開放されているかどうかはAのデタッチ時にデバッグメッセージを出して確認しています
>> 842 >> 845 蟻が㌧
>>844 LoadLibraryした奴はFreeLibraryしようぜ
849 :
848 :2007/07/15(日) 00:38:05
参照カウンタの原理から言って、 後からロードされたのが先に開放されるのは道理なんじゃないか?
>>841 B.DLLからA.DLLをLoadLibraryするってのは駄目なの?
静的リンクされていても、LoadLibraryで参照カウンタを1つ上げておくってこと。
~Library系はAttach/Detach中に呼んじゃいけないんだよ
EXE→Bはインポートテーブルにのっとったリンクで
B→AはBがロードされた時に明示的にLoadLibraryでリンクされてるって事?
だったらEXEがAを解放するってのはありえない処理だと思うんだけど…
>>841 の問題を解決したいなら
EXEの方でBを明示的にロードしてEXEの終了前にFreeすりゃいいとも思う。
ラッパプログラミングでEXEの挙動を制御できないってなら話は変わってくるけど
>>844 そもそもDLLの依存関係はツリーじゃなくて循環が起きうる有向グラフなので
ノード操作時には非常に強い制約をもうけないとどうしようもない。
OSもがんばりはするけど、理想的な解放順序は常には期待できないよ。
んで結果としてDllMainではkernel32.dll以外のDLLの存在を期待するなということになっている。
一方で、DllMainがアンロード時に呼ばれるのを利用して
自DLL内で作ったリソースの解放処理を行う実装も結構多いためややこしい。
この2つが組み合わさると今回みたいな問題が起きる。
例えばDLL内にC++のグローバル変数を置くとき、
そのデストラクタが呼び出す処理はkernel32.dll以外のDLLに依存してはならない。
(厳密にはコンパイラとランタイムライブラリに依存する話だろうけど)
んで、今回ルールを破っているのは、
(おそらく終了処理で)別のDLLを呼んでしまっているB.DLLなので文句は言えないんじゃなかろうか。
一応有名なルールのはずだし。
たとえ結果が「OSとしてありえない処理」にみえたとしても。
855 :
819 :2007/07/15(日) 07:23:50
>>820 かなり自分自身まだ理解出来てないけどそれでやってみます!
>>825 検索にヒットしませんでしたorz
>>852 それって、循環参照で無限ループになる可能性があるから
呼ぶべきではないって話で、呼べないわけじゃないんじゃない?
ProxyDLLはAttachProcessでLoadLibraryするのが普通だと思うけど。
>>852 呼べることは呼べるし、実際それやってくれる困ったAPIフックのソースコードも見たことあるけど
かといって普通と言っていいほど安全じゃないと思うけどな。
Advanced WindowsでもDllMain中でのLoadLibraryは循環が起きることがあるから避けろって書いた上で
実際API HookのサンプルでもAttachProcess中のLoadLibraryはやってない。
というか別にAttachProcess中で別のDLLロードしなくても、遅延ロード使えばいいんでは?
あと循環で困るのは無限ループというよりはローダーロックがやばいんじゃないかと思う。
本来DllMainは同時に1つしか走らないはずなので。
ローダーロックは問題ないかと。 同一スレッドならブロックしない仕様だから。
APIでUnicodeな入力をできるWindowを作るにはどうしたらいいでしょうか。
-DUNICODE
>>860 UNICODEオプションはMFCのおまじないだと思うんですが、
Win32APIでウインドウの作り方は、どうなりますか。
-D_UNICODE_
それは、MFCのおまじないなんぞではない。 れっきとしたWin32API用のもの。 だからMFCでも引きづられて使用可能というだけ。 ちなみに、860と862の両方が要るぞ。
げ、862は-D_UNICODEかと思ったら後ろの一文字が余計だ。 -D_UNICODEに読み替えてやれ。
Win32API → UNICODE CランタイムとかMFC → _UNICODE なんで分かれてるんだよぉ。
__UNICODEとかは?
俺は、UNICODEと_UNICODEを両方定義するが?
ウニコード
grep初感だけど、 tchar.h絡みは_UNICODEで その他はUNICODEみたいだなー
>>869 ,ll/ /lll /lll | | | | | | | | | | | '''''l||l l||l l||l/ ./ /
.'リ| | /lll /lll | | | | | | | |`‐|┼!┼|‐| | | / / / ̄`/
.:l|\| |lll /lll | | | | | | | | || |_|// | | // / /
.:l||/ | |lll |lll| | | | | | ,| | | |. | ,イ::::::ヾ'| | | / / /
l|/ | |lll |llll | | | |/| | | ′ 弋:::ン// |// /.,,
`ヽ,、., \|lll |llll || | |/ |_ _| | \ /,,,,,_. | /l
`゙| `゚'゙/llll゙|/| '| /:::::ヽ """ / /__ /\|,,//
゚!、 /llll゙,ン \゙x 弋:::ン ` _ |∠'' ((,,(..,,,. '''''
\|llレ'/== ゙'\ 丶 ) | _ ∨'' _ _____,,、
/ (__ ,,,,/ ゙'フ" ,/ ヤr―-''''''""""¨ |_
(⌒ 、)/./ ,, ̄/``:゙゚'ヶv ,, -‐'''ソ l l ,-‐-`.、
 ̄)) \ ''''',' ,/ /-== - ~l´ ,.'-‐-、 ×ウニコード ,=ニヾ||l l||l |l:
 ̄  ̄/ ヽ、,′ | `、 〈_,.rニ=、 ,ニ=d λ ̄``|||
/、 | .| \/( r_rk=ニ、○ユニコード >‐-.、_ r .:ll l||
/:: ::\ \/ | | /|||l λ _,.-‐く "''‐-、._).!||i'//
\:: ::\ 、 | | ̄ ̄ K_,.-‐''" | /|lll/ /
/ | `、 |__,,,......--―─=''''''''フ''''''''.::l||/ /
`、 \ \ | .`、 ` .||l: . l||/ /
誰だこいつ
雲丹cord
WinMain内のメッセージループで int msg[8]; while(GetMessage((MSG *)msg,hWnd,0,0)!= -1){ if(msg[1] == 15){ ... と処理をしているコードを発見しました。 この場合の msg[1]は何を指してるんでしょうか?? どなたかご存知の方、教えてください・・・。
16/32bit版では、MSG msgとしたときの、msg.messageと同じ。
7行プログラミングとか3行プログラミングとか 構造体の定義をうだうだ書いてられないときにそうなる
ネイティブなUnicodeのウィンドウなら、
RegisterClassW/RegisterClassExWで登録したクラスを元にウィンドウを作成、
というのが答えなんだけどなあ。
9x系含めてUnicodeな入力って話なら以下の所が詳しそう。
ttp://www.honet.ne.jp/~tri/ の「プログラムの小ネタ」
とりあえずRichEdit2.0以降を使っとけってことか?
878 :
874 :2007/07/16(月) 00:55:27
LocalAllocとCoTaskMemAllocの違いってなによ つーかCOMタスクアロケーターってなによ
CoTaskMemAllocはCOM用 IMallocインターフェイスを関数として利用するもの
その時点でMSGは既知だから、 素直にMSG使っとけって話じゃまいか。
>>884 定義済みなら始めから
MSG msg;
って書かけばいいのにって事でしょ
>>881 LocalAlloc=GlobalAlloc
COMタスクアロケーターはCOMのメモリ管理機能だと思っとけ
>>876 に対して
MSG構造体を定義している事が言いたいんじゃないか
ム板でこれだけレスが付けば 人気にSHIT!って言っていいんだろうか
889 :
887 :2007/07/17(火) 00:25:02
俺はリロードし忘れただけだから
890 :
884 :2007/07/17(火) 00:26:16
安価おいしいです
891 :
デフォルトの名無しさん :2007/07/17(火) 00:29:08
VisualStudio.NET 2003 C++ XP 質問です システムのミキサーの音量設定をプログラムから調整するにはどんなAPIを使ったらいいんでしょうか?。どなたかお願いしますm(__)m
>>881 COMの基本を少し勉強することをお勧めする。急がば回れだ。
>>882 > IMallocインターフェイス
そういう言い方、やめようよ。
インタフェース自体は何の機能も持たずプロトコルでしかなく、
誰でもIMallocインタフェースを持つことが可能なんだからさ。
あるCOMタスク・アロケータ・オブジェクトのIMalloc::Alloc()で確保したものを、
別のCOMタスク・アロケータ・オブジェクトのIMalloc::Free()で解放してはいけないことくらい、わかるでしょう。
>>891 mixerSetControlDetails
COMはちゃんと勉強しないとイミフだからな
>>885-887 msg.message, msg.wParam, msg.hwnd て書くより
msg[1], msg[2], *msg のほうが短いんじゃね?
短くていいならa[0],a[1]とかでいいだろ ソースはわかりやすさが大切
>>897 そんなこと言ったら、構造体なんていらないな。
本当に短くしたいのなら != -1 も要らなそうだな。 GetMessage() が -1 を返すのは引数が無効な場合だけだし。
COMに未来は無い
MANに未来はある
>>901 COMなんて簡単だろ。
C++のクラスをDLLでexportする時に発生する数々の問題点を解決しつつ、
VBとC++の橋渡しをする、ただの呼び出し規約みたいなものだから。
Win32APIでも、COMのものがたくさん有るでしょう。
COMは避けては通れないのです。
使う手順が面倒だと言うなら、VBを使うとか、
.NETからCOMインターロップを経由して使えばいい。
#importして_com_ptr_tとか利用して「使う」だけなら楽だが コンパイラサポートなしで使うのはマンドいな 「使う」んじゃなくて「作る」のは超マンドいな まあ今更COM「作る」仕事はあまり無いだろうし どんどん減っていくだろうけどな
ATL使うようになって作るのも使うのもだいぶ楽にはなった コンパイラ互換性が問題だが・・・
>903 済みませんが、COMのスレッディングモデルと アパートメントについて、解説をよろしくお願いいたします。 フリースレッドマーシャラは、結局何をマーシャリングするんですか?
いわゆる共有フォルダってたまに見えなくなったりしますが、 そういうときの対策ってアプリレベルでやるべきですか?
当然です
見えなくなった共有リソースに対して、 FindFirstFileとかやっちゃった日には、当分帰って来なくなるんですが、 10秒ぐらいでタイムアウトさせる方法ないですか?
>>906 まずはCOMの話ではなく、
マルチスレッドのプログラムにおける問題点とベストプラクティス
について勉強することをお勧めする。
さすれば、COMのスレッド周りの話も、解説本を1冊読むだけで理解できる。
>>909 そうです。そういう問題をどうすればいいのかわからなかったんです。
>>909 FindFirstFileをワーカースレッドでやればいいんじゃない
GetStdHandleで取得したハンドルは最後にCloseHandleしなければいけないのでしょうか?
WNetGetConnection NetUseXXX あたりを見れ。
開いているハンドルはプロセス終了とともに閉じられるので、 閉じる必要はない。malloc&free。
>>913 もちろん、
アプリが終了すれば勝手に閉じられるけど
使わなくなった時点でするのが常識
ファイルアクセスすべてをスレッド化すると大変だし そこまでやってるの?
CloseHandleもアンチウイルスに捕まるので、別スレッドで。
>>917 ソケットを使ってローレベルでやるより簡単じゃん
他にもっといい方法があると思うならもうちょっとレスを待ちな
>>921 いや、俺のほうが頭いいに決まってるだろ?
FindFirstFileでは仕方がないけど、 単に読み書きするだけなら、 非同期IOにするとどうなの?
いや結局、FindFirstFile相当がすぐ応答を返せるかどうかだから
>>912 がベストと俺は判断した
>>914 は多分ネットワーク名取得してping打ってどうこう、
みたいなややこしい事させるんだろうけど、それが一通り
うまくいった所で、FindFirstFileが応答するかどうかは判らんしな
>>913 閉じるのはかまわないけど、以降標準出力が出来なくなるから普通はCloseしないと思う
3種類のStdHandleはプロセスの開始時に特定のアドレスで初期化される
でもってGetStdHandleはそれを参照するだけっぽい
>>924 すごい判断力です
言われてる事ももっともです
尊敬します
>>924 物事の本質を捉えた、良い意見だな。
まさにプロフェッショナルだ。
>>924 その明快な決断力に敬服する
ぜひ政治家になって世の中を正してくれ
>>917 たいていは、UIなどスレッドを長時間停められない部分と、そうでない部分の2つに分けるだけで事足りる。
>>919 なんでソケットが出てくるの
>>924 なんでpingなんか撃つのさ。
接続状態を見るんだよ。
コマンドプロンプトで、net use って打ってみなよ。
>コマンドプロンプトで、net use って打ってみなよ。 だったら始めからそう書いてよ ちなみにNetUseXXXって何?
>>932 NetUseGetInfo
NetUseEnum
好きなほうをどうぞ。
935 :
デフォルトの名無しさん :2007/07/17(火) 23:40:19
このURLでCreateRemoteThreadをつかってLoadLibraryとFreeLibraryとGetModuleHandleを別のプロセス上で実行してるけど、
GetProcAddressとかも実行できますか?
ttp://www.geocities.co.jp/egggarden/win32api/download/DllInjection.cpp.txt Kernel32のアドレスが固定で、上記3つの関数の引数のサイズがPVOIDに入りきりCreateRemoteThread経由で実行できていると思っているので、
GetProcAddressは引数が2つあるんでできないと考えていますし、
Kernel32とかのアドレスが固定でない自分でつくったDLLの関数は再配置されてしまっていると、
アクセス違反が起こってしまうと考えています。
おっと、その質問には答えられない。
そんなあやしい技術はよそで聞いた方がいいと思うぞ
Wizard Bible でも嫁
知ってることだとつい口を挟みたくなるのも分かるが、 そういうのに手を貸すべきではないと思う どうせネットゲームのチートに使うのだろうから
>>925 おお、そうだったのか。
ものすごく貴重な意見を聞いた。
ありがとうございます。
DLLインジェクションはチートっつうよりキーロガーとかトロイに使ったりするな あやしいのは同じだけど
.
エクスプローラで選択したファイルの拡張子を含めた名前を取得したいんですけど どうやったらできるでしょうか? LVM_GETITEMTEXTだと拡張子を表示しない設定にしている場合など、同じ名前になってしまいます。 LVITEMのlParamあたりにそのような情報が入っていそうなんですが、ご存じの方いましたら教えて下さい。
>>944 たぶんオレには応えられないと思うが、レス付きやすいように聞いてやる。
>エクスプローラで選択
ってお前が開発していると思われるプロセスと
別のプロセス(Windowsのメニューからとか)で立ち上がる
エクスプローラのことを言っているのか?
946 :
944 :2007/07/18(水) 01:56:41
はい。デスクトップのファイルや、 初めから入っているexplorer.exeでフォルダを開いた時のファイルについてです。
>>944 XPまでならLVITEM.lParamにPIDLが入ってた希ガス
それがPIDLだと書いてあるところはなかったと思うけど
とりあえず確かめてみるとたしかにPIDLが入ってる。
ただしただし9x系は知らない。VistaではNULL。
まじでやるならCOMの世界だな。
IShellView.GetItemObjectとか。
スクリプト等からならIShellFolderViewDual.SelectedItemsとかかな
948 :
944 :2007/07/18(水) 02:45:39
マジでPIDLが入ってました!ちょっと感動して涙が出ました。ありがとうございました!
スタートメニューについて教えて下さい。XP&Spy++で確認しておりますが、 クラシックスタートメニューのプログラム(P)を開いたメニューアイテムの選択を切り替えた時、 TB_COMMANDTOINDEXやTB_SETHOTITEMが飛んで来るのですが、indexが1のままです。 選択されたメニューアイテムの情報を入手したい場合どうすればよろしいでしょうか?
>>935 自分でDLL作って読み込ませればなんでもできるだろ。
再配置?ヴァカ?実際にやってみろ。
>>938 リモート先のGetProcAddress実行はCreateRemoteThreadのThreadProcと引数のサイズが違うからできないとおもってます。
>>939 よみました。AdvancedWindowsと「別のプロセスにコードを割り込ませる3つの方法」もよんでみました。
>>940 違います。DLLとプロセスの勉強。ネットゲームとかはこういう割り込みとかできないように工夫してあると聞いています。
>>942 あやしいけど知りたいってのないですか?
>>950 DLLつくってATTACHするときにメモリ経由で値の受け渡ししたりとかスレッド起こしてAPI呼んでみたり方法ならやってみました。
今回やりたいことはCreateRemoteThreadだけで他のプロセス上のAPIをゴリゴリと呼び出して値がとれるかです。
>再配置?ヴァカ?実際にやってみろ。
すでに同一ロード位置にDLLがいたら再配置で別のアドレスに移動して自分のアドレスと同位置に関数がいないので呼び出せないと考えてみました。
できるみたいなので試してどういう仕組みになっているか調べてみます。
952 :
デフォルトの名無しさん :2007/07/18(水) 09:41:39 BE:1191643586-2BP(5)
まあこんな事を聞くレベルじゃネトゲのチートツールなんて作れんよ いちいち過剰反応しすぎだっつーの
同じようにやましい事をしようとした経験があるんだろ。
実際、質問の内容じゃなくて、質問の“仕方”でやりたいことはだいたいわかるw
マビノギすれでやってください><
>>952-953 同意
初歩のレベルもいってないのにプロの対応入ってるコードをさわることなどできるわけもなし
だれだ
>このスレを見ている人はこんなスレも見ています。(ver 0.20)
>→○●○2時間サスペンス総合スレ●○● 第16崖 [テレビドラマ]
>>950 たまたま再配置されてないだけ、なんていうこともあるから、
やってみて動いたらOKというのは、駄目だと思う。
再配置されようが、されなかろうが、それに関係なく、
モジュールのロードされたアドレスを調べてから呼べばいい。
>>950 ためしてみました。同一初期位置が指定されているDLLがすでに存在すると別のアドレスに移動されているため、
同一アドレスにあるとおもってローカルでGetProcAddressした位置をCreateRemoteThreadで呼び出すと落ちました。
OLLYDBGでモジュールのロード位置も確認しました。
>>958 リモートのプロセスの再配置位置を調べるということでEnumProcessModulesからBaseOfAddressを調べて、
ローカルのプロセスとの差分をとって呼び出したら再配置に関係なく呼び出せました。
デバッグ情報をみているとLoadLibraryでかえってくる値はEnumProcessModulesでとれるBaseOfAddressと同一なので、
EnumProcessModulesは必要ないかもしれません。
CreateRemoteThreadでThreadProcと一緒のサイズでない引数の関数を呼び出せるかどうかがわからないところです。
勉強なんでCreateRemoteThreadだけでなんとかできないかというのが目標です。
できなさそうなんで、WriteProcessMemoryで構造体渡して、構造体の情報を元に実行する関数をDllに忍ばせればいいかなあと思ったりしてます。
いろいろ教えてもらってありがとうございます。
CreateRemoteThreadでLoadLibraryが呼び出せるのは、引数や戻り値のサイズが同じということ以外に 「kernel32.dllのAPIのアドレスは再配置されない」という仕様が決まっているから。 それ以外の自前DLLでやりたいならまずLoadLibraryで注入してから相手先プロセス上のコードでやれ。
すみません、少し困っています Win32API入門のコモンコントロールの 6.ファイル選択 での最初のソース ファイルの選択ダイアログなのですが 起動後右クリックしても実行結果のようなダイアログ自体が出ません 打ち間違いかと思いコピペしても同じ結果で その後のSetWindowText()は機能しているようなのですが ダイアログ自体が出ない原因が分かりません 機種はWin98SEでBCCを使っています、よろしくお願いします
>>960 再配置されても、
>>958 が教えてくれたとおり、再配置位置をしらべれば実行できますよ。
実際に再配置を起こして試してみました。
CreateRemoteThreadでThreadProcと一緒のサイズの引数でないと呼べそうに無いですね。ありがとうございました。
_cdeclと_stdcallの挙動の違いを調べれば何故引数が違うのを渡せないかが解るはず
引数を参照しない事とreturnせずにExitThreadで終了する事という2点を守れば 問題なく呼べると思うよ 何の意味もないが
965 :
961 :2007/07/18(水) 17:33:08
961です BorlandC++5.5.1 + Win98SEのトラブルだったようです OPENFILENAME の lStructSizeメンバ に OPENFILENAME_SIZE_VERSION_400 を 格納格納させて無事に解決しました 失礼しました
>>961 質問の仕方が悪いぞ。
> Win32API入門
というのは何者なのか。
> 6.ファイル選択 での最初のソースファイルの選択ダイアログなのですが
> 起動後右クリックしても実行結果のようなダイアログ自体が出ません
なんて言われても、他人にはわからないでしょう。
> 機種はWin98SEでBCCを使っています、よろしくお願いします
初心者なら、なおのこと、
単体のコンパイラではなく、統合環境付きのコンパイラを使うべし。
マイクロソフトのVC++2005 Express Editionは無性だが、立派なデバッガが付いてる。
かつては、
コマンドラインのコンパイラなら3万円、統合環境付きなら7万円、OWL付きなら10万円
なんていう時代もあって、お金がない学生がMSI-C試食版で頑張ってたりしてたがなぁ。
それから、プログラムを書くなら、WindowsはNT系(2000とかXPとかVista)がいい。
> BorlandC++5.5.1 + Win98SEのトラブルだったようです
違うよ。
人のせいにしてはいけない。
967 :
デフォルトの名無しさん :2007/07/18(水) 18:01:00
2000以降に限定した場合、Iniファイルのサイズって制限ありましたっけ?
>>966 >マイクロソフトのVC++2005 Express Editionは無性だが、立派なデバッガが付いてる。
無性
>なんていう時代もあって、お金がない学生がMSI-C試食版で頑張ってたりしてたがなぁ。
MSI-C
いいから喪前は落ち着け。
969 :
961 :2007/07/18(水) 18:35:55
別に人のせいにしてる訳ではないんですけど…書き方が悪かったのかな 「Win32API入門」はテンプレのサイトです、付け加えた方がよかったですね これは申し訳なかったです コンパイラは一通り勉強し終わったらBorlandC++からそれに変えてみる予定です PCに関しては今はこれしかないので
>>965 #define WINVER 0x0400
#define _WIN32_WINDOWS 0
#define _WIN32_WINNT 0
#define _WIN32_IE 0
#include <windows.h>
OPENFILENAMEに関しては_WIN32_WINNTさえ指定すれば十分だが、
それだけでは不恰好なんで、ついでにほかのも書いた。
>>969 勉強に無駄に時間を費やすのを防ぐために、
現時点での一般的な道具を使うべきだという話なんだけどなぁ。
論点がずれてますよ
974 :
デフォルトの名無しさん :2007/07/19(木) 00:05:36
FindFirstFile()に関して質問です。 FindFirstFile("abc_????.dat", &lpFindFileData); として、「abc_0000.dat」~「abc_9999.dat」というファイルを検索したいのですが、 (数値かどうかの判定はもちろん別途行う) このように検索すると、「abc_1234567890.dat」でも、「abc_.dat」でも、「abc_1234.datdat」でも 引っかかってしまいます。 「?」は任意の1文字であると思ってこうしているのですが、もしかして間違ってますか? どうすれば、「????」部分が4文字のファイル名を検索できるでしょうか? 知っている人いたら、教えてください。 それと、「#」は数字1文字ではないのですか? 「abc_####.dat」で検索できないものかと試したのですが、全然引っかかりません。 ワイルドカードって「*」、「?」、「#」が使えると思っていたのですが。
>>974 ワイルドカードに*.*を指定して全てリストアップした後、
自力か適当な正規表現libなどで判定させるのが定石。
FindFirstFileのワイルドカードは高級な事もできないし、
クセもあるのでね。
*.*という表記はフォルダ上の全ファイルにマッチする事が
保証されてる。(だよね?)
>>974 abc_1234567890.dat, abc_1234.datdatが引っかかるのは、
ショートネームの方で引っかかっているはず。
>>977 >保証されてる。(だよね?)
おれもそれどっかで見た。
AdvancedWindowsか何かだった様な。
MSDNに引っかからねー
>*.* 拡張子無しのファイルでも引っかかるのか これは試したこと無かったわ
*だけというのも使えると思う。 OPENFILENAMEのフィルタで、 単にTEXT("全てのファイル (*.*)\0*\0")としているのを見たことがある。
982 :
974 :2007/07/19(木) 01:06:43
皆さんレスありがとうございます。 助かりました。 自分でも調べたのですが、欲しい情報が見つからず往生してました。 「*」で全ファイル検出して、それからファイル名を判定するのがいいようですね。 実際に動かして試してみたいと思います。 ありがとうございました。
>>974 俺もそれではまったことがある。
OSの差かファイルシステムの差かまでは確認しなかったが
Windows9X(FAT32)では
"abc_????.dat"で"abc_1234567890.dat"はひっかからない
WindowsXP(NTFS)では
"abc_????.dat"で"abc_1234567890.dat"も引っかかる
で、俺も
>>977 のようにした
??のように?を2回続けるときはトライグラフに気をつけないとはまるw
トライグラフなんて知らなかったぜ。
化石過ぎて普段全く意識してねーからな
VC++ってトライグラフはデフォルトでオンだっけ? あんま使わないが一応\?\?と書いておくほうがいいのか。
>>987 オレはVC++ではまったw
プリンタ向けに出力したデータをソースに埋め込んだんだけど、それが?の羅列で、、、、
結局該当のとこだけ""をはさんで何とかしたけど、見つけるまで苦労したぜ。
VC7.1で試してみたけど、トライグラフ使っても警告出ないなぁ。 本当にトライグラフとして処理していいのか警告してくれても良さそうなものなのに。
*.*は前世紀の遺物だからなw
ワイルドカードで全部引っ張ってきて自分でフィルタするにしても、 abcから始まるファイルが目当てなら、abc*.*と指定しようよ。 NTFSはB*Treeなので、名前順にソートされて格納されてるのでね。