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で質問しましょう!
似たような質問が見つかりました
- その他(プログラミング・Web制作) IT初心者です 仕事で、vb.netで作成されたdllをvbaで呼び出すプログラムを作成しろと言われ 1 2023/03/27 08:22
- Visual Basic(VBA) 複数シートの複数列に入力されているデータを重複なしで抽出するVBAを作りたいです。 9 2022/06/17 10:33
- Visual Basic(VBA) VBA横データを縦にしたいです 2 2023/08/08 19:38
- Visual Basic(VBA) Vbaで数式をポーランド記法に変換するコードを作って実行しようとするとフリーズします。 1 2022/05/24 17:53
- Visual Basic(VBA) VBAでのMATCH関数 3 2022/10/17 19:06
- Windows 10 IT初心者です! powershellで以下のようなエラーが出ました オブジェクト参照がオブジェクト 1 2023/05/17 11:30
- Visual Basic(VBA) マクロについて教えてください。 4 2023/06/06 09:06
- その他(Microsoft Office) マクロVBAについて 1 2022/09/06 18:12
- Visual Basic(VBA) エクセルVBAで以下のようなコードを書いたらエラーになりました。何処が間違っているの教えて? 1 2023/02/10 18:30
- C言語・C++・C# C言語初心者 ポインタについて、お助けください、、 2 2023/03/15 23:50
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VBA 変数名に変数を使用したい。
-
C#でbyte配列から画像を表示さ...
-
コンボボックスのインデックス...
-
Segmentation Fault (メモリ制限?)
-
エクセル(VBA)の空白配列の削除...
-
vba フィルター 複数条件 3つ以...
-
順位をつける VB.NET2008
-
2次元配列の初期値
-
配列の中の最大値とそのインデ...
-
Dir関数で読み取り順を操作でき...
-
Excel2010のinputboxで複数デー...
-
CheckBoxの配列化
-
Redim とEraseの違いは?
-
1ビットごとの配列を作りたい
-
定数配列の書き方
-
mpiによる多次元配列の送受信
-
レコードセットの中身を配列に...
-
EXCELで年齢別の分布表を...
-
ポーカーを作りたいのですが・・・
-
ReDim PreserveよりもReDimが遅い
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBA 変数名に変数を使用したい。
-
C#でbyte配列から画像を表示さ...
-
vba フィルター 複数条件 3つ以...
-
Dir関数で読み取り順を操作でき...
-
エクセルでXY座標に並べられた...
-
配列の中の最大値とそのインデ...
-
VB.NETの配列にExcelから読み込...
-
定数配列の書き方
-
Excel2010のinputboxで複数デー...
-
大量の変数を定義するにはどう...
-
構造体配列の特定のメンバーをF...
-
構造体配列内の文字列検索のよ...
-
Redim とEraseの違いは?
-
Segmentation Fault (メモリ制限?)
-
OutOfMemoryExceptionの回避策...
-
VBAでMODE関数をつくる
-
COBOLの基本的な事なので...
-
Excelのメモリ(配列)の上限は2G...
-
コンボボックスのインデックス...
-
VB6のメモリ解放に関して
おすすめ情報