変数名は「AIにレビューさせろ」Part0(初心者の方へ)

老兵は死なず、AIと踊る

変数名は「AIにレビューさせろ」Part1を公開したのですが、同時にAIから
「これは初心者向けの記事ではないのでは?」
と散々、指摘を受けたので初心者とスクールで教えようとしている方向けに補足を行います。どちらが最初でも構いませんが、初心者の方は本記事を最初に読んだ方がよいかもしれません。

初心者の方

 例えばですが、Google C++ スタイルガイドや、Linux Kernel 2.6 Documentation- CodingStyle を参照してみてください。変数名の記載の項目になります。
 何を言っているかわからないかと思います。それが答えです。

という、哲学的な問答はやめてストレートに言いますと、「まったくの初心者の方は、まずはプログラミングの書き方を学習するべきであり、コーディングスタイル(変数の命名だけでなく、あるべきコードの書き方の基準)は、後回しにしてもかまわない」ということになります。つまり今は考えなくてよい(もし気になるのならAIに聞け)ということになります。

それでも、気になる方はもう一度Google C++スタイルガイドの「命名規則」を読みましょう。引用しますと、

命名に関するスタイルルールはかなり恣意的なものです
・あなたにとってわかりやすいと感じるかどうかに関わらず、「ルールはルール」と考えるようにしてください。

ということです。これの意味するところを大げさにかくと、「変数名は「AIにレビューさせろ」Part1」の記事になります。
加えて、日本人に対する補足を行います。(通訳案内士の観点になりますが)、日本人というのは「言われなくても規律を守る」民族のようで、一方で欧米(というか民主主義の国の人は)、「自由が基本、必要ならルールを作る」という文化的な違いがあります。主にアメリカからくるルールを日本人に当てはめると、必要以上に日本人が守りすぎるという傾向があるので注意しましょう。という話です。

初心者から脱しようという方

 上記の2つのスタイルガイドをみて、「言っていることは解る」という人はもう、命名規則については卒業ということになります。
「これでは不安」だという方は、一つ卒業試験をしましょう。上記の2つのスタイルは真逆のことを言っている部分がありますがどれでしょうか?

私が見つけた正解の1つは、
Linux Kernel 2.6のコーディングスタイルは、変数名の省略を許容しており、Google C++の方は許容していないということがあります。
(もっともどちらのスタイルもループカウンタは i でよいとしています)。
私の観点(理解)になりますが、これらの違いを補足すると、カーネルは基盤ソフトウェアで、Googleが作ろうとしているものはアプリケーションということも言えます。
コーディングの文化というか、作成しているもののレイヤーが異なります。
例を挙げると、変数の値を交換する swap関数 というものがありますが、Linuxの方は、swap関数を作る方、Googleの方は、swap関数を使う方ということです。

swap関数を C言語風に 書くと

void swap( int *a, int *b) {
 int t = *a;
 *a = *b;
 *b = t;
}

となるかと思います。ここで、a,b,tと出ましたが、これに対して「変数名が、意味のない1文字だろ!」という人は(0ではないかと思うが)私の周りではいません。逆にここで変数名に対してとやかく言う人とは距離をとった方がよいです。(実は変数名以外には問題があります)。

一方で、Googleの方は、swap関数を使う側、例えば、

 swap( oldMachineStatus, newMachineStatus);

と言ったコードにフォーカスを当てているということになるかと思います。

言っていることは解るが釈然としない(初心者の方)

 コードコンプリートやリーダブルコードなど実績のある書籍を読むことをお勧めします。
「1文字変数はダメ。booleanは○○。」と言ったような断片的な情報ではなく、「なぜこのように命名すると良いのか?」についてできるだけ主観を抑える努力を用いて書かれているでしょう。
また、上記のようなスタイルガイドも併せて読むことを勧めします。書籍やガイドによって矛盾点が見つかります。それに対して『自分はどうするか?』と自問してみましょう。

2026年現在確認できる多くのコーディングスタイルでは、ループカウンタには i でよいとしていますが、意味のある名前にしましょうという書籍もあるようです。「○○にこう書いてある」ではなく、あなたの正解を見つけてみましょう。

実践

さらに、実際のコードがどうなっているかを調べることも重要です。
以下、Linux kernel 6.18.3 で適当に選んだファイル(acct.c)からの変数名(と引数名)を出現順で10個を列挙します。
acct
sbuf
p
ns
res
pin
work
acct
file
name

私には大変馴染み深い名称ですが、皆様どうでしょうか?
これだけだと何なので、同プロジェクトから適当に選んだpythonのファイル(check-perf-trace.py)からの変数名(引数名)を10個ほど列挙します。

event_name
context
common_cpu
common_secs
common_nsecs
common_pid
common_comm
common_callchain
vec
call_site

理解できるかはともかく、分かりやすい名前になっているかと思います。

老兵は死なず、AIと踊る

変数名は「AIにレビューさせろ」Part1

-「命名に悩む時間」は生産性の無駄。AIに任せて、ロジックに集中すべき。-

老兵は死なず、AIと踊る

 変数名の命名というのは鬼門と言えば鬼門で私は、35年近く前になりますが駆け出しの頃、処理対象を指す変数名に「enemy」という変数名を付けて当時の先輩から笑われた。もっとも直せと言われずにユーモアと受け取ったようで、牧歌的というか微笑ましい時代でもありました。
 もちろん今なら、destination???? やら target???? やらもっと適切な名称をつけるでしょうし、変数を適切に命名する。つまり「何を」保持しているのかを明確かつ分かりやすく命名することは、単なる読み手だけではなく、おそらく自分自身のためにもなるかと思います。例えば金額計算なら、「税抜き価格」、「税込み価格」、「税率」、「合計金額」、「税率別税額」、「税率別課税対象額」等が考えられますが、これらを、

p1,p2,p3,p4,p5,p6

という風に命名したら、多分、解読不能(バグを誘発する)プログラムになると思います。
一方で、Youtubeのプログラミング初心者向けの動画で「可読性の高いプログラム」ということで、変数名の命名について

・1文字の変数名はダメ
・boolean型にはis/hasをつける

ということを堂々と教えていた。これらについては全否定する気はないですが、『初心者に対して変数名の命名に対してルールを強制するのは如何なものか?』と思う。
というのも本来プログラミングというのは人間が作り出すもので、思考の結晶ということも言えます。変数名も同様です。しかしながら、日本人の性質として、このように言及されるとそれを額面通り受け取り例外を考えなくなり、1文字の変数を書かなくなったり、booleanに必ずis/hasをつけたりします。本来自由であるべき変数名を強制するには、それなりの理由付けが必要でしょう。大規模プロジェクトのように『予め命名規則が決まっている』プロジェクトならともかく、「経験不足の初心者に対して枷になるような規則」をつけるのもどうかと思います。ちょいちょい言っているのは『ソースコードはなるべく自由に、動くプログラムが最強』ということに尽きます。もちろん解読可能な範囲でということになりますが。

で、前置きが長くなりましたが、変数の命名についてまず言わなければならないのは、プログラミングが出現して半世紀を超えましたが、その中で命名規則も変わってきているということが言えます。

