通用函數(shù)
來源:易賢網(wǎng) 閱讀:1063 次 日期:2015-01-15 14:32:44
溫馨提示:易賢網(wǎng)小編為您整理了“通用函數(shù)”,方便廣大網(wǎng)友查閱!

1.通用數(shù)據(jù)庫處理函數(shù)

和其它的CGI函數(shù)相比,PHP的優(yōu)點(diǎn)之一是具有很強(qiáng)大的數(shù)據(jù)庫處理能力。但是,在PHP中,對(duì)于不同的數(shù)據(jù)庫都使用一些特定的函數(shù)來專門處理,缺少通用的數(shù)據(jù)庫處理函數(shù)。這大大降低了程序代碼的可移植性,這也為初學(xué)編程的朋友帶來了很多不便。

在網(wǎng)上,許多程序員都通過封裝類解決了這個(gè)問題。他們編寫了統(tǒng)一的函數(shù)用來處理任何流行的數(shù)據(jù)庫——不管是在Linux世界深受歡迎的Mysql還是在Windows平臺(tái)上廣泛流行的SqlServer。

就濟(jì)南網(wǎng)站建設(shè)來說,非常喜歡使用這些函數(shù),因?yàn)榭梢灾苯邮褂靡恍┖?jiǎn)單的諸如”query”、”next_record”之類的函數(shù),而不需要考慮數(shù)據(jù)庫的連接、數(shù)據(jù)庫句柄這些復(fù)雜的東西,更不需要考慮使用的是何種數(shù)據(jù)庫。

2.變量調(diào)試函數(shù)

PHP程序的調(diào)試一直是一件讓人頭疼的事,它既不像VB等高級(jí)語言那樣有集成的編譯調(diào)試環(huán)境,也不想Perl那樣可以在Linux或者DOS環(huán)境下直接運(yùn)行。其實(shí),我們完全可以通過靈活地使用echo語句來完成對(duì)PHP的調(diào)試工作。下面的幾個(gè)函數(shù)可以讓你隨時(shí)查看程序中任何變量的類型及其值。

1.function ss_array_as_string (&$array, $column = 0) {

2. $str = "Array(n";

3.while(list($var, $val) = each($array)){

4. for ($i = 0; $i < $column+1; $i++){

5.$str .= " ";

6. }

7. $str .= $var. ==> ;

8. $str .= ss_as_string($val, $column+1)." n";

9.}

10.for ($i = 0; $i < $column; $i++){

11. $str .= " ";

12.}

13.return $str.);

14. }

15. function ss_object_as_string (&$object, $column = 0) {

16.if (emptyempty($object->classname)) {

17. return "$object";

18.}

19.else {

20. $str = $object->classname."( n";

21.while (list(,$var) = each($object->persistent_slots)) {

22. for ($i = 0; $i < $column; $i++){

23.$str .= " ";

24. }

25. global $$var;

26. $str .= $var. ==> ;

27. $str .= ss_as_string($$var, column+1)." n";

28.}

29.for ($i = 0; $i < $column; $i++){

30. $str .= " ";

31.}

32.return $str.);

33.}

34. }

35. function ss_as_string (&$thing, $column = 0) {

36. if (is_object($thing)) {

37.return ss_object_as_string($thing, $column);

38. }

39. elseif (is_array($thing)) {

40.return ss_array_as_string($thing, $column);

41. }

42. elseif (is_double($thing)) {

43.return "Double(".$thing.")";

44. }

45. elseif (is_long($thing)) {

46.return "Long(".$thing.")";

47. }

48. elseif (is_string($thing)) {

49.return "String(".$thing.")";

50. }

51. else {

52.return "Unknown(".$thing.")";

53. }

54. }

需要的時(shí)候,在程序中簡(jiǎn)單地加入下面的一條代碼即可查看程序中的所使用的變量(包括數(shù)組和對(duì)象)的類型和值:

echo ss_as_string($my_variable);

使用下面的語句,我們可以直接查看程序中所有的變量的值:

echo ss_as_string($GLOBALS);

3. 控制Log信息的函數(shù)

調(diào)試PHP程序的另外一種重要的方法就是查看Log信息。如果能夠方便地控制Log信息的級(jí)別以及Log信息的顯示內(nèi)容,將會(huì)給程序調(diào)試帶來更多的便利。下面的幾個(gè)函數(shù)可以方便地實(shí)現(xiàn)這個(gè)功能。

1.$ss_log_level = 0;

2.$ss_log_filename = /tmp/ss-log;

3.$ss_log_levels = array(

4. NONE => 0,

5. ERROR => 1,

6. INFO => 2,

7. DEBUG => 3);

