
VC++初心者です。よろしくお願いします。
VC++2008ExpressでWindowsアプリケーションのDLLを作成してみました。
Excel2007VBAにて、そのDLLを呼び出して関数を使用したいのですが
VBAの配列を参照渡しで渡すと、配列のデータをうまく渡せません。
コードは以下の通りです。
配列ではないデータはうまくいきますが。。。
配列の場合はもっと他に必要なことがあるのでしょうか?
よろしくお願いします。
//VC++ DLLコード
#include <windows.h>
int APIENTRY Add(int[] a)
{
return a[0] + a[1] ;
}
'''VBAのコード
Private Declare Function Add Lib "TEST_DLL.dll" (ByRef a() As Integer) As Integer
Dim a(1) As Integer
Sub test()
a(0) = 1
a(1) = 2
MsgBox (Add(a))
End Sub
メッセージボックスには3が表示されるはずですが
変な数字に化けてしまいます。
どなたか、ご存知の方、よろしくお願いします。
No.1ベストアンサー
- 回答日時:
CPPファイルでコンパイルしているなら extern ”C"でCPPの自動命名を抑制したほうがいいと思います
VBAのIntegerは16ビットなので C++側の受けは shortにしないといけません
VBA側をC++に合わせるなら 変数を Longにします
またVBA側のDeclare宣言を
' C++側が intなら
Private Declare Function Add Lib "Test_DLL.dll" ( a as Long ) as Long
' C++側が shortなら
Private Declare Function Add Lib "Test_DLL.dll" ( a as Integer ) as Integer
といった具合にします
呼び出し方法は
MsgBox( Add( a(0) ) )
といった具合に 先頭要素を引数に渡しましょう
ありがとうございます。
Declare宣言と先頭要素を渡すという点がおかしかったんですね。
うまくいきました。
相当、悩んでおりました。
ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VBA 変数名に変数を使用したい。
-
VBAでMODE関数をつくる
-
Msgboxのループ
-
Dir関数で読み取り順を操作でき...
-
Excel2010のinputboxで複数デー...
-
7億ある配列を含んだ計算をした...
-
VBScriptでCSVファイルを読み出...
-
エクセルでXY座標に並べられた...
-
定数配列の書き方
-
vb2008で文字列から文字列コー...
-
ASPのReDim Preserveについて
-
C#でbyte配列から画像を表示さ...
-
【ExcelVBA】値を変更しながら...
-
VBAコンボボックスの内容が反映...
-
VB6.0でSQLServerへ・・・Recor...
-
Web画面のTableから数字を取得...
-
HTTPストリーミングによるデー...
-
テーブルのデータ型の変更がで...
-
文字列から、null値を除去する方法
-
StrConvでUnicodeに変換出来な...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBA 変数名に変数を使用したい。
-
C#でbyte配列から画像を表示さ...
-
エクセルでXY座標に並べられた...
-
Dir関数で読み取り順を操作でき...
-
vba フィルター 複数条件 3つ以...
-
配列のペースト出力結果の書式...
-
複数のtextboxの処理を一括で行...
-
Excelのメモリ(配列)の上限は2G...
-
配列の中の最大値とそのインデ...
-
大量の変数を定義するにはどう...
-
Excel2010のinputboxで複数デー...
-
COBOLの基本的な事なので...
-
構造体配列内の文字列検索のよ...
-
VBAでMODE関数をつくる
-
Redim とEraseの違いは?
-
VBScriptでCSVファイルを読み出...
-
VB6のメモリ解放に関して
-
VB.NETの配列にExcelから読み込...
-
Segmentation Fault (メモリ制限?)
-
ActiveReports(アクティブレポ...
おすすめ情報