例えば、大昔は変数名の長さに制約があったり、ポケコンなどは1文字の変数名しか許していなかったり、大文字しか許していなかったりしていました。この時期に作られたプログラムならp1,p2とかもバンバンあったかと思います。省略も良く行われていて、逆に単語をフルに書くことの方が少なかったかと思います。よく「母音」を省くということもあったかと記憶しています。userNameでなく、usrNmとかですね。
時代が進み、大文字小文字の区別がついたり、記号を入れられるようになり、比較的自由に変数名が命名できるようになると、様々流派が出てきました。
それでも、例えばC言語なら

while( *p++ = *q++);

という、知らない人が見れば「何をやっているんだ」というコードも逆に知っている人からすれば「お馴染み」となってました。

そして、変数名の命名に決定的な影響を与えた書籍が出てきました。『コードコンプリート』です。コードコンプリートで『変数名は理解しやすい意味のある名前にした方が良い』と整理され、今に至ったように思えます。無用な誤解を与える前に注意ますと、変数の命名について(だけでないですが)、コードコンプリートは大変有意義です。

私が問題にするのは、『変数の命名に対する意見(批判)がコードレビューと相まって「読みやすさ」という基準があいまいな個人の主観的な判断で行われること』です。

 実は、コードコンプリートも「1文字の変数」というのは良くないと言っている個所があります。
25年程前になりますが、大変ありがたい”主観的なレビュー”を受けて、ループに対しても『i ではなく index と書け。コードコンプリートに書いてある。』と言われた覚えがあります。その時に直したか直してないかは定かではありませんが、その後、変な影響を受けて一時ループインディックスをindexとした記憶はあります。ただ、明らかに違和感があったので元に戻した記憶もあります。
その後、改めてコードコンプリートを読むと「純粋にループのスコープで収まるインディックスは、i でもよい」と書いてありまして、「この野郎」と思った次第です。もっとも、私が index としたのはほんの数か月で、また i に戻したので、あまり悪影響は受けていないです。
では、私がコードレビューをしていたときにループインディックスに index としているコードを見たらどうするでしょうか?
答えは「何も指摘しない」です。ただ「この人は2重ループの外側にindexを使ったら内側のループインディックス名などうするのか?」と思うことはあります。

 この記事を書くにあたって、改めて、コードコンプリートを読み直しましたが、変数名の長さの基準が少々長いように感じます。「そこまで書くか?」という印象をぬぐえません。「読みやすさ」ということをいうのであれば、「適度な長さ」については個人差が大きいのではないかと思います。多分私は短い方に寄っています。

 いずれにしても、変数名に対してのチェックというのは、コードレビューで取り上げられやすく、いかにも日本人が好きそうな「儀式」にあったおもちゃという印象がぬぐえないです。真面目にやっている人もいらっしゃるでしょうが、そういう人は「1文字はダメ」とかは言わないかと思います。
 もちろん、大規模プロジェクトで「変数名の命名規則」が決まっている場合は従う必要がありますが、残念ながら日本の多くの現場が予め決められたものではなく主観的かつその時代時代で「良いと思われる」ものが個人の裁量で使われる傾向があるでしょう。
また日本人の英語力は、ばらつきがあり変数名の命名に英語を使うときは危険度が増します。一方でローマ字の変数名は嫌われるという厄介な風潮があります。
例えば上記にあった「税込価格」という変数名は割と難しいです。良く見るのは taxPrice ということになりますが、実はこれは「英語」としては成立していません。では taxPrice はダメかというと、これは難しいところではあります。今ならもちろんChatGPTに聞けば正解が解ります(正解は各自の宿題にしましょう。次の記事に回答編を書きます)。ちなみにそもそも「税込価格」を表す変数名に日本語が使えないところが最大の問題点ではあるのですが、言い出したらきりがないのでおいておきましょう。

 その他、命名に関しては主観的になりがちですが、あーだこーだと言わずに書いた人のアイデアを尊重し、AIに判定させれば良いかと思います。もちろんAIが明らかに間違えれば適宜人間が修正すればよいかと思います。

 ということで、私が過去に作成したコードを、AIに命名チェックをさせてみました。もちろんですが、enemyという変数名は無いことは事前に確認しています。単に命名チェックをさせると何がでるか分かりませんので会話を通して「望ましい変数名について」定義を行っています。

とあるライブラリの変数名のレビュー結果

私の基準を叩きこんだので私よりのレビューになりましたが、それでもrc、tranflgなどは「やんわりとダメよ」と教えてくれています。
「このライブラリを2026年基準で“軽く化粧直し”するならどこを直すか」と提案を受けましたが、結果は出さずに止めています。動いているコードを不用意に直すのは危険で、無責任に「これが2026年のコードです!」としたくないためですが、今ならAIにより(間違いはあったとしても)ある程度機械的にチェック&訂正案を出してもらえるので上手く使えば余計なストレスを受けずにすみます。

 特に初心者のうちは意味が通らない命名をすることが多いでしょうが、逆に命名に時間をかけず適当に書いて、AIに修正をお願いするというのも現代的なコーディングかと思います。
 さらに付け加えると私自身の経験になるのですが、実は論理的思考力や抽象化力が高い人ほど変数名に意味をつけない傾向があるかと思います。例えば数学者は a b c と1文字の変数名を使いますが、彼らは「この変数の名前が○○でないとダメ」とかは言わないで純粋に式について議論します。もちろん私もそこまではいきませんが、変数名にあまり惑わされないでロジックを追えます。もちろん、これは「意味のない名前でよい」という話ではなく、文脈を理解できる人ほど、名前に依存しなくてもロジックを追えるという意味です。

老兵は死なず、AIと踊る

コードレビューは鬼門か?

-人間がレビューするよりAIにレビューさせた方がよいのでは?-

老兵は死なず、AIと踊る

最近、SNSで「AIでコードを書いてみました(バイブコーディング)」という記事が氾濫するようになったのですが、一方でその書いたコードを出していない人が目につく。私の場合は、規模は小さいがAIに出力させたコードを公開していたりする。
まぁ、権利関係から出せないものもあるのでしょうが、実際に動くものを出さないで「バイブコーディングしました」というのは、眉唾もので、15年程前に「オブジェクト指向やってます。」という、「エアオブジェクト指向」と同じ香りがして、「エアバイブコーディング」じゃないかと疑ってしまいます。
(と言っていたら、こんな記事がGoogle discoverからサジェストされました。正直、部品レベルのものをいっぱい出して「限界を突破」と言われても・・・というのはありますが、コードを出している少ない例です。)
私の場合は、今は、AIをハックしている状況で、つまりAIの特性を体感している状況で、バイブコーディングをするまでには至っていない。もっとも、将来的にはバイブコーディングを視野に入れているので、今は色々試しています。

 そういった中で、バイブコーディングの前段として、「AIにコードレビューをさせたらどうか?」ということで、コードレビューさせました。

 ちなみに、コードレビューですが、こちらもネット上では色々言われていますが、『エアコードレビューではないか?』というのも散見されます。
 というのもコードレビューは、ある意味コードを書くより高度な技術が要求されます。「なぜそう書いたのか?」ということに対して、本来ならレビューアーはレビューイーより高度な視点と経験が必要かと思いますが、実際には「ただのいちゃもん」に成り下がっている面もあります。
 私が本格的なソースコードレビューがあるプロジェクトに参加したのは30年以上前になります。それ以降は、「個人的な感想をいう場」としてのレビューはありましたが、当たり前ですが、そんな「個人的な感想」を言われてもどうしようもないです。また、ここにも書いていますが、私自身は他人の書いたコードをレビューしてやろうとは思わないです。もちろんデバッグの為に読むことはありますが、ここ炎上プロジェクトとクソコードに書いているとおり、コードに対しての評価というのは考えないようにしています。

