パスカルケース
パスカルケース(英: Pascal case[注釈 1])は、プログラミングおよびコンピュータサイエンスの分野において、複数の単語を連結する際に使用される命名規則の一種である[1][2][3][4]。この記法は、各単語の頭文字を大文字で表記し、それ以外の文字を小文字で表記するという特徴をもつ。パスカルケースは、しばしば関数名[5][6][7][8]、変数名[1][5][9][10]、およびクラス名[5][11][12][13]の命名規則として使用される。この命名規則はPascal言語に由来しており、名称考案時にこのスタイルが普及していたことから「パスカルケース」と命名された[14][15][16][17]。
パスカルケースは別名、バイキャピタライゼーション(英: bicapitalization / bi-capitalization / BiCapitalization)[18][19]、インターキャプス(英: InterCaps / internal capitalization)[20][19]とも呼ばれることがある。頭文字に小文字と大文字を混在させるケースはミックストケース(英: mixed-case)[21]とも呼ばれる。一部、日本語訳してキャメル記法(きほう)[22]、キャメル方式(ほうしき)[23]と表現されることもある。
パスカルケースは広く普及している[2][5][10][24]呼称だが、厳密には.NETの文脈で使用されるものであり[14][15][25][26][27][28][注釈 2]、同じく並び称されるものとして「キャメルケース(英: camel case)」が存在する[11]。パスカルケースとキャメルケースは、共に複数の単語を連結する命名規則であるが、両者には明確な違いがある。キャメルケースでは最初の単語の頭文字は小文字とし、次の単語から頭文字を大文字にする(例:camelCase)。一方、パスカルケースでは全ての単語の頭文字を大文字にする(例:PascalCase)[37][38][39]。この違いにより、パスカルケースはキャメルケースとは異なる命名規則として認識される。
パスカルケースは、複数の単語が連結された場合でも、各単語の頭文字が大文字で示されるため、どの部分が新しい単語であるかを容易に判別することができる。これにより、プログラムコードの可読性が向上し、保守・点検を行いやすくなる[10][40]。
歴史
[編集]1970年代:Pascal言語の登場
[編集]パスカルケースの起源は、1970年代に登場したプログラミング言語「Pascal」に遡ることができる[41][42]。Pascal言語は、教育目的で開発され、その簡潔で構造化された文法により、プログラミングの学習および実践において広く使用された[43][44]。Pascal言語の命名規則として採用されたのがパスカルケース(この時点ではまだこの呼称の定着はしていない)であり、その後、他の多くのプログラミング言語やフレームワークに影響を与えることとなった[45][46][47]。
1980年代~1990年代:オブジェクト指向プログラミングの普及
[編集]1980年代から1990年代にかけて、オブジェクト指向プログラミング(OOP)の普及に伴い、パスカルケース(のスタイル)はクラス名やオブジェクト名の命名規則として広く採用されるようになった。特に、Delphi[48][49]やC++[50][51]などの言語において、パスカルケース(のスタイル)はコードの可読性を高めるための重要なスタイルガイドラインとして位置付けられた。
2000年代初頭:.NET Frameworkの登場と「パスカルケース」の名称採用
[編集]Microsoftの.NET Frameworkが登場した2000年代初頭[15][52]には、Turbo Pascalの設計者であり、.NET設計チームの主要なメンバーでもあったアンダース・ヘルスバーグが、これはPascal言語によって普及したスタイルであると提言したことにより、「パスカルケース」という名称が.NET公式の命名規則の一部として採用され、以降、多くの開発者がこれを標準的なスタイルとして受け入れるようになった[17][53]。
現代:Java、C#、JavaScriptなどの主要プログラミング言語での広範な使用
[編集]さらに、パスカルケース(のスタイル)はJava、C#、JavaScriptなど、現代の主要なプログラミング言語においても広く使用されている。これらの言語では、特にクラス名や構造体名に対してパスカルケース(のスタイル)を使用することが推奨されており、統一された命名規則がコードの整合性と可読性を維持する上で重要な役割を果たしている。ただし、「パスカルケース」という名称は厳密には.NETの文脈で使用されるものであるため[54][55][56]、より広範な文脈では、同じスタイルでも「アッパーキャメルケース(英: upper camel case)」という名称を使用する[57][58][59]。
パスカルケースの普及と共に、その明確な命名規則は、多言語環境や国際的なソフトウェア開発プロジェクトにおいても、開発者間のコミュニケーションを円滑にする一助となっている[47][54]。統一された命名規則の採用により、コードレビューや保守作業が効率化され、バグの発見や修正も容易になるといった利点も生じている[47][54]。
文脈別の使い分け
[編集]先述のように、「パスカルケース」という名称は、厳密にはMicrosoftの.NET Frameworkにおける命名規則として使用される用語である。2000年代初頭に登場した.NET Frameworkは、Windowsプラットフォーム向けのアプリケーション開発を簡素化し、統一された開発環境を提供することを目的として設計された[15][52]。このフレームワークにおいて、クラス名や関数名の命名規則として「パスカルケース」という用語が公式に採用され、広く認識されるようになった。
一方、より広範な文脈においては、パスカルケースと同様の命名規則を指す際に「アッパーキャメルケース(英: upper camel case)」という用語が使用される。「キャメルケース(英: camel case)」とは、単語の「境界」を大文字で区切る命名規則の総称とみなされる場合があり[47][54][注釈 3]、そのうちの「全ての単語の頭文字を大文字にする」ものを「アッパーキャメルケース」[63][64]、「最初の単語の頭文字を小文字にする」ものを「ローワーキャメルケース(英: lower camel case)」と分類する[63][65][注釈 4]。
「アッパーキャメルケース」という用語は、特定のフレームワークや言語に依存せず、より包括的な文脈で使用可能なため、多くのプログラミング言語やフレームワークにおいて適用可能である。例えば、Java[73]やC++[74]、Python[75]などの言語では、クラス名や型名に対してアッパーキャメルケースを使用することが推奨されており[76][77]、これによりコードの一貫性と可読性が向上する。
利点
[編集]利点については、「アッパーキャメルケース」の「利点」項目で説明されている。
パスカルケースについて、利点という点でアッパーキャメルケースの利点と比較して特筆すべき点はないため、このページでは省略する。
欠点
[編集]欠点については、「アッパーキャメルケース」の「欠点」項目で説明されている。
パスカルケースについて、欠点という点でアッパーキャメルケースの欠点と比較して特筆すべき点はないため、このページでは省略する。
適用例
[編集]以下の点について以外は「アッパーキャメルケース」の「適用例」項目で説明されている。
パスカルケースについて、適用例という点でアッパーキャメルケースの適用例と比較して以下の点について以外に特筆すべき点はないため、このページでは省略する。
Pascalは元々、大文字・小文字を区別しない言語であり、またISO規格準拠の標準Pascalでは識別子にアンダースコア_
は用いることができない仕様になっているということもあり[78]、単語境界を認識しやすくするために単語先頭を大文字にする慣習があった。規格の文書には標準手続き(英: Required Procedure)はwriteln
(Write Ln)のように全て小文字で記載されているが、一部のPascal処理系の文書にはWriteLn
のようにアッパーキャメルケースが採用されているものもある[79][80]。
命名規則一覧
[編集]名称 | 英語表記 | 説明 | 表記例 |
---|---|---|---|
スネークケース | snake case | 単語間をアンダースコア(_ )で繋ぐ形式。
|
example_variable
|
スクリーミングスネークケース | screaming snake case | 単語間をアンダースコア(_ )で繋ぎ、全て大文字にする形式。「アッパースネークケース(upper snake case)」や「コンスタントケース(constant case)」とも呼ばれる[81]。
|
EXAMPLE_VARIABLE
|
キャメルケース | camel case | 各単語の頭文字を大文字にし、単語を連結する形式(最初の単語のみ頭文字が小文字)。.NETの文脈で使用。 | exampleVariable
|
ローワーキャメルケース | lower camel case | キャメルケースと同じ形式だが、フレームワークや言語に依存しない表現。 | exampleVariable
|
パスカルケース | Pascal case | 各単語の頭文字を大文字にし、単語を連結する形式(キャメルケースと似ているが、最初の単語の頭文字も大文字)。.NETの文脈で使用。 | ExampleVariable
|
アッパーキャメルケース | upper camel case | パスカルケースと同じ形式だが、フレームワークや言語に依存しない表現。 | ExampleVariable
|
ケバブケース | kebab case | 単語間をハイフン(- )で繋ぎ、各単語の頭文字を小文字にする形式。
「チェインケース / チェーンケース(chain case)」とも呼ばれる[81]。 |
example-variable
|
トレインケース | train case | 単語間をハイフン(- )で繋ぎ、各単語の頭文字を大文字にする形式。
|
Example-Variable
|
ドットケース | dot case | 単語間をドット(. )で繋ぐ形式。
|
example.variable
|
脚注
[編集]注釈
[編集]- ^ 「Pascal」は固有名詞であるため、先頭を小文字にしてはならない。
- ^ パスカルケースと同じ意味でも、他の言語では「アッパーキャメルケース」が用いられる。Java[29][30][31][32]、Python[33][34][35][36]など。
- ^ 各辞書で「"通常"、キャメルケースと呼ぶ場合ローワーキャメルケースを指す」のように表現されていることから、場合によってはパスカルケース(アッパーキャメルケース)を指すこともある(「総称としての紹介[60]」、「"通常"という表現を用いた紹介[61][62]」が存在する)。
- ^ 「ローワー」という読み仮名表記は、「大辞林第四版[66]」「大辞泉[67]」「日本語シソーラス第2版[68]」「コトバンク[69]」「IT用語辞典[70]」「goo辞書[71]」「シマウマ用語集[72]」など、様々な辞書で採用されている表記である。
出典
[編集]- ^ a b “Programming naming conventions (explained by a snake)” (英語). www.pluralsight.com. 2024年7月1日閲覧。
- ^ a b “Programming Naming Conventions – Camel, Snake, Kebab, and Pascal Case Explained” (英語). freeCodeCamp.org (2022年8月22日). 2024年7月1日閲覧。
- ^ “Coding best practices — Research Computing University of Colorado Boulder documentation”. curc.readthedocs.io. 2024年7月1日閲覧。
- ^ “Most Common Programming Case Types” (英語). www.curiouslychase.com. 2024年7月1日閲覧。
- ^ a b c d “Java Naming Conventions: PascalCase, camelCase, and more - CRS Info Solutions”. www.crsinfosolutions.com. 2024年7月1日閲覧。
- ^ “Code Style Guide” (英語). Android Open Source Project. 2024年7月1日閲覧。
- ^ “JavaScript Style Guide” (英語). www.w3schools.com. 2024年7月1日閲覧。
- ^ “Follow TypeScript best practices - AWS Prescriptive Guidance”. docs.aws.amazon.com. 2024年7月1日閲覧。
- ^ “Coding best practices — Research Computing University of Colorado Boulder documentation”. curc.readthedocs.io. 2024年7月1日閲覧。
- ^ a b c “What is Pascal Case? - Tuple”. www.tuple.nl. 2024年7月1日閲覧。
- ^ a b BillWagner: “Identifier names - rules and conventions - C#” (英語). learn.microsoft.com (2023年12月15日). 2024年7月1日閲覧。
- ^ Datadog: “Class name should be `PascalCase`”. Datadogでインフラストラクチャーとアプリケーションのモニタリング. 2024年7月1日閲覧。
- ^ Mukesh Kumar: “C# Naming Conventions” (英語). www.c-sharpcorner.com. 2024年7月1日閲覧。
- ^ a b Prosise, Jeff (2002) (英語). Programming Microsoft .NET (core Reference). Microsoft Press. ISBN 978-0-7356-1376-8
- ^ a b c d Richter, Jeffrey (2012-11-15) (英語). CLR via C#. Pearson Education. ISBN 978-0-7356-6876-8
- ^ Esposito, Dino; Saltarello, Andrea (2014-08-28) (英語). Microsoft .NET - Architecting Applications for the Enterprise. Microsoft Press. ISBN 978-0-13-398640-2
- ^ a b “The Private Life of a Public API”. www.moserware.com. 2024年7月1日閲覧。
- ^ “bicapitalizationの意味・使い方・読み方 | Weblio英和辞書”. ejje.weblio.jp. 2024年6月29日閲覧。
- ^ a b “Style Guide | Sui Documentation” (英語). docs.sui.io. 2024年7月13日閲覧。
- ^ “InterCaps - definition of InterCaps - synonyms, pronunciation, spelling from Free Dictionary”. freedictionary.org. 2024年6月29日閲覧。
- ^ “Converting Between Different Naming Conventions - Python Cookbook [Book]” (英語). www.oreilly.com. 2024年6月29日閲覧。
- ^ “キャメルケースとは? 意味や使い方”. コトバンク. 2024年6月29日閲覧。
- ^ “新人コーダーに知っておいて欲しい命名規則の考え方[画像・ID・class名]”. 株式会社クロノドライブ. 2024年6月29日閲覧。
- ^ “Snake Case VS Camel Case VS Pascal Case VS Kebab Case – What's the Difference Between Casings?” (英語). freeCodeCamp.org (2022年11月29日). 2024年7月1日閲覧。
- ^ “Programming Case Styles : Using The Conventions - ITU Online” (英語). ITU Online (2024年1月24日). 2024年7月1日閲覧。
- ^ “ASP.NET - Citus 11.1 documentation” (英語). docs.citusdata.com. 2024年7月1日閲覧。
- ^ “C# Excellence in .NET Development: Comprehensive Guide to Best Practices and Useful Tips” (英語) (2019年6月10日). 2024年7月1日閲覧。
- ^ KathleenDollard: “F# coding conventions - .NET” (英語). learn.microsoft.com (2023年5月18日). 2024年7月1日閲覧。
- ^ “NamingConventions.UpperCamelCase (DataStax Enterprise Java Driver - Binary distribution 1.9.0 API)”. docs.datastax.com. 2024年7月1日閲覧。
- ^ “XML Standards and Conventions”. docs.oracle.com. 2024年7月1日閲覧。
- ^ “Style Guide | SoftConst2x | edX”. courses.edx.org. 2024年7月1日閲覧。
- ^ “Google Java Style Guide”. google.github.io. 2024年7月1日閲覧。
- ^ “CS 1110: Notes on Style”. www.cs.cornell.edu. 2024年7月1日閲覧。
- ^ “BytePlus | Business growth through superior technology”. docs.byteplus.com. 2024年7月1日閲覧。
- ^ “Coding Style — PyLith 4.1.1 documentation”. pylith.readthedocs.io. 2024年7月1日閲覧。
- ^ “Conventions — MSOLVE 2024 documentation”. 2023.help.altair.com. 2024年7月1日閲覧。
- ^ KrzysztofCwalina: “Capitalization Conventions - Framework Design Guidelines” (英語). learn.microsoft.com (2023年10月3日). 2024年7月1日閲覧。
- ^ dotnet-bot: “CodeIdentifier.MakePascal(String) Method (System.Xml.Serialization)” (英語). learn.microsoft.com. 2024年7月1日閲覧。
- ^ dotnet-bot: “CodeIdentifier.MakeCamel(String) Method (System.Xml.Serialization)” (英語). learn.microsoft.com. 2024年7月1日閲覧。
- ^ “Camelcase” (英語). DevX. 2024年7月1日閲覧。
- ^ Wirth, Niklaus (1970-11). The Programming Language Pascal (Niklaus Wirth). Inst. f. Datenverabeitung, Techn. Hochsch. München
- ^ Wirth, Niklaus (1980) (英語). Algorithms + Data Structures: Programs. Scholars Book Company
- ^ “Pascal Programming: Object, History & Usage” (英語). Vaia. 2024年7月1日閲覧。
- ^ “Pascal: The Complete Skill Guide”. RoleCatcher. 2024年7月1日閲覧。
- ^ Knuth, Donald (1973) (英語). The Art of Computer Programming. Addison-Wesley Publishing Company, Pearson Education
- ^ (英語) Structured programming. Acad. Press. (1974)
- ^ a b c d Martin, Robert C. (2008-08-01) (英語). Clean Code: A Handbook of Agile Software Craftsmanship. Pearson Education. ISBN 978-0-13-608325-2
- ^ Rubenking, Neil J. (1995) (英語). Delphi Programming for Dummies. IDG Books. ISBN 978-1-56884-200-4
- ^ Cantu, Marco (英語). Mastering Delphi - Book. Pearson Education, Limited. ISBN 978-0-273-61958-1
- ^ Stroustrup, Bjarne (2000) (ドイツ語). The C++ Programming Language. Pearson Deutschland GmbH. ISBN 978-3-8273-1660-8
- ^ Meyers, Scott Douglas (2003) (英語). Effective C++: 50 Specific Ways to Improve Your Programs and Designs. China Electric Power Press. ISBN 978-7-5083-1498-3
- ^ a b Cwalina, Krzysztof; Abrams, Brad (2008-10-22) (英語). Framework Design Guidelines: Conventions, Idioms, and Patterns for Reusable .NET Libraries. Pearson Education. ISBN 978-0-321-60500-9
- ^ “MICROSOFT ® .NET DEVELOPER”. Pearson Education, Inc.. 2024年7月1日閲覧。
- ^ a b c d McConnell, Steve (1993) (英語). Code Complete: A Practical Handbook of Software Construction. Microsoft Press. ISBN 978-1-55615-484-3
- ^ “A Simple Approach to Optimized Text Compression's Performance”. IEEE Xplore. 2024年7月1日閲覧。
- ^ Mix, Scott R.; Rice, Mark J.; Sridhar, Siddharth; Schmidt, Charles M.; Raju, Srini; Gonzales-Perez, Carlos; Bharadwaj, Debraj (2021-12-10) (English). Universal Utility Data Exchange (UUDEX) Information Structures - Rev. 1 .
- ^ “Google Java Style Guide”. checkstyle.org. 2024年7月1日閲覧。
- ^ “C# namespace annotation” (英語). api-linter. 2024年7月1日閲覧。
- ^ “JavaScript coding guidelines”. www.zabbix.com. 2024年7月1日閲覧。
- ^ “camel caseの意味・使い方・読み方 | Weblio英和辞書”. ejje.weblio.jp. 2024年7月2日閲覧。
- ^ “キャメルケース(camel case)とは? 意味・読み方・使い方をわかりやすく解説 - goo国語辞書”. goo辞書. 2024年7月2日閲覧。
- ^ “キャメルケースとは? 意味や使い方”. コトバンク. 2024年7月2日閲覧。
- ^ a b “キャメルケースとは - IT用語辞典”. IT用語辞典 e-Words. 2024年7月1日閲覧。
- ^ “アッパーキャメルケースとは? 意味や使い方”. コトバンク. 2024年7月1日閲覧。
- ^ “ローワーキャメルケースとは? 意味や使い方”. コトバンク. 2024年7月1日閲覧。
- ^ “大辞林第四版”. 三省堂. 2024年7月1日閲覧。
- ^ “大辞泉”. 大辞泉. 2024年7月1日閲覧。
- ^ “日本語シソーラス 第2版 類語検索辞典”. 大修館書店. 2024年7月1日閲覧。
- ^ “ローワーキャメルケース”. コトバンク. 2024年7月1日閲覧。
- ^ “キャメルケース”. IT用語辞典. 2024年7月1日閲覧。
- ^ “ローワーキャメルケース”. goo辞書. 2024年7月1日閲覧。
- ^ “キャメルケース”. シマウマ用語集. 2024年7月1日閲覧。
- ^ “Google Java Style Guide”. google.github.io. 2024年7月1日閲覧。
- ^ “C & C++ - OpenTitan Documentation”. opentitan.org. 2024年7月1日閲覧。
- ^ “Python style guidelines [go/cros-pystyle]”. www.chromium.org. 2024年7月1日閲覧。
- ^ “Camel case - MDN Web Docs Glossary: Definitions of Web-related terms | MDN” (英語). developer.mozilla.org (2024年5月7日). 2024年7月1日閲覧。
- ^ “Coding conventions | Kotlin” (英語). Kotlin Help. 2024年7月1日閲覧。
- ^ “Pascal ISO/IEC 7185:1990”. University of Texas at Austin, specifically by Gordon S. Novak Jr.. 2024年7月1日閲覧。
- ^ “WriteLn”. www.freepascal.org. 2024年7月1日閲覧。
- ^ “WriteLn - The GNU Pascal Manual”. www.gnu-pascal.de. 2024年7月1日閲覧。
- ^ a b “スネークケースとは - IT用語辞典”. IT用語辞典 e-Words. 2024年7月7日閲覧。