1+ <!doctype html>
2+ < html class ="cpprefjp " lang ="ja " itemscope ="" itemtype ="http://schema.org/WebPage ">
3+ < head >
4+
5+
6+ <!-- Google tag (gtag.js) -->
7+ < script async src ="https://www.googletagmanager.com/gtag/js?id=G-NXNBNVBTJS "> </ script >
8+ < script >
9+ window . dataLayer = window . dataLayer || [ ] ;
10+ function gtag ( ) { dataLayer . push ( arguments ) ; }
11+ gtag ( 'js' , new Date ( ) ) ;
12+
13+ gtag ( 'config' , 'G-NXNBNVBTJS' ) ;
14+ </ script >
15+
16+
17+ < meta charset ="UTF-8 ">
18+
19+ < title > optional::begin - cpprefjp C++日本語リファレンス</ title >
20+
21+ < meta name ="viewport " content ="width=device-width,initial-scale=1 ">
22+ < meta name ="keywords " content ="
23+ C++,標準ライブラリ,リファレンス,ドキュメント,STL,std,optional,std,optional,function,cpp26
24+ ">
25+ < meta name ="title " content ="optional::begin - cpprefjp C++日本語リファレンス " />
26+ < meta itemprop ="name " content ="optional::begin - cpprefjp C++日本語リファレンス " />
27+ < meta property ="og:title " content ="optional::begin - cpprefjp C++日本語リファレンス " />
28+ < meta property ="og:url " content ="https://cpprefjp.github.io/reference/optional/optional/begin.html " />
29+ < meta property ="og:site_name " content ="cpprefjp - C++日本語リファレンス " />
30+ < meta property ="og:type " content ="article " />
31+ < meta property ="og:description " content ="`optional`をrangeとした時の先頭要素を指すイテレータを取得する。 " />
32+ < meta name ="twitter:card " content ="summary " />
33+ < meta name ="twitter:title " content ="optional::begin - cpprefjp C++日本語リファレンス " />
34+ < meta name ="twitter:url " content ="https://cpprefjp.github.io/reference/optional/optional/begin.html " />
35+ < meta name ="twitter:description " content ="`optional`をrangeとした時の先頭要素を指すイテレータを取得する。 " />
36+
37+
38+ < link rel ="alternate " type ="application/atom+xml " title ="Atom " href ="https://cpprefjp.github.io/rss.xml " />
39+
40+
41+ < link rel ="apple-touch-icon " sizes ="180x180 " href ="../../../static/favicons/apple-touch-icon.png?cachebust=759f03fc15b30d6368ce2e93b7017b1d9cee9a73 ">
42+ < link rel ="icon " type ="image/png " sizes ="32x32 " href ="../../../static/favicons/favicon-32x32.png?cachebust=759f03fc15b30d6368ce2e93b7017b1d9cee9a73 ">
43+ < link rel ="icon " type ="image/png " sizes ="16x16 " href ="../../../static/favicons/favicon-16x16.png?cachebust=759f03fc15b30d6368ce2e93b7017b1d9cee9a73 ">
44+ < link rel ="manifest " href ="../../../manifest.json?cachebust=759f03fc15b30d6368ce2e93b7017b1d9cee9a73 ">
45+ < meta name ="theme-color " content ="#f5f8fc ">
46+
47+ < link rel ="stylesheet " href ="../../../static/pygments/default.css?cachebust=759f03fc15b30d6368ce2e93b7017b1d9cee9a73 ">
48+ <!-- <link rel="stylesheet" href="../../../static/css/root.css"> -->
49+
50+
51+
52+
53+
54+ < link href ="../../../static/kunai/css/kunai-stage-0.css?cachebust=759f03fc15b30d6368ce2e93b7017b1d9cee9a73 " rel ="stylesheet ">
55+ < link href ="../../../static/kunai/css/kunai-stage-1.css?cachebust=759f03fc15b30d6368ce2e93b7017b1d9cee9a73 " rel ="stylesheet ">
56+ < link href ="../../../static/kunai/css/kunai-stage-2.css?cachebust=759f03fc15b30d6368ce2e93b7017b1d9cee9a73 " rel ="stylesheet ">
57+ < link href ="../../../static/kunai/css/kunai-stage-3.css?cachebust=759f03fc15b30d6368ce2e93b7017b1d9cee9a73 " rel ="stylesheet ">
58+
59+ < script type ="text/javascript " src ="../../../static/kunai/js/kunai-vendor.js?cachebust=759f03fc15b30d6368ce2e93b7017b1d9cee9a73 "> </ script >
60+ < script type ="text/javascript " src ="../../../static/kunai/js/kunai.js?cachebust=759f03fc15b30d6368ce2e93b7017b1d9cee9a73 "> </ script >
61+
62+ < script type ="text/javascript ">
63+ document . addEventListener ( 'DOMContentLoaded' , function ( ) {
64+ var kn = new Kunai ;
65+ kn . cpprefjp ( ) ;
66+ } ) ;
67+ </ script >
68+
69+ </ head >
70+ < body >
71+ < header data-kunai-mdinfo ="{"meta": {"header": ["optional"], "namespace": ["std"], "class": ["optional"], "id-type": ["function"], "cpp": ["cpp26"]}, "sources": [{"id": "0e9914a5a89a8df5a4751094875ee0f90b43d490", "source": "#include <iostream>\n#include <optional>\n\nint main()\n{\n std::optional<int> p1 = 1;\n for (auto i = p1.begin(); i != p1.end(); ++i) {\n std::cout << *i; // \uff11\u5ea6\u901a\u308b\n }\n\n std::optional<int> p2 = std::null_opt;\n for (auto i = p2.begin(); i != p2.end(); ++i) {\n std::cout << *i; // \uff11\u5ea6\u3082\u901a\u3089\u306a\u3044\n }\n}\n"}], "page_id": ["reference", "optional", "optional", "begin"]} ">
72+ < nav class ="navbar navbar-default " role ="navigation ">
73+ < div class ="container-fluid ">
74+ < div class ="navbar-header ">
75+ < button type ="button " class ="navbar-toggle collapsed " data-toggle ="collapse " data-target ="#navbar-collapse ">
76+ < span class ="sr-only "> Toggle navigation</ span >
77+ < span class ="icon-bar "> </ span >
78+ < span class ="icon-bar "> </ span >
79+ < span class ="icon-bar "> </ span >
80+ </ button >
81+ < a class ="navbar-brand " href ="../../../index.html ">
82+ < div class ="title-wrapper clearfix ">
83+ < div class ="title "> cpprefjp - C++日本語リファレンス</ div >
84+ </ div >
85+ </ a >
86+ </ div >
87+
88+ < div class ="collapse navbar-collapse " id ="navbar-collapse ">
89+ < ul class ="nav navbar-nav navbar-right ">
90+ < li >
91+ < div class ="google-search ">
92+
93+
94+ < script >
95+ ( function ( ) {
96+ var cx = '013316413321391058734:ji_u66hl7hq' ;
97+ var gcse = document . createElement ( 'script' ) ;
98+ gcse . type = 'text/javascript' ;
99+ gcse . async = true ;
100+ gcse . src = ( document . location . protocol == 'https:' ? 'https:' : 'http:' ) +
101+ '//www.google.com/cse/cse.js?cx=' + cx ;
102+ var s = document . getElementsByTagName ( 'script' ) [ 0 ] ;
103+ s . parentNode . insertBefore ( gcse , s ) ;
104+ } ) ( ) ;
105+ </ script >
106+ < div class ="gcse-search "> </ div >
107+
108+
109+ </ div >
110+ </ li >
111+ < li >
112+ < a href ="https://github.com/cpprefjp/site "> GitHub Project</ a >
113+ </ li >
114+ </ ul >
115+ </ div >
116+ </ div >
117+ </ nav >
118+ </ header >
119+
120+ < main id ="main " role ="main ">
121+ < div class ="container-fluid ">
122+ < div class ="row ">
123+ < div class ="col-sm-9 col-sm-push-3 " itemscope itemtype ="http://schema.org/Article ">
124+ < div class ="row ">
125+ < div class ="col-sm-12 google-search-result ">
126+ < gcse:searchresults > </ gcse:searchresults >
127+ </ div >
128+ </ div >
129+ < div class ="row ">
130+ < div class ="col-sm-12 content-header ">
131+
132+ < ol class ="breadcrumb ">
133+
134+ < li itemscope itemtype ="http://www.schema.org/SiteNavigationElement ">
135+ < span >
136+
137+ < a href ="../../../index.html " itemprop ="url ">
138+
139+ < i class ="fa fa-fw fa-home "> </ i >
140+
141+ </ a >
142+
143+ </ span >
144+ </ li >
145+
146+ < li itemscope itemtype ="http://www.schema.org/SiteNavigationElement ">
147+ < span >
148+
149+ < a href ="../../../reference.html " itemprop ="url ">
150+
151+ < span itemprop ="name "> リファレンス</ span >
152+
153+ </ a >
154+
155+ </ span >
156+ </ li >
157+
158+ < li itemscope itemtype ="http://www.schema.org/SiteNavigationElement ">
159+ < span >
160+
161+ < a href ="../../../reference/optional.html " itemprop ="url ">
162+
163+ < span itemprop ="name "> optional</ span >
164+
165+ </ a >
166+
167+ </ span >
168+ </ li >
169+
170+ < li itemscope itemtype ="http://www.schema.org/SiteNavigationElement ">
171+ < span >
172+
173+ < a href ="../../../reference/optional/optional.html " itemprop ="url ">
174+
175+ < span itemprop ="name "> optional</ span >
176+
177+ </ a >
178+
179+ </ span >
180+ </ li >
181+
182+ < li class ="active " itemscope itemtype ="http://www.schema.org/SiteNavigationElement ">
183+ < span >
184+
185+
186+ < span itemprop ="name "> begin</ span >
187+
188+
189+ </ span >
190+ </ li >
191+
192+ </ ol >
193+ < div class ="crsearch "> </ div >
194+
195+ </ div >
196+ </ div >
197+ < div class ="row ">
198+ < div class ="col-sm-12 edit-button ">
199+
200+
201+ < p class ="text-right "> < small >
202+ 最終更新日時(UTC):
203+ < span itemprop ="datePublished " content ="2025-11-12T11:34:03 ">
204+ 2025年11月12日 11時34分03秒
205+ </ span >
206+ < br />
207+ < span itemprop ="author " itemscope itemtype ="http://schema.org/Person ">
208+ < span itemprop ="name "> suomesta</ span >
209+ </ span >
210+ が更新
211+ </ small > </ p >
212+
213+
214+ < p class ="text-right ">
215+ < a class ="history " target ="_blank " href ="https://github.com/cpprefjp/site/commits/master/reference/optional/optional/begin.md ">
216+ < span class ="fa fa-fw fa-clock-o fa-flip-horizontal "> </ span > 履歴
217+ </ a >
218+ < a class ="edit " target ="_blank " href ="https://github.com/cpprefjp/site/edit/master/reference/optional/optional/begin.md ">
219+ < span class ="fa fa-fw fa-pencil "> </ span > 編集
220+ </ a >
221+ </ p >
222+ </ div >
223+ </ div >
224+ < div class ="row ">
225+ < div class ="col-sm-12 content-body ">
226+
227+ < div class ="identifier-type "> function</ div > < div class ="header "> <optional></ div > < h1 itemprop ="name "> < span class ="namespace " title ="namespace std "> std::</ span > < span class ="class " title ="class optional "> optional::</ span > < span class ="token "> begin</ span > < span class ="cpp cpp26 " title ="C++26で追加 "> (C++26)</ span > </ h1 >
228+ < div itemprop ="articleBody "> < p > < div class ="codehilite "> < pre > < span > </ span > < code > < span class ="k "> constexpr</ span > < span class ="n "> iterator</ span > < span class ="nf "> begin</ span > < span class ="p "> ()</ span > < span class ="k "> noexcept</ span > < span class ="p "> ;</ span > < span class ="c1 "> // (1)</ span >
229+ < span class ="k "> constexpr</ span > < span class ="n "> const_iterator</ span > < span class ="nf "> begin</ span > < span class ="p "> ()</ span > < span class ="k "> const</ span > < span class ="k "> noexcept</ span > < span class ="p "> ;</ span > < span class ="c1 "> // (2)</ span >
230+ </ code > </ pre > </ div >
231+ </ p >
232+ < h2 > 概要</ h2 >
233+ < p > < code > optional</ code > をrangeとした時の先頭要素を指すイテレータを取得する。</ p >
234+ < h2 > 効果</ h2 >
235+ < p > < code > < a href ="has_value.html "> has_value()</ a > == true</ code > なら、保持している有効値を指すイテレータを返す。またこの時、< code > < a href ="../../iterator/distance.html "> distance</ a > (begin(), < a href ="end.html "> end()</ a > ) == 1</ code > となる。</ p >
236+ < p > < code > < a href ="has_value.html "> has_value()</ a > != true</ code > なら、末尾要素の次を指すイテレータを返す。この時、< code > begin() == < a href ="end.html "> end()</ a > </ code > である。</ p >
237+ < h2 > 例</ h2 >
238+ < p > < div class ="yata " id ="0e9914a5a89a8df5a4751094875ee0f90b43d490 "> < div class ="codehilite "> < pre > < span > </ span > < code > < span class ="cp "> #include</ span > < span class ="cpf "> < a href ="../../iostream.html "> <iostream></ a > </ span > < span class ="cp "> </ span >
239+ < span class ="cp "> #include</ span > < span class ="cpf "> < a href ="../../optional.html "> <optional></ a > </ span > < span class ="cp "> </ span >
240+
241+ < span class ="kt "> int</ span > < span class ="nf "> main</ span > < span class ="p "> ()</ span >
242+ < span class ="p "> {</ span >
243+ < span class ="n "> < a href ="../optional.html "> std::optional</ a > </ span > < span class ="o "> <</ span > < span class ="kt "> int</ span > < span class ="o "> ></ span > < span class ="n "> p1</ span > < span class ="o "> =</ span > < span class ="mi "> 1</ span > < span class ="p "> ;</ span >
244+ < span class ="k "> for</ span > < span class ="p "> (</ span > < span class ="k "> auto</ span > < span class ="n "> i</ span > < span class ="o "> =</ span > < span class ="n "> p1</ span > < span class ="p "> .</ span > < span class ="n "> < span style ="color:#ff0000 "> begin()</ span > </ span > < span class ="p "> ;</ span > < span class ="n "> i</ span > < span class ="o "> !=</ span > < span class ="n "> p1</ span > < span class ="p "> .</ span > < span class ="n "> < a href ="end.html "> end()</ a > </ span > < span class ="p "> ;</ span > < span class ="o "> ++</ span > < span class ="n "> i</ span > < span class ="p "> )</ span > < span class ="p "> {</ span >
245+ < span class ="n "> < a href ="../../iostream/cout.html "> std::cout</ a > </ span > < span class ="o "> <<</ span > < span class ="o "> *</ span > < span class ="n "> i</ span > < span class ="p "> ;</ span > < span class ="c1 "> // 1度通る</ span >
246+ < span class ="p "> }</ span >
247+
248+ < span class ="n "> < a href ="../optional.html "> std::optional</ a > </ span > < span class ="o "> <</ span > < span class ="kt "> int</ span > < span class ="o "> ></ span > < span class ="n "> p2</ span > < span class ="o "> =</ span > < span class ="n "> std</ span > < span class ="o "> ::</ span > < span class ="n "> null_opt</ span > < span class ="p "> ;</ span >
249+ < span class ="k "> for</ span > < span class ="p "> (</ span > < span class ="k "> auto</ span > < span class ="n "> i</ span > < span class ="o "> =</ span > < span class ="n "> p2</ span > < span class ="p "> .</ span > < span class ="n "> < span style ="color:#ff0000 "> begin()</ span > </ span > < span class ="p "> ;</ span > < span class ="n "> i</ span > < span class ="o "> !=</ span > < span class ="n "> p2</ span > < span class ="p "> .</ span > < span class ="n "> < a href ="end.html "> end()</ a > </ span > < span class ="p "> ;</ span > < span class ="o "> ++</ span > < span class ="n "> i</ span > < span class ="p "> )</ span > < span class ="p "> {</ span >
250+ < span class ="n "> < a href ="../../iostream/cout.html "> std::cout</ a > </ span > < span class ="o "> <<</ span > < span class ="o "> *</ span > < span class ="n "> i</ span > < span class ="p "> ;</ span > < span class ="c1 "> // 1度も通らない</ span >
251+ < span class ="p "> }</ span >
252+ < span class ="p "> }</ span >
253+ </ code > </ pre > </ div >
254+ </ div > </ p >
255+ < h3 > 出力</ h3 >
256+ < p > < pre > < code > 1
257+ </ code > </ pre > </ p >
258+ < h2 > バージョン</ h2 >
259+ < h3 > 言語</ h3 >
260+ < ul >
261+ < li > C++26</ li >
262+ </ ul >
263+ < h3 > 処理系</ h3 >
264+ < ul >
265+ < li > < a href ="../../../implementation.html#clang "> Clang</ a > : ??</ li >
266+ < li > < a href ="../../../implementation.html#gcc "> GCC</ a > : ??</ li >
267+ < li > < a href ="../../../implementation.html#icc "> ICC</ a > : ??</ li >
268+ < li > < a href ="../../../implementation.html#visual_cpp "> Visual C++</ a > : ??</ li >
269+ </ ul >
270+ < h2 > 参照</ h2 >
271+ < ul >
272+ < li > < a href ="https://open-std.org/jtc1/sc22/wg21/docs/papers/2024/p3168r2.html " target ="_blank "> P3168R2 Give std::optional Range Support</ a > </ li >
273+ </ ul > </ div >
274+
275+ </ div >
276+ </ div >
277+ </ div >
278+
279+
280+ < div id ="sidebar " class ="col-sm-3 col-sm-pull-9 ">
281+ </ div >
282+
283+
284+ </ div >
285+ </ div >
286+ </ main >
287+ < footer class ="footer navbar navbar-default ">
288+ < div class ="container-fluid ">
289+ < p > < small >
290+ 本サイトの情報は、
291+ < a href ="https://creativecommons.org/licenses/by/3.0/deed.ja " rel ="nofollow "> クリエイティブ・コモンズ 表示 3.0 非移植 ライセンス(CC BY)</ a >
292+ の下に提供されています。
293+ </ small > </ p >
294+ </ div >
295+ </ footer >
296+ </ body >
297+ </ html >
0 commit comments