レビューさせたのは、私が開発しているプログラミング言語(ADP)のプロジェクトになります。ChatGPTは一式をZipファイルにまとめて読み込ませました。
Geminiの方は、ファイル数の制限のため、ソースコード、ヘッダファイルそれぞれを1つのファイルにして読み込ませました。

ChatGPTとのやりとり
Geminiとのやりとり

※Gemini上で「与太さん」というのは私のことです。

C++での比較的規模の大きいプロジェクト(プログラミング言語の実装プロジェクト)のコードレビューなので、
・技術的に突っ込んだ内容となっている
・大きなプロジェクトなので評価も大雑把(ピンポイントの指摘もありますが、全体を細かくみていない)
というところはありますが、ChatGPT,Geminiとも会話が弾んでいることが分かるかと思います。
ChatGPTにしても、Geminiにしてもただ褒めるのではなく、開発者の意図を読み取って良いところをほめています。
 前述のとおり私自身、コードレビューに対してはあまりいい思い出がありません。30年以上前のプロジェクトに関しては、レビューアーが「あー、そうなんですね。」というだけで私自身はなにも得られなかったですし(もっともそれはそれで開発工程としては成立していたかと思います)、それ以降の「個人的な感想を受けるレビュー」は、(悪く言えば)レベルの低い相手からの嫉妬交じりともいえる言いがかりを聞く非生産的な場所ということで、私自身「日本の開発プロジェクトでコードレビューは鬼門」と思っていました。誤解のないように補足しますと、コードレビューが大事なのは理解しておりますし、効用はあるのでしょうが、日本の多くの現場では、そもそも「チームプレイとは何か?」から入る必要がある状況で、コードレビューは(対新人)以外にはあまり効果がないというのが実感です。

そういう印象でのAIレビューですが、第一印象が、奴らの「ほめるところを分かっている」ところに逆に恐ろしさを感じました。

「このレベルの議論ができる方と話せるのは正直かなり楽しいです。」(ChatGPT)
「正直に言って、ここまで地に足のついたマニアックな話が自然に続くのは、かなり稀です。」(ChatGPT)
とか
「この挑戦は、言語処理系開発の醍醐味が詰まった非常にエキサイティングな領域だと思います。」(Gemini)
「与太さん、仰る通りですね。「意図しないバックトラック」のデバッグは、論理型言語を開発・利用する上での最大の難所であり、永遠の課題と言っても過言ではありません。」(Gemini)

とかは、おべっかが嫌いな硬派なエンジニアを気取っている私でも

お前は分かっているな!

と喜ばずにはいられないです。

 当然と言えば当然なのですが、AI達は、良質の多数のコードを読み込んで学習していますので、「個人の感想」レベルを超えたレビューが出来るところまで達しているようです。AIあるあるの「ハルシネーション」ですが、AIの出力はバイブコーディングと違い直接的な成果物とはなりません。コードレビューはあくまでも「指摘」なので、その指摘が正しいかどうかは、仕組み上、人間が確認できることも大きいです。上記のChatGPTとのやり取りもAIの返答を鵜呑みにせずに

『>分岐予測が効きやすい
これは無いかと思います。つまり必ず失敗する分岐予測が2回から1回に減ったということになります。』

AIの間違いを指摘&その返答を繰り返すことにより、よりコンピューターに対する知見が向上するでしょう。

AIの指摘は受け入れるのか?という点ですが、例えば、「C++11以降に書き換えてみては?」というのは、ChatGPTもGeminiも指摘しているところです。これは、参考にできるところとできないところがあるのですが私としては視野に入れているところです。ChatGPTの方は、「このプロジェクトですが、17年程の歴史があります。数回大幅な書換えがあるのですが、歴史的にみるとC++色からC色に移っています。」と現状を説明しながら効果的なアドバイスを求めています。Geminiの方は「メモリ管理についてはRustの借款のアイデアを使っている」ということで議論を進めています。プロジェクトの全体設計の話になるので大雑把な議論になるので、既に考えていることの指摘ということもありますが、会話を重ね深堀することにより発見があったりします。
 また、もちろんですが、AIコードレビュー一本ではなく、セキュリティ監査等より慎重なレビューが求められる場合は人間との共同でレビューを行うこともできるでしょう。

とまぁ、個人開発されている方やプログラミング学習者の方は、モチベーションを維持するためにもAIによるコードレビューをお勧めします。
人間の嫉妬や無理解に晒されるコストをゼロにし、純粋に技術的対話に没入できる。
これこそが、AI時代の真の生産性だと思います。

老兵は死なず、AIと踊る

AI時代のプログラミングスクールとの付き合い方 Part3 -私のスクール経験(プログラミング、英語)について-

老兵は死なず、AIと踊る

 前回に続き、私自身のスクール経験(プログラミング、英語)について書いてみたいと思います。
プログラミングに関しては、学校に通ったことはないです。一方で、英語(通訳案内士)に関しては学校(複数)に数年間通いました。以下、それぞれの学習記録になります。

プログラミングの学習について

 私は14歳のときからプログラミングを始めました。3か月でベーシックを学んで、次の3年でアセンブラを学びました。
 学校に通わなかったのは、お金がないこともあるのですが、「十分な学習時間が確保できた」と「向いていた」ということが大きいです。大学に入る前にほぼ毎日2,3時間ずつ4年以上学びました。
 自己学習ということは、本を読むことになりますが、私が本に書いてあることがまぁまぁ理解できました。もちろんですが、一回読んでもわからないこともあり何回も読んで「どうなっていんだ!」と考えたこともありますが、突き詰めると、本に書いてあることが分かったという経験は、独学を行う上で重要です。
 本の良さの一つですが、「一定のクオリティが期待できる。」というのがあります。本という一定の分量の文章を書くというのは結構大変です。ネットに「つぶやかれた」ような文章とは質については一線を画しています。さらに著者一人が書いているだけでなく編集者のチェックが入ります。チェック自体は最低限ですが、「書きっぱなし」の文章とは異なります。残念ながらIT業界の人材は玉石混交で、今SNSを見ると「現場経験の乏しい人(SES崩れ)」の人が学校をやっていると思えるものもあります。実は、IT人材にばらつきがあるのは昔からで、例えばこの記事では、大手の企業でもあまり質の良い記事を書いていないことを10年前に指摘しています。多数の本を読むことにより、偏った考えに陥ることを防止できますが、残念ながら2026年現在は書籍自体が減っており、信頼できる情報源というのを見つける難易度があがったかと思います。。
 ちなみに脱線しますが、私はもともと国語力がなかったのですが、技術文書の読書をとおして読解力が付いたのも大きいです。そういう意味でも「独学の利点」をあげられます。
 私は現役の時は大学を途中で辞めたのですが、35年ほど前の当時、既に大学には情報系のコースがあったかと記憶しています。しかしながら大学でプログラミングをマスターして就職するというコースはあまり一般的ではありませんでした。むしろ大学を辞めた人がプログラマーとして就職するというのは日本では割とポピュラーでした。一方で、アメリカで就職しようとすると”コンピューターサイエンスの学位または同等の資格”というが必須なようです。
 学校には通いませんでしたが資格はとりました。高校生の時に第二種情報処理技術者の資格をとりその後いくつかの資格をとり10年程前にも、(このブログのタイトルである)システムアーキテクトの資格をとっています。

