質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

DLL

DLL(Dynamic Link Library)とは、他のモジュールからも使用する事が出来る、関数とデータが格納されているモジュールのことです。

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Q&A

解決済

3回答

2207閲覧

VBAのLongLongからdllの__int64へ値を渡すと数字が壊れます。

退会済みユーザー

退会済みユーザー

総合スコア0

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

DLL

DLL(Dynamic Link Library)とは、他のモジュールからも使用する事が出来る、関数とデータが格納されているモジュールのことです。

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

0グッド

0クリップ

投稿2021/03/19 07:32

編集2021/03/19 13:20

VBAのLongLongからdllの__int64へ値を渡すと数字が壊れます。
なぜでしょうか?

少しわかってきました。
一つ目と二つ目の引数を入れ替えたら、一つ目の引数はちゃんと渡るのに二つ目の引数が壊れるようです。

C++ dll 側の宣言

extern "C" __declspec(dllexport) long __stdcall func(const long l1, const char *pStr);

VBA 側

Private Declare PtrSafe Function func Lib "test.dll" (ByVal long1 As Long, ByVal str As String) As Long

Sub sub1()
Dim long1 As Long
Dim str As Variant

long1 = 10000 str = "abc" func(long1, str)

End Sub

これでなぜ文字列が渡らないのか?

C++ dll 側の宣言 ★修正版★

extern "C" __declspec(dllexport) long __stdcall func(const char *pStr);

VBA 側

Private Declare PtrSafe Function func Lib "test.dll" (ByVal param As String) As Long

Sub sub1()
Dim long1 As Long
Dim str1 As string
Dim param As Variant

long1 = 10000 str1 = "abc" param = str1 + "," + str(long1) func(param)

End Sub

わけわからんけどこれで解決した。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

K_3578

2021/03/19 07:50

数字が壊れます。とは 問題が明確にわかるソースコードを追記してください。
guest

回答3

0

ベストアンサー

双方の変数の形式が違うから、ですね

投稿2021/03/19 08:10

y_waiwai

総合スコア87774

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2021/03/20 05:23

VBAわけわからん。 もう使いたくないな。
guest

0

質問者が なぞかけ的な質問をしてくるとは、驚きです。
Excelの32ビットと64ビットの違いでは? これしか私にはわかりません
詳しくは YouTube, URL[【VBA】64ビット版のExcelは、思わぬところでマクロがエラーになる]
https://www.youtube.com/watch?v=mG5yzWPSxaA
を参照してください。

投稿2021/03/19 11:46

syousuke.33

総合スコア312

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

どのようなコードなのか分かりませんが、PtrSafeとかが必要なのではないでしょうか。
WinAPIの64bit化で出てくるPtrSafe、LongLong、LongPtrってなんなのさ?

投稿2021/03/19 09:02

sazi

総合スコア25188

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問