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

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

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

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

Q&A

解決済

4回答

727閲覧

Visual Studio C# 戻り値に関して

hanimaru11

総合スコア29

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

0グッド

0クリップ

投稿2018/08/15 05:22

編集2018/08/15 05:25

---現在、Visual Studio 2017でmacアドレスを取得し、文字列で戻り値として扱おうとしております。
コードは以下です

static String GetMca() { // アダプタリストを取得する NetworkInterface[] adapters = NetworkInterface.GetAllNetworkInterfaces(); foreach (NetworkInterface adapter in adapters) { // 物理(MAC)アドレスの取得 PhysicalAddress phy = adapter.GetPhysicalAddress(); String macAddress = phy.ToString(); } return xxxxxxx; }

return xxxxxxx;
の部分で戻り値に macAddress を入れたいと考えているのですがうまくいきません。
少し調べてみたのですが、macAddress がローカル変数になってしまっているのでしょうか?

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

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

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

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

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

guest

回答4

0

複数の値を返すよう書き直してみました。
検証はしていません。

C#

1static IEnumerable<String> GetMca() 2{ 3 // アダプタリストを取得する 4 NetworkInterface[] adapters = NetworkInterface.GetAllNetworkInterfaces(); 5 return adapters.Select(a => a.GetPhysicalAddress().ToString()); 6}

最初の値のみ欲しければ

C#

1string s = GetMca().FirstOrDefault();

のようにします。

投稿2018/08/15 05:39

Zuishin

総合スコア28660

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

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

hanimaru11

2018/08/15 05:57

ご回答ありがとうございます。 ご教授いただきましたコードでも無事macアドレスを戻り値で取得することができました。 サンプルコードを自分で弄っていましたので、ここまでシンプルにできるものなのかと驚いております。 現状ではご教授頂いたコードでなぜできているのかわかりませんのでこの後調べて理解したいと思っております。 ありがとうざいました!
guest

0

foreachの大括弧の中で「string macAddress」と宣言してしまっているので、macAddress変数はforeachのカッコの中でしか参照できません。

戻り値の行でも使いたいならば、foreachの前で「string macAddress」と書けば大丈夫です。

ただ、別の方の指摘にもあるようにこのままだと

  1. foreachで複数のアダプター情報の1つを対象にする
  2. そのmacアドレスをmacAddressに入れる。
  3. 次のアダプター情報を対象にする。
  4. そのmacアドレスをmacAddressに上書きする……

上記の3、4を繰り返し、複数のアダプターがあると最後の1つのmacアドレスしか取れません。それでよいのなら、前述のstring宣言の場所を変えるだけでうまくいくと思いますよ。

投稿2018/08/15 05:40

backyard

総合スコア534

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

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

hanimaru11

2018/08/15 05:50

ご回答ありがとうございます 今回、1つのアダプタのmacアドレスを取得することが目的でしたのでforeach前で宣言を追加しました。 ですが確かに今後複数アダプタの情報を取得することも考え、改良していきたいと思います。 ありがとうございました!
guest

0

ブロックの中{}で定義した変数は、そのブロックの外では参照できません。
その外で定義しておきましょう。

って、foreach のループしてるなら、その最後の値になってしまうけど、そんでいいの?

投稿2018/08/15 05:25

y_waiwai

総合スコア87774

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

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

hanimaru11

2018/08/15 05:44

ご回答ありがとうございます、以下のようにforeachの外側で変数を定義することで自分の行おうとしてたことはできました! static String GetMca() { string macAddress = null; // アダプタリストを取得する NetworkInterface[] adapters = NetworkInterface.GetAllNetworkInterfaces(); foreach (NetworkInterface adapter in adapters) { // 物理(MAC)アドレスの取得 PhysicalAddress phy = adapter.GetPhysicalAddress(); macAddress = phy.ToString(); return macAddress ; } return macAddress ; } foreachに関しまして、今回macアドレスのみ使用したくサンプルを見ながら不要な部分を削ったりしていました。元々はIPなども取得するようになっておりましたのでそのせいかと思います。 もう少しきちんとできるよう試行してみます。 本当にありがとうございました!
y_waiwai

2018/08/15 05:48

いろいろやって動作を試して、不都合あれば修正して試して、を繰り返すことです。 がんばってください。 で、ちなみに、そのコードだと、foreach の最初の値を返すってことになりますね。 まあ、ネットワークアダプタがない場合はループに入らずnullを返すのでそんでいいか。
guest

0

自己解決

static String GetMca() { **string macAddress = null;** // アダプタリストを取得する NetworkInterface[] adapters = NetworkInterface.GetAllNetworkInterfaces(); foreach (NetworkInterface adapter in adapters) { // 物理(MAC)アドレスの取得 PhysicalAddress phy = adapter.GetPhysicalAddress(); macAddress = phy.ToString(); return macAddress ; } return macAddress ; }

foreach前で宣言することで解決しました。
ですが回答いただきました「複数のアダプタへの対応」ができておらず、現状ではforeachの結果で複数あるアダプタの最後のものが変数にセットされている状態です。

投稿2018/08/15 06:01

hanimaru11

総合スコア29

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

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

hanimaru11

2018/08/15 06:03

回答いただきました方々、申し訳ありません。 自分の解決方法をまとめたのですが、ベストアンサーになってしまいました。ごめんなさい…
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問