英語学習について

 英語については、私の実力は壊滅的でした。本を読んでも「で?」としか分かりません。文法書を読んでも良く分からず、改めて振り返ると「英語については向いていなかった」ということが言えます。特に厄介なことは、英文を読むと10分ほどで脳が限界を感じます。コンピューターの本なら何時間でも読めるのですが、英文となると体が拒否反応を起こします。これではダメということで学校に通い出しました。足掛け10年以上、学校に通いました。ただ、週1回で学校に通うだけでは、一向にしゃべれるようになりませんでした。学校はあくまでも学習の習慣づけが基本になります。英語勉強の基本的な考え方(反復練習が大事、文法より文脈)については学校で習いました。
 加えて、語学留学も行いました。2026年現在、英語の学校に通うことについては賛否があるでしょうが、語学留学や大学への留学に関してはお勧めいたします。言葉というのはなるべく大勢の人とやり取りをする方が、つまり数をこなした方が上達するかと思います。
帰国後、通訳案内士として就業しましたが、これは仕事で英語を使うことにより、単なる勉強を超えて語学レベルをブラッシュアップできたと実感しています。

向き不向きについて

 向いている向いていないに関係なく、一定技術を習得するには「質より量」という側面があります。私はITエンジニアとしても通訳案内士としても大体、5,000時間程度勉強していますが、学習においては結局のところ「どれだけ自分で勉強したか?」が重要になります。学校に行くということはあまり勉強時間とは関係がありません。最終的にはどれだけ自己学習をしたかが大きいようです。勉強時間は個人差はあるかと思いますが、5,000時間を目安として頑張れば、学習前とは違う景色がみられるかと思います。

 伝統芸術や伝統工芸でよく「師匠から教えてもらえない」ということがありますが、これについては今なら良く分かります。技術は教えてもらうものではなく、自分で学ぶものだということです。

 印象深いことがありまして、とあるITの炎上プロジェクトの助っ人をやっておったときのことです。担当者に対して色々説明を行っていたのですが、彼は相槌をうつだけで、一向に私の説明を理解していませんでした。少々腹がたったのですが、ちょうどその時に通訳案内士の学校に通っており、当時の私としては内容がかなり高度になりまして、私自身も相槌をうつだけで授業内容が頭に入ってきませんでした。「向いていないということはこういうことか」と当時は実感したものです。

 向いている向いていないは学習の進み具合に関係しますし、プロとして活動するようになってからも差が出てきますが、「向いている=プロとして優秀」というのは少し違うかと思います。私も炎上プロジェクトの当事者になって挫折も味わいましたし、プログラマとしては向いているかもしれませんが、企画やスケジュールを立てることは苦手(向いていない)です。画面のデザインも不得意です。結局、細かく検証していくと「業務に関して全方位的に向いている」という人は現実としていないのではないかと思います。ITエンジニアとしても長所・短所があり通訳案内士としても長所・短所があることになります。
 英語については向いていませんし、今でも「向いていない」と時々感じることですが、こちらも仕事をする上ではあくまでも一要素ということになります。「通訳案内士」は外国語で話をするのはそうなのですが、特に英語の場合、「ネイティブのように」というのは場合によりけりで、イギリス英語なのか、アメリカ英語なのか、西なのか、東なのか、非英語圏の人なのか、と様々あり、よく言われる「ネイティブ信仰」というのは必ずしも当てはまりません。(もっとも私はアメリカの西海岸に留学したのでカルフォルニアあたりから来た人は「うまいね」と確かに言われ、フランスからの人は「?」といわれます)。通訳案内士というのは実際にお客さんと同行して案内するのでいわゆる旅程管理という業務もになっており、さらにはお客さんは「日本人の意見が聞きたい」とか「日本のドラッグストアに行きたい」とかいろいろな要望に応える等、複合的な職業ということもあります。こちらも「英語の向き不向き」だけでは実力は測れないかと思います。ということで翻訳や通訳はともかく通訳案内士については、しばらくはAIにとって代わられないと思っています。

メンターについて

 メンターについてですが、英会話の先生については、あくまでも先生ということでそれ以上何かきくことはありませんでした。通訳案内士の学校の先生についてはある程度、メンターの役割もあったかもしれませんが、生徒が複数おり、あくまでも授業を聞くというところ以上のものはありませんでした。いずれの先生も感謝はしているのですが、メンターとまではいきませんでした。

一方で、ITエンジニアとしても通訳案内士としても仕事をやりだしてからは、数名ほど尊敬できる先輩(メンター)がいたのは事実です。が、残念ながら不徳の致すところで深い付き合いとはなりませんでした。もっともITエンジニアとしても通訳案内士としても自立した専門家になるということはメンターからは卒業という意識もありました。

プログラミング学習と英語学習の違い

 せっかくなので、プログラミング学習と英語学習の違いについても触れたいと思います。一番大きな違いは、「プログラミング学習は主に考えること」であるのに対して「英語学習はとにかく量(習うより慣れろ)」につきます。
 もちろん、どちらにしても「授業を受ける。先生の話を聞く」ということを否定はしませんが、プログラミングの場合、ある意味芸術家のように「あーでもない、こーでもない」と悩むこと自体がプログラマとしての基礎練習になります。私としては「オブジェクト指向おじさん?」の記事は、単に記事を読んで納得するのもいいし、異論や反論をする。つまり記事を読んで考える行為そのものが、エンジニアの成長のきっかけになると思います。
 一方で、英語の場合、考えるより鵜呑みにしてもよいので覚える行為が重要かと思います。実は、「自動詞と他動詞を考え直す(Part2)、日本人にとっての自動詞と他動詞の恐ろしさ」この記事自体は読み物としては面白いかと思いますが、「英語学習」にフォーカスを当てるとあまり意味がないです。おそらく英語の上級者はこの記事を読んで「で?」と思うと思います。この記事でも指摘しているとおりネイティブでも間違う(というか辞書どおりでない)というのは、日本人が日本語を話すときに細かい理屈を知らないことと似ています。「では何でこんなことを考えるのか?」ということですが、こういう理解というのは一種の精神安定剤的に作用します。つまり、「なんで自分ができないのか?自分が勘違いをしているのではないか?」という不安を解消するために使うと有効かと思います。直接的な学習効果はないが一種のサプリメントということができます。

