Help us understand the problem. What is going on with this article?

Visual Studio 2017 による C++ 開発 まとめ

More than 1 year has passed since last update.

はじめに

Visual Studio 2017 ですが、「主要言語」としては Visual C#, Visual Basic, Visual C++ がサポートされています。このうち、C# と VB は .NET Framework をターゲットにしています。一方、Visual C++ は Win32 を主にターゲットにしています。

Windows のネイティブ環境は Win32 なので、Visual C++ を使ってアプリを作成すると、より高速なアプリを構築できます。

とは言え、近年、Windows では .NET Framework が主流で、Win32 でアプリを開発することは少なくなりました。

Visual C++ を使っての開発となると、特別なデスクトップアプリ (高速性が必要で画面も比較的複雑なものなど) や過去の資産を流用するアプリとかぐらいでしょうか。

Visual C++ プロジェクトの種類

Visual Studio 2017 の「新しいプロジェクト」ダイアログですが、下の画像のようになっています。ただし、CLR と MFC は標準ではインストールされておらず、Visual Studio インストーラを使ってインストールする 必要があります。

VCProj.png

ATL

これは Active Template Library のことで、COM コンポーネントを作成するのに使います。COM コンポーネントを利用すると .NET Framework のアプリから Win32 の機能を容易に利用できます。
VCProj_ATL.png

CLR

CLR は Common Language Runtime のことです。これは .NET Framework と Win32 の両方を使うアプリ向けにクラスライブラリを作ったり、C++ で .NET Framework のクラスライブラリを利用するコンソールアプリを作ったりするのに使用します。
VCProj_CLR.png

全般

VCProj_Common.png

MFC

MFC は Microsoft Foundation Class の略で、Win32 API を直接使用せずにデスクトップアプリなどを開発するのに使用します。
VCProj_MFC.png

テスト

VCProj_Test.png

Win32

これは、Win32 API を直接使用してデスクトップアプリやコンソールアプリを作成するのに使用します。
VCProj_Win32.png

クロスプラットフォーム - Linux

これは Linux で動作するアプリを Visual Studio 2017 で開発するための機能です。詳しくは Visual Studio 2017 の Linux C++ 開発機能 参照。
VCProj_Linux.png

Visual C++ による Windows 開発の問題点

ポインタ

Windows 開発だけの問題ではないのですが、C/C++ はマネージ言語でないのでポインタをよく使います。これは便利な反面、危険な機能でもあるので、よく考えながらプログラミングしないと、プログラムがすぐクラッシュしたりします。

できれば、CPU の動作を想像し、機械語 (アセンブラ) をイメージしながらプログラミングするといいですが、そこまでやるのも大変です。

C++ が複雑

C++ は C を拡張してオブジェクト指向機能を追加したのですが、その他にテンプレート機能も追加されています。このため、シンプルな C に比べて「巨大な」言語になっていて、いろいろ難解な面があります。

Win32 API

Win32 API は C 言語用の API で、元となる Win16 は 1980 年代終わりごろに策定されたものと思います。(Windows 1.0 は 1985 年発売)

このため、あまり洗練されておらず、複雑で使いづらいです。しかも、非常に多くの関数からなっており、Windows の内部動作を知ってないと、これらの関数を使いこなすのは困難です。

MFC

MFC は Win32 API をカプセル化したクラスライブラリで、これを使えば本来なら簡単に Windows アプリを構築できるはずですが、実際にはそうではなく、Win32 API を知っていないと使いこなせません。というのは、MFC は Win32 API の薄いラッパー (Wrapper) で、Win32 API 関数の知識が必要なためです。

実は Visual でない Visual C++

Visual C++ は Visual Basic のように画面のデザインとプログラミングをできません。 Visual C++ でできるのは「画面のリソース」の編集をビジュアルにできるだけです。

このため、プロパティで設定できない項目も多数あって、どうやってプロパティを設定したらいいかわかりません。(たいていは Win32 API 関数やそれに対応する MFC のメソッドを呼び出す必要がある)

ATL もある

これは主に COM コンポーネントを作るのに使います。知らなくても、Win32 アプリケーションを作ることはできますが、COM コンポーネントを作る際には、COM の知識とともにライブラリの知識が必要です。

-

Why not register and get more from Qiita?
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
Comments
Sign up for free and join this conversation.
If you already have a Qiita account
Why do not you register as a user and use Qiita more conveniently?
You need to log in to use this function. Qiita can be used more conveniently after logging in.
You seem to be reading articles frequently this month. Qiita can be used more conveniently after logging in.
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away