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

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

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

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

1回答

1330閲覧

使いたいメソッド名が実際に使う場合と違う場合

matsujin_

総合スコア25

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

2クリップ

投稿2015/05/13 08:41

Web側で見積作成機能を追加しているのですが、同じようなことをバッチ処理機能で見つけ利用しようとしたのですが、
メソッド名がtestForBatch();とバッチ用になっているために、
新たにtestForWeb();メソッドを作成してtestForBatch();を呼ぶかそのままのメソッド名で呼ぶか悩んでます。

本当はtestForBatchをもっと汎用性のある名前に変えたいのですが、
すでにいくつで利用されているので、再テストやバグが怖いのでそれは避けたいと考えてます。

名前だけの問題なのですが、みなさんならどうしますでしょうか。
他にもよい方法があれば教えてください。
よろしくお願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

こんにちは。

実際のコードの状況を見ないとはっきりしたことは言えない、という前提の
もとで回答させて頂きます。

WEBからの入力で、見積り機能を呼ぶときに、

testForBatch();

をそのまま使うのは、私だったら
「ちょっと嫌だな。なんとかしたいな」
と思うだろうと思います。
たとえ、testForWeb()が、testForBatch()を、全くどこも修正しなくても
OKである場合であっても

lang

1function testForWeb() 2{ 3 return testForBatch(); 4}

のように、testForWeb()を作成すると思います。

ただし、このような名前へのこだわり度というのは、個人差があるので、

lang

1function testForWeb() 2{ 3 return testForBatch(); 4}

のようなものをわざわざ作るのは意味がないという考えをする方も
いらっしゃると思えまして、それはそれで間違いとはいえないかと
思います。

なので、以下、あくまで私見ということになりますが、
既存の関数
testForBatch()
を(ほぼ)そのままWEB入力からも流用するという状況が発生したということは、
そのような状況が発生したその時点においては
testForWeb()

testForBatch()
とまるっきり同じでよいとしても、将来的にはおそらく

testForBatch() = 見積り作成処理本体+バッチ用のI/O

testForWeb() = 見積り作成処理本体+WEB用のI/O

のように分解して、見積り作成処理本体はひとつの関数(なりクラスなり)にし、
バッチとWEBとで異なるI/O部分だけをそれぞれの関数に書いたほうが見通しが
よいような状況に進展するのではないか? さらに言えば、第3のI/Oに対応した

testForXxx()

の必要性も出てくるのではないか、と私だったら推測してしまうので、
その布石として

lang

1function testForWeb() 2{ 3 return testForBatch(); 4}

であったり、もしくは現状の
function testForBatch()
をリネームして
function testCommon()
としたうえで、

lang

1function testForBatch() 2{ 3 return testCommon(); //元testForBatch 4} 5 6function testForWeb() 7{ 8 return testCommon(); //元testForBatch 9}

の2つを作成して、先の将来予測に備えるかもしれません。

それと、ひと手間かけて

lang

1function testForWeb() 2{ 3 return testCommon(); //元testForBatch 4}

を作っておいて、WEBからの入力はこちらを使うことにしたときの
(ささやかな or 場合によってはけっこう大きな)メリットとして、
このWEB入力のコードを誰かに改修をお願いするとして、その中に
出てくる見積り作成が、testForBatch() のままだと

「このtestForBatch() なのですが、ここでバッチを起動しているんですか?
バッチはcronやJenkinsで夜間に回してたりとかしないんですか?」

といった質問をされない、ということがあるかと思います。
この質問への回答として、

「バッチじゃないんだけど、(関数名は)バッチなんです。(キリッ」

といった(やや苦しい)説明を私なら避けたいと思いますので。

お役に立てる回答になっているか心もとないのですが、
私が思うところは以上です。

投稿2015/05/13 10:05

編集2015/05/13 12:22
jun68ykt

総合スコア9058

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

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

matsujin_

2015/05/15 00:03

返答ありがとうございます。 返信が遅れて申し訳ありません。 ここまで丁寧に解説していただけるとは思ってなかったので とても感謝しておりますm(_ _)m ykt68さんの意見をもとに修正していきたいと思います。 ありがとうございます。 P・S こういう意見を謙虚に丁寧に言える方と仕事や勉強会をしてみたいと初めて思いました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問