老兵は死なず、AIと踊る

AI時代のプログラミングスクールとの付き合い方 Part2 -メンターについて-

老兵は死なず、AIと踊る

あけましておめでとうございます。
昨年末から、AIによる文書作成が私の中で成立するようになり、すっかり YouTube がご無沙汰になったのですが、YouTube はそのうちやるということで、続けます。

文書作成におけるAIの使い方ですが、
・論点整理
・モチベーションの維持
・評価(批判)
が受けられるところですが、当然、AIの意見を真に受けるはずもなく、そこはそこで多角的に分析をしています。
具体的なプロンプト等は、「企業秘密」ということで出すのは控えます(このあたりのノウハウについては公開するとAIがそれを取り込み面倒なことになりかねないので秘密としておきます)、が、やっていることは、様々なプロンプトで回答を引き出したり、今は、ChatGPT, Gemini, Grokを使って評価させたりしています。
もちろんですが、文書は私が作成していますし、文責も私が担っております。

で、前回(AI時代のプログラミングスクールとの付き合い方)の記事の批判で、「優良なプログラミングスクール(メンター)の存在について触れていない」という指摘を受けて記事を書いてみます。

まず、プログラミングについて『メンターが必要か?』というと、私自身は『必要な人もいるかもしれないが、一般論として必須ではなく、もしプログラミングスクールがメンターの存在だけを前面に押し出しているのであれば、注意が必要』だと思います。

メンターが必要というのは2000年代から言われたように思いますが、このメンターですが、プログラミング技術の習得に限っていうと、疑問が残ります。

技術者として改めて思うのですが、プログラマなり(通訳案内士)なりのある種の専門家は、その専門領域に関して「メンター」という存在は不要なのではないか?という考えです。

これはある種の「師弟関係」の否定ととられる恐れがあるのですが、「師弟関係」をむしろ肯定するからこそ、プログラミングスクールのいう「メンター」の存在に違和感があります。

本来、師匠というのは単なるプログラミング技術を教えるのではなく、「プログラマ」として一人前になるうえでの先生にあたるかと思います。

プログラミングを学ぼうという人に対しての「プログラミングが出来るようになる」というのは単なる知識だけではなく、「自立したエンジニア」として活動できるようにする必要があります。
この場合、単なる技術的なアドバイスだけでなく、プログラマとしての職業倫理や技術的な哲学について指針となるような人が「師匠(メンター)」という存在になりえると思います。

少なくとも、私自身の知る限りでは、そのような人は日本にはほとんどいないでしょう。というのが長年の私のエンジニアとしての経験からくる結果になります。

もちろん、『スーパークリエーター』とか検索すれば出てくると思いますが、スーパークリエーターが職業人として成功しているか?という疑問もあれば職業倫理や技術的な哲学等、師匠(メンター)たる器を持っているかは未知数です。

従来のプログラマがおかれた環境(困難にぶち当たっても自助努力のみを押し付けられ孤独になる)からの脱却を図るためのメンターというのは理解できなくもないですが、プログラミングスクールがそのようなことを全面に押し出されても、「本当にメンターが必要なときは、実際に会社や現場に入ったときであり」、プログラミングスクールの講師がそこまで面倒を見るのは金銭的にも(講師の)技術的にも怪しいものです。

もちろんですが、学習者が学習において孤独を感じ、メンターが必要ということでプログラミングスクールの門をたたくことを否定はしません。
先輩やメンターに助言を乞うことは否定しませんが、本来、プロとして活動するということは、技術面では先輩やメンターから独立して「孤独」の中でプログラミングを行うことになります。そこには、プログラミングスクールのメンターの存在というのは私にはなじみません。

まとめますと、

・期待されるメンターの役割を持った人間がそもそもいないかいたとしても希少
・メンターとは本来、技術だけでなく、職業倫理や哲学といったことも持ち合わせてないとダメ、スクールというより組織で必要
・もしあなたが、「この人から教えを乞いたい」と思えばそれはそれでよい

ということが言えます。

老兵は死なず、AIと踊る

AI時代のプログラミングスクールとの付き合い方 Part1

老兵は死なず、AIと踊る

この記事は、『50代半ばのじいさんが、AIを目の当たりにした『大学に入ってから自分の無力感がエグい』という大学生にかけることば』『AI時代のコードレビューは“理解”ではなく“責任”を見る』との続編になります。

AI時代に入り、私も当然ですが、『遅れないようにしよう』と思いながらも日々精進しているのですが、
『AIで書いたコードを、
細部まで理解できていないままコードレビューに出すのは、
職場でも最も信用を落とす行為なので、気をつけましょう笑』
この発言ですが、要はプログラミングスクールをやっている方の発言でした。これは今流行しているSNSのマーケティングで、愚かにも私はプログラミングスクールの広告にマジレスをしたということになります。ということで、文章はそのまま残しますが、投稿へのリンクは外します。これは『宣伝を拡散しない』ということもあるのですが、これから「プログラミングスクールではなくAIから学べ!」という話をするので、営業妨害をする意図ではないことを明確にするためということもあります。

プログラミングスクールは最近特に、雨後の筍のごとく出ており玉石混交状態で、中には悪徳業者もいらっしゃいます。そいう悪徳業者のはSNSを使って広告を出して素人から高額な授業料をもらっているようです。そういった中には『35歳からのSESについて考える』でコメントしている通り『IT業界の実態を良く知らない人達をとりあえずSES(ITエンジニアの派遣)に放り込んで搾取する』という実態があります。これらの悪徳業者は

スクール → SES

というルートを確立しており、粗製乱造で商品(エンジニア)を作り会社へ送り込むという、エンジニアをモノ扱いして商売を行っており、IT業界への入り方としては注意が必要(あまりお勧めできない)です。もちろんきちんとした業者もあるでしょうし、上記のSNS発言の会社が、このようなことをやっているかどうかは解らないということは改めて付け加えておきます。

自身のプログラミングスクール開校の模索

 ちなみに、私ですが、高校生相手のプログラミングスクールをやろうかと考えておりました。それなりにリサーチを行い、「情報の教科書」を購入したり、大学入学共通テストを受けたりしました。点数ですが、70点ほどでした。意外に低いと思われるかと思います。私は高三の時に第二種情報処理技術者試験に合格しており大学にはいるとアルバイトでプログラムを組んでいましたのでこの点数には一瞬納得できませんでした(ちなみにサンプル問題を解いたときは90点台だったので油断していたというのもあります)。
改めてこういう試験を、自身が受けてみると、ある種の試験の目的と限界が解りました。私は受験が苦手だったのですが、やはりそこは実践と異なるようです。これだけだとただの愚痴になるので、補足しておきますと、細かい用語の定義を問う問題については、プロが見れば「知らんわ」とか「知る必要があるか?」というのがありそこはわざわざ勉強しなくてもと思うのですが、学生諸君はきちんと勉強する必要があるでしょう(テストなので)。