8.function ss_log_set_level ($level = ERROR) {

9. global $ss_log_level;

10. $ss_log_level = $level;

11.}

12.function ss_log ($level, $message) {

13. global $ss_log_level, $ss-log-filename;

14. if ($ss_log_levels[$ss_log_level] < $ss_log_levels[$level]) {

15.// 不顯示Log信息

16.return false;

17. }

18. $fd = fopen($ss_log_filename, "a+");

19. fputs($fd, $level. - [.ss_timestamp_pretty().] - .$message."n");

20. fclose($fd);

21. return true;

22.}

23.function ss_log_reset () {

24. global $ss_log_filename;

25. @unlink($ss_log_filename);

26.}

在上面的函數(shù)中,有四個(gè)Log級(jí)別變量。運(yùn)行PHP程序時(shí),只有當(dāng)Log的級(jí)別低于預(yù)設(shè)的級(jí)別值時(shí),Log信息才可以被記錄和顯示出來。例如,在程序中加入如下的一條語句:

ss_log_set_level(INFO);

那么,運(yùn)行PHP程序時(shí),只有ERROR和INFO級(jí)別的LOG信息才能被記錄和顯示出來,DEBUG級(jí)的信息則被忽略了。除此之外,我們還可以設(shè)定顯示的信息內(nèi)容,其語句如下:

ss_log(ERROR, "testing level ERROR");

ss_log(INFO, "testing level INFO");

ss_log(DEBUG, "testing level DEBUG");

你也可以隨時(shí)使用下面的語句清空LOG信息:

4.速度測(cè)試函數(shù)

為了優(yōu)化代碼,我們需要一種可以測(cè)試代碼運(yùn)行時(shí)間的方法,從而來選擇最優(yōu)的代碼。下面的函數(shù)可以測(cè)試運(yùn)行代碼所需的時(shí)間:

1.function ss_timing_start ($name = default) {

2. global $ss_timing_start_times;

3. $ss_timing_start_times[$name] = explode( , microtime());

4.}

5.function ss_timing_stop ($name = default) {

6. global $ss_timing_stop_times;

7. $ss_timing_stop_times[$name] = explode(, microtime());

8.}

9.function ss_timing_current ($name = default) {

10. global $ss_timing_start_times, $ss_timing_stop_times;

11. if (!isset($ss_timing_start_times[$name])) {

12.return 0;

13. }

14. if (!isset($ss_timing_stop_times[$name])) {

15.$stop_time = explode(, microtime());

16. }

17. else {

18.$stop_time = $ss_timing_stop_times[$name];

19. }

20. $current = $stop_time[1] - $ss_timing_start_times[$name][1];

21. $current += $stop_time[0] - $ss_timing_start_times[$name][0];

22. return $current;

23.}

現(xiàn)在可以輕松地檢查任何一段代碼的執(zhí)行時(shí)間了,甚至我們可以同時(shí)使用多個(gè)計(jì)時(shí)器,只需在使用上述的幾個(gè)函數(shù)時(shí)設(shè)定不同的參數(shù)作為計(jì)時(shí)器的名稱就可以了。

5.調(diào)試和優(yōu)化數(shù)據(jù)庫的操作

對(duì)于數(shù)據(jù)庫來說,運(yùn)行速度是至關(guān)重要的。盡管很多書籍和文章都講授了一些快速運(yùn)行數(shù)據(jù)庫的方法,但是所有的方法都必須經(jīng)過實(shí)踐的檢驗(yàn)。下面我們將把PHPLib函數(shù)庫中的query()函數(shù)和上面介紹的幾個(gè)函數(shù)綜合起來編寫成新的query()函數(shù),和原先的函數(shù)相比,這個(gè)函數(shù)增加了運(yùn)行時(shí)間的監(jiān)測(cè)功能。

1.function query($Query_String, $halt_on_error = 1) {

2. $this->connect();

3. ss_timing_start();

4. $this->Query_ID = @mysql_query($Query_String,$this->Link_ID);

5. ss_timing_stop();

6. ss_log(INFO, ss_timing_current(). Secs - .$Query_String);

7. $this->Row = 0;

8. $this->Errno = mysql_errno();

9. $this->Error = mysql_error();

10. if ($halt_on_error && !$this->Query_ID) {

11.$this->halt("Invalid SQL: ".$Query_String);

12. }

13. return $this->Query_ID;

14.}

更多信息請(qǐng)查看IT技術(shù)專欄

更多信息請(qǐng)查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機(jī)網(wǎng)站地址:通用函數(shù)
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2026國考·省考課程試聽報(bào)名

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)