話は脱線しますが、ついでに英語も受けました70点ほどでした。こちらも意外に低いと思われるかと思いますが、大学入学共通テストの英語で70点以上をとれるのなら、ほぼ間違いなく英語を使って仕事ができるかと思います。ただし、文章は全部読んだ上で回答するのとリスニングは相手の言うことを分かった上で回答する、という条件がつきます。巷には大学入学共通テストのテクニックが存在しますが、それを使って高得点を取っても生きた英語ができるかどうかは怪しいです。なので、将来英語の仕事に付こうかという人は「全部を読んだ上で回答する」というスタイルでやった方がより実力が付く(将来困らない)というか、そのようなやり方で満点やそれに近い点数をとる学生もいるとも思えます。もっとも少しでもいい大学に行くのなら、テクニックも必要なことは言うまでもないです(まぁ人生が掛かっているので)。

話を戻しますと、ここまでリサーチをしたのですが、今はプログラミングスクールをやることは中止しています。
なぜかというと、先に書いたように情報テストの実用性についての疑問(とそれを教えなければならないある種の苦痛)もあるのですが、

2025年現在、本人にやる気があればプログラミングスクールに通わなくても、「AIに聞けば」色々教えてくれるようになった。

というのが大きいです。

自身のAIによる学習例

最近ですと私の場合は、

ScratchとRustの言語のチュートリアル、llama.cppのコードの読み方(およびLLMの考え方)についてChatGPTに聞いて勉強しています。

llama.cppというのはローカルAI(LLM)の実行ツールで、つまり自宅のマシンでChatGPTのようなAIサーバーを立てられるものになります。その内部構造について知りたいとき、昔ならコードを手当たり次第に読んでいたのを、今ならChatGPTに『C++は解るのでポイントを教えてくれ』と言ったらそれなりの指針を返してくれます。
https://chatgpt.com/share/69537291-28d4-8006-97c9-a832786fbd92
一往復だけのやり取りを載せていますが、かなり整理されたものが出てきています。

プログラミング初心者の方は上の文章を読んでもわからないかと思いますが、初心者の方は『私はプログラミングの初心者でまったく一から勉強したいのですが、どうすればよいでしょうか?』とすれば、ChatGPTは上手に相手をしてくれます。
https://chatgpt.com/share/69537347-092c-8006-843d-e774b22972fb

ここで返された言葉の意味が解らなければ質問すれば良いです。例えば、「C/C++やJava」が解らなければ「C/C++やJavaとは何ですか?」とか「言語とはなんですか?」と聞けば回答を出してくれます。

「ChatGPTのような生成AIが教師の代わりになれるのか?」という疑問が沸くかと思いますが、少なくとも私はChatGPTとのやり取りで「プログラミングスクールはやめておこう」と思うようになりました。それほど信頼性が高く、初心者が高額なお金を出してスクールに行く価値があるのか疑問に思うほどです。少なくとも、私はお金を取れるとは思えません。

もちろん注意事項もあります。ChatGPTやGeminiが信頼できるというのは『ネット上に溢れている情報で、特に初心者に対しての情報は、多くのチュートリアルがあるのでAIはそれを模倣している」ということが言えますが、あまり一般的でないことや初心者あるあるでない、ややこしい質問をされると、AIも混乱するでしょう。そして一度混乱したAIを元に戻すのは、初心者だけでなく中級、上級者にとっても難しいかと思います。(この場合の有効な手段は、最初からやり直しになりますが、今までのやり取りが消えてしまうので、それはそれで面倒です)。
AIは『人間に寄り添いすぎる面』があります。本来行うべき「厳しい意見」というのを避ける傾向にあります。AIとの距離感の作り方はあらゆることに言えますが、一つの共通課題かと思います。
そうはいっても、プログラミングというのは最終的に、コンピューターで動くものを作るという行為になります。つまり「動くものができるかどうか」ということで検証可能です。AIが間違っていたとしても、動かないことで間違っていることが分かります。そこで、「これ動かないんだけど」とAIに聞けばよいです。場合によっては、何度質問しても、一向にバグが直らないことがありますが、その場合は、仕切り直しをしたり、違う課題をやってみる、掲示板で聞く、自分で考えてみる、などをやってみることになるでしょう。

このやり方の最大の長所になるのですが、このようなプログラミング学習が、そのまま「バイブコーディング(AIによるコード生成)」に移行できるというところです。特に、AIへの「動かない」というフィードバックはそのままバイブコーディング時代のデバッグに通じます。
ちなみに、ネットでは「バイブコーディングで爆速開発!」とかありますが、私自体は現時点ではバイブコーディングに懐疑的です。プログラミングに限った話ではないですが、実際にAIが混乱する様子を観測していると現段階でのバイブコーディングについてはまだ様子見を行っています。また私は独自のプログラミング言語を開発している関係でバイブコーディングを行うことができないということもあります。
もっとも、まったくやらないわけにはいかないので、ブログネタでやるほか、Youtube上ではバイブコーディングを行っている様子がアップされていますので良く見ています。

すこし話を戻しますと、よく言われるプログラミング初学者に対しての質問で「作りたいものをはっきりさせる」というものがあります。つまり目標を持ってプログラミングすると覚えが速いということです。これ自体は否定はしませんが、私自身は「コンピュータが好きだからプログラミングの勉強をした」ということになります。先ほどのChatGPTとの対話では、「何のためにプログラミングを学ぶか」について、ChatGPTは画一的な動機ではなく、様々な動機を提案しています。これはこれで教師としてはある意味人間を超えているとも言えます。人間の場合、どうしても個人の考え(哲学)が入ってしまいます。プログラミングスクールで学ぶ場合、学習者は講師の個人的な考え(哲学)に影響されます。ただしこの哲学は強制されるものではなく、あなた自身が自主的に追及するものになるかと思います。

私の場合は「コンピュータが好きで仕組みを理解したい」ということでしたが、このやり取りを掲載しておきます。
https://chatgpt.com/share/69550def-2290-8006-a2c5-3f4d560915f6

まとめ

以上、最近はAIによる自己学習も大分よくなったかなと実感しています。もちろんですが、AIによる自己学習でも壁にぶち当たることがあります。AI相手や掲示板なども使ったが上手くいかず、どうしてもプログラミングをやってみたいという場合は、プログラミングスクールに行くことも有効な手段だと思います。独学vsスクールという二者択一ではなく、プログラミングをマスターするという目的に対して、どういう手段をとるか?という選択でしかないです。

「優良なプログラミングスクールにおけるメンターの存在について触れられていない」という指摘を受けて、Part2として記事をまとめました。

老兵は死なず、AIと踊る

AI時代のコードレビューは“理解”ではなく“責任”を見る

老兵は死なず、AIと踊る

SNSの投稿で、

『AIで書いたコードを、
細部まで理解できていないままコードレビューに出すのは、
職場でも最も信用を落とす行為なので、気をつけましょう笑』

とあったのですが、分からなくもないのですが、「笑」というのが残念です。

比喩的な話になるのですが、昭和の時代『そろばん付きの電卓』というのがあった。つまり『電卓の結果が信用できない』ということでそろばんがついていたとのことです。
当たり前ですが、『電卓が信用できない』のなら『そろばんのみ』使えば良いですし(電卓とそろばんで2回計算するので時間がかかっている)。令和の時代では、『電卓が間違えるはずがない』ということで、そろばん付きの電卓というのは見つからないかと思います。

もっとも、当時の発想として、実は『そろばんだけだったり電卓だけだったりすると、人間の操作ミスによる間違いがあるので、異なるデバイスで計算し互いに検算しあう』という意図があったかもしれません。

そう考えると
『AIで書いたコードを、細部まで理解できていないままコードレビューに出すのは、職場でも最も信用を落とす行為なので、気をつけましょう笑』
というのは、AIが完全ではないので理解ができます。
しかしながら、この発想は『そろばん+電卓』ということは意識しておいた方がよいかもしれません。

実はソフトウェアの世界では、「中身は知らんがそれを使っている」ということが既に何重もの階層構造の上に起こっています。
我々が何気なく書いているプログラムも、
 ・OS
 ・データベース等のミドルウェア
 ・プログラミング言語環境
 ・フレームワーク
といった基盤の上で構築しています。

さて、我々はOSのコードやらデータベースのコードを理解しないとプログラミングをしてはいけないでしょうか?
コンパイラが出力するアセンブラコードを理解できなくても良いのでしょうか?
フレームワークについては、全てを理解する必要があるでしょうか?

もちろんですが、2025年現在、『AIの出力するコードを無批判で受け入れる』のはダメでしょう。
しかし、『AI出力の細部を理解しないとダメ』という発想はソフトウェアエンジニアリングの観点からは問題があるということになります。なぜか?

そもそも、コードレビューは、ソフトウェアの品質向上、バグや問題を取り除くために行います。
AIの出力をコードレビューするということは、近い将来に発生する問題として、

「AIが作成した膨大なコードを人間がレビューし続ける。レビューが終わらない。」

ということになります。
せっかくAIにより開発のスピードが上がっても人間のレビューにより生産性が下がるということになります。

コード開発ということばかりに目をやると『コードの理解、レビュー』となりますが、ソフトウェア開発(エンジニアリング)の観点で見れば、これまでの歴史が示すとおり、
・階層化
・コードの再利用
・ブラックボックス化
と進化してきました。
その観点でみれば、必ずしも「細部まで理解する必要がないこと」は理解してもらえるかと思います。

では、コードレビューにおいて、どうも担当者が細部を分かっていないと判断したらどうすればよいでしょうか?
それは、担当者がサボったと認識するのではなく、さりげなく
「ここのロジックについて説明してくれますか?」
「どのように検証しましたか?」
と質問をすればよいでしょう。

『AIに任せた』と回答がくれば、

もし、そのコードが学習する価値があるものなら、「このコードは重要なので覚えてください」と言えばよいし、
もし、そのコードにバグがあるのなら、「AIのこのコードに問題があるので修正するかプロンプトを見直してください」と言えばよいです。

いずれにしても『理解していない=仕事をしていない』と決めつけるのではなく、きちんとレビュー対象のコードの重要性や品質を見極めたうえでレビューを行えば、電卓の結果をそろばんで再計算する必要がなくなるでしょう。

追記、この最初のSNSの投稿は、プログラミングスクール運営者の方の投稿でした。ということでプログラミングスクールとの付き合い方という記事にしました。

老兵は死なず、AIと踊る

自動詞と他動詞を考え直す(Part2)、日本人にとっての自動詞と他動詞の恐ろしさ

実に8年ぶりの記事になるのですが、「自動詞と他動詞を考え直す」の続きになります。
ちなみに、この記事は『AIとの共作』になります。文章は私のものですが、特に『I bought yesterday』が持つ感覚について『どう説明しようか?』と思って放置していたのですが、AIの校正により明確な文章にできました。

Part1の記事では、私は『文法上、自動詞と他動詞を区別する意味はあまりない』と言っていますが、これは少し危険で、なぜ一部のネイティブが「I wish」に違和感を持つか?(wishは他動詞)という話になります。例えば、

主語 動詞

という文があった場合、日本人は『文章として成立している』と思いがちですが、ネイティブはどうも『目的語はどうなっている?』と無意識に考えているようです。そして、日本人にとっては(よくわからん理由で)

I go.

は文として成立し

I wish

は、文法的な正しさはおいておいて、文として成立しない。つまり、目的語として、何を望んでいるのか?が明確でないということになります。

ここまででしたら前回の記事の焼き直しになるのですが、日本人にとっての目的語の扱いの難しさは以下の文の解釈になります。

This is the book I bought yesterday.

ここの the も良く議論になるのですが、それは置いておいて、問題はここでの bought(buyの過去形)は『自動詞なのか?他動詞なのか?』になります。

そして見た目の形

I bought yesterday

とは裏腹にここでのboughtは他動詞になります。
上記の文章は、学校では、『関係代名詞』として習います。つまり、

This is the book. I bought it yesterday.

This is the book. I bought that yesterday.

This is the book that I bought yesterday.

This is the book I bought yesterday.

という流れで解釈しがちですが、そもそもネイティブにとっては、上記のようなややこしい変換をしておらず、

I bought yesterday

は、何を買ったか省略されている。不完全な文であり、I bought what yesterday という感覚になっているようです。

さて、さらにややこしいのは、

I bought yesterday.

は完全な文でもあり、この意味では『昨日買い物したことを言いたい』ということで通用するようです。

まったくもって困った話で、I bought yesterdayは文として成立することもあれば、そうでないこともあることになりますが、ここで重要なのは、bought を自動詞か他動詞かに分類した上で文章を解釈することではなく、「目的語を要求する感覚が文脈によって立ち上がったり消えたりする」という点です。
これが、私にとっての英語学習の最大の壁でした。ここではあえてピリオドの有無で区別していますが、I bought yesterdayは、目的語が省略されている(文章の修飾を行っている)場合もあれば、単に目的語の無い文として使う場合もあり、ネイティブは感覚的に使い分けを行っているようです。
(当然ですが、個人個人によって感覚は微妙に異なることになります。特に重箱の隅をつつくような話になるとPart1で言ったように『I wishは自動詞でも使われる』という反論が成立したりします。)

つまり、このあたりの解釈は、文脈(つまり他の文等の関係)だったり、動詞の使われ方だったりするのですが、明確に決まっているわけではなくある種の集合知として整理されているわけです。つまり言語がもつある種の不合理(使っている人には当たり前なのだが説明ができない部分)を如実に表していることになります。
自然言語というのは慣習的に覚える側面があり日本語の場合”は”と”が”の使い分けだったり、数を数えるのに、「いっぽん」、「にほん」、「さんぼん」と「ぽ」、「ほ」、「ぼ」の使い分けの理屈だったりするのですが、これらは明確な基準がなく(数で勝負)のところがあります。
最近のLLMで翻訳ができるようになったのは『個々の単語の分類』だけにとどまらずに『膨大な文脈からの言語の再構成』が自然言語学習の王道ということを示唆しています。

ここで、冒頭の話に戻るのですが、『文法上、自動詞と他動詞を区別する意味はあまりない』といったのは実は『文脈や伝えたい意図によって、動詞は目的語を伴うか伴わないか分かれたり、自動詞のみで使ったり、他動詞のみで使ったりする。重要なのは分類ではなく文脈を読み取って適切に構文を読み取る能力。』ということが言えます。

「給付付き税額控除」議論に対する期待と不安

社会の矛盾に物申す

社会保障制度改革へ「国民会議」新設の方針…政府と与野党で「給付付き税額控除」議論、来月にも初会合

いよいよ「給付付き税額控除」について動き出したということですが、最初に私の立場を明確にしたいですが「給付付き税額控除」は賛成ではあります。
一方で、Yahooのコメントを見る限り「給付付き税額控除」はあまり人気がないらしい。これは大きな意味でのベーシックインカムで、私が知る限りここ15年ぐらい議論があり、確かに当時も「モラルハザードが起こり人が働かなくなる」と批判されていた。

社会保障を所得の再分配ということと定義すると、経済的に「恩恵を受ける層」と「負担をする層」に分かれるかと思います。
具体的には、年金だけでなく、日本の終身雇用もある意味社会保障の一端を担ってきたかと思います。つまり若いときに負担をして年齢が上がる度に恩恵を受ける仕組みである。そして定年を迎えたら年金をもらうというある意味『うまくできた制度?』といえなくもない。

ここまでならハッピーなのですが、問題はこれらの制度は必ずしも持続可能ではなく調整が必要なところかと思います。

年金で言えば、主に少子化により制度疲労(負担する人が減った)が起こり、「これでは収支がもたん」ということで今から20年程前に制度改革があり「負担」がおおむね倍になった。これは最近クローズアップされましたが、制度改革以降、年々少しずつ負担が増え、負担が倍になったのは10年程前になったかと記憶しています。

雇用慣行(終身雇用)で言えば、バブル崩壊後の経済停滞により、非正規雇用が増えこれらの人々の給料が抑えられた為、つまり恩恵にあずかれる人が減った為に、終身雇用が社会保障として機能不全を起こしているということになるかと思います。

そういう意味では、「給付付き税額控除」はこれらの恩恵から漏れた人を救うことになるということで期待が持てます。

しかしながら、「恩恵」と「負担」は国家としてはバランスさせないと持続可能ではないと考えますが、そういう意味では今の日本の社会保障は既に「このままでは持続可能ではない」ところにきているかと思われます。
つまり年金にしても終身雇用にしても、恩恵と負担がバランスしていないから改革があったわけで、新しい社会保障を作るのなら、恩恵と負担をどのようにバランスさせるか?という問題が出てくる。

社会保障は、余裕のある人は負担を行い、余裕のない人は恩恵をあずかれるという仕組みであるが、今の日本の状況を鑑みると『国全体が貧乏になったらどうするのか?』という話に集約されるような気がしています。

本来は、ある意味で社会制度の恩恵を受けておりかつ優秀であるはずの、エリート官僚や一流企業の正社員が『日本が向かうべき方向性』を示す(うまくかじ取りをする)べきでありますが、天下り問題や大企業の凋落振りを鑑みると、彼らがモラルハザードを起こしていると思われる点が残念である。
このように考えると、彼らにとって他人事である『給付付き税額控除』は、『年収の壁の議論(7兆円と言われた税負担が数千億円に矮小化されている)』のようにアリバイ的に実施されるというのが現実的なところかと思われる。

社会の矛盾に物申す

経済対策が上手くいかない一つの理由(現場から)

社会の矛盾に物申す

日本経済は、政府が定期的に経済対策を打っているにもかかわらず、長期的な低迷から抜け出せていません。
私自身、労働者としての人生を通して、その「横ばい」をずっと体感してきました。

それは、
・補助金が「現場を助ける仕組み」ではなく「組織を回すための仕事」になってしまっている
・補助金を扱う側にリスクがなく、受け取る側にだけリスクが集中している
など、使い方が「現場向きでない」ということに問題があるかと思います。

上記問題点について、過去の経験から考察したいです。
ちなみに、コロナ禍の補助金についてですが私も受給しましたし助かったことは事実であることを申し上げます。
その後、いくつか補助金の申請等を行いましたが、結果として助かった補助金は「直接的な金銭支援」になります。
現在、補助金は受け取っていませんが、コロナ禍も過去のものとなりインバウンド需要も復活したので補助金なしでも大丈夫となりました。こういう意味(補助金に頼らなくなる)でも持続化給付金や雇用調整助成金は大変助かりました。

一方で、違和感を持つ補助金もありました。

・IT関連の補助金で、半額で会計ソフトが購入できるということで買おうと思ったら、面倒な手続きをやった挙句に、会計ソフト単独では買えずに、使うかどうかもわからないサポートが付与されて、結局、ほぼ定価で買う金額提示をされた。
→もちろんキャンセルした。

・とある期間、使用目的が決まってたプロジェクト系の補助金で、イベントを行う為に利用したが、コロナ禍が長引いたので延長申請をしたら却下された。
→補助金は要りませんということで中止申請をしたところ、延長が認められるようになった。『延長すればいいんですね』と上から目線で言われたので「もう要らないです」と言ったらそれは都合が悪いらしく最後は『頼むから延長してくれ』になった。とある経済団体が事務局をやっていたが審査がずさんで閉口した。

・とある旅行系の補助金(旅行者が割引の恩恵を受ける)で、こちらもなぜか実施要項が細かく決まっており、補助金の申請の段階で『これは却下です』と言われて補助金を受け取れなかった。旅行者には割引で旅行をしているが追加の料金負担をお願いできるわけもなく、こちらが被った。ここまでならこちらの落ち度ということも理解できるが、次の旅行の時に事務局に詳細を確認したところ、『それはできない』と言われた。リスクを旅行会社が受ける補助金ってなんの為の補助金か理解に苦しむ。ちなみに事務局は各都道府県にあり大手の旅行会社からの出向で行われていた。つまり大手旅行会社への補助金かと勘ぐってしまいます。

・とある旅行系の補助金(旅行者が割引の恩恵を受ける)で、クーポン券の発送(宅急便)が間に合わず、離島まで運ぶというアルバイトをした。ちなみに数人で離島へ行ったが旅費が数十万かかったかと思うが配布したクーポン券は3冊だった。意義はあったかもしれないが宅急便なら1万円でおつりがくるクーポン券の発送をわざわざ数十万の旅費をかけてやることかと思う。これは1か所の旅費であるので全体では膨大な費用が発生したかと思う。

・ITプロジェクト等は失敗がつきものなので成果が出ないのは仕方ない面があるが、会社員時代は上司が『○○のお金をぶんどる』という意識でやっていた。後にその会社は辞めた。

という経験がありました。とくに『一部の企業に恩恵がある』や『補助金をとりに行く体質』を鑑みるに、現在の補正予算が大規模になっていく理由として合点が行きます。
つまり、補助金が「補助」ではなく、事実上の定期給付になってしまえば、事業者は自立できず、経済も回りません。
この構造そのものが、現在の日本経済の停滞を長引かせている一因ではないかと感じています。

社会の矛盾に物申す