根据具体的情况,一般的开发人员往往比优秀的开发人员的效率低 10%~20%。优秀的开发人员的效率更高,因为他们拥有丰富的经验和良好的编程习惯。不良的编程习惯将会影响到效率。本文通过展示一些良好的编程习惯,帮助您成为更优秀的程序员。

这些良好的编程习惯不仅能提高效率,还能让您编写出在应用程序的整个生命周期中易于维护的代码。编写出来的代码可能需要大量的维护;应用程序的维护是一笔很大的开支。养成良好的编程习惯能够提高设计质量(比如模块化),从而使代码更加容易理解,因此维护就更加容易,同时也降低维护成本。

不良的编程习惯会造成代码缺陷,使其难以维护和修改,并且很可能在修改时又引入其他缺陷。以下是 5 个良好的编程习惯,能够帮助 PHP 代码避免这些缺陷:

使用良好的命名。

分成更小的部分。

为代码添加注释。

处理错误条件。

切忌使用复制粘贴。

下一小节将详细介绍这些习惯。

使用良好的命名

使用良好的命名是最重要的编程习惯,因为描述性强的名称让代码更加容易阅读和理解。代码是否好理解取决于是否能在未来维护它。即便代码不带有注释,如果它很容易理解,将大大方便日后的更改。这个习惯的目标是让您编写的代码像书本一样容易阅读和理解。

不良习惯:含糊的或无意义的名称

清单 1 中的代码包含过短的变量名、难以辨认的缩写词,并且方法名不能反映该方法的功能。如果方法名给人的感觉是它应该做这件事情,而实际中它却做另外的事情,这将带来严重的问题,因为它会误导人。

清单 1. 不良习惯:含糊的或无意义的名称

function getNBDay($d)

{

switch($d) {

case 5:

case 6:

case 7:

return 1;

default:

return ($d + 1);

}

}

$day = 5;

$nextDay = getNBDay($day);

echo ("Next day is: " . $nextDay . "\n");

?>

良好习惯:说明性强并且简洁的名称

清单 2 中的代码体现了良好的编程习惯。新的方法名具有很强的说明性,反映了方法的用途。同样,更改后的变量名也更具说明性。惟一的保持最短的变量是$i,在本清单中,它是一个循环变量。尽管很多人不赞同使用过短的名称,但在循环变量中使用还是可以接受的(甚至有好处),因为它明确表明了代码的功能。

清单 2. 良好习惯:说明性强并且简洁的名称

define ('MONDAY', 1);

define ('TUESDAY', 2);

define ('WEDNESDAY', 3);

define ('THURSDAY', 4);

define ('FRIDAY', 5);

define ('SATURDAY', 6);

define ('SUNDAY', 7);

/*

*

* @param $dayOfWeek

* @return int Day of week, with 1 being Monday and so on.

*/

function findNextBusinessDay($dayOfWeek)

{

$nextBusinessDay = $dayOfWeek;

switch($dayOfWeek) {

case FRIDAY:

case SATURDAY:

case SUNDAY:

$nextBusinessDay = MONDAY;

break;

default:

$nextBusinessDay += 1;

break;

}

return $nextBusinessDay;

}

$day = FRIDAY;

$nextBusDay = findNextBusinessDay($day);

echo ("Next day is:" . $nextBusDay . "\n");

?>

我们鼓励您将大的条件拆分为一个方法,然后用能够描述该条件的名字命名方法。这个技巧能够提高代码的可读性,并且能够将条件具体化,使之能够被提取甚至重用。如果条件发生变化,更新方法也很容易。因为方法拥有一个有意义的名字,所以它能反映代码的用途,让代码更容易阅读。

分成更小的部分

专心解决一个问题之后再继续编程,这样会让您更轻松。在解决一个紧急的问题时,如果继续编程,会使函数越来越长。从长远来说,这并不是一个问题,但您要记得回过头来将它重构为更小的部分。

重构是个不错的主意,但您应该养成编写更短、功能更集中的代码。短的方法能够在一个窗口中一次看完,并且容易理解。如果方法过长,不能在一个窗口中一次看完,那么它就变得不容易理解,因为您不能快速地从头到尾了解它的整个思路。

构建方法时,您应该养成这样的习惯,让每个方法只完成一件事情。这个习惯很好,因为:首先,如果方法只完成一件事情,那么它就更容易被重用;其次,这样的方法容易测试;第三,这样的方法便于理解和更改。

不良习惯:过长的方法(完成很多件事情)

清单 3 展示了一个很长的函数,其中存在很多问题。它完成很多件事情,因此不够紧凑。它也不便于阅读、调试和测试。它要做的事情包括遍历一个文件、构建一个列表、为每个对象赋值、执行计算等等。

清单 3. 不良习惯:过长的函数

function writeRssFeed($user)

{

// Get the DB connection information

// look up the user's preferences...

$link = mysql_connect('mysql_host', 'mysql_user', 'mysql_password')

OR die(mysql_error());

// Query

$perfsQuery = sprintf("SELECT max_stories FROM user_perfs WHERE user= '%s'",

mysql_real_escape_string($user));

$result = mysql_query($query, $link);

$max_stories = 25; // default it to 25;

if ($row = mysql_fetch_assoc($result)) {

$max_stories = $row['max_stories'];

}

// go get my data

$perfsQuery = sprintf("SELECT * FROM stories WHERE post_date = '%s'",

mysql_real_escape_string());

$result = mysql_query($query, $link);

$feed = "" .

"" .

"

My Great Feed" .

"http://www.example.com/feed.xml" .

"The best feed in the world" .

"en-us" .

"Tue, 20 Oct 2008 10:00:00 GMT" .

"Tue, 20 Oct 2008 10:00:00 GMT" .

"http://www.example.com/rss" .

"MyFeed Generator" .

"editor@example.com" .

"webmaster@example.com" .

"5";

// build the feed...

while ($row = mysql_fetch_assoc($result)) {

$title = $row['title'];

$link = $row['link'];

$description = $row['description'];

$date = $row['date'];

$guid = $row['guid'];

$feed .= "";

$feed .= "

" . $title . "";

$feed .= "" . $link . "";

$feed .= " " . $description . "";

$feed .= "" . $date . "";

$feed .= "" . $guid . "";

$feed .= "";

}

$feed .= "

// write the feed out to the server...

echo($feed);

}

?>

如果多编写几个这样的方法,维护就成了真正的难题了。

良好习惯:易管理、功能专一的方法

清单 4 将原来的方法改写为更加紧凑、易读的方法。在这个示例中,将一个很长的方法分解为几个短方法,并且让每个短方法负责一件事情。这样的代码对将来的重用和测试都是大有裨益的。

清单 4. 良好习惯:易管理、功能专一的方法

function createRssHeader()

{

return "" .

"" .

"

My Great Feed" .

"http://www.example.com/feed.xml" .

"The best feed in the world" .

"en-us" .

"Tue, 20 Oct 2008 10:00:00 GMT" .

"Tue, 20 Oct 2008 10:00:00 GMT" .

"http://www.example.com/rss" .

"MyFeed Generator" .

"editor@example.com" .

"webmaster@example.com" .

"5";

}

function createRssFooter()

{

return "";

}

function createRssItem($title, $link, $desc, $date, $guid)

{

$item .= "";

$item .= "

" . $title . "";

$item .= "" . $link . "";

$item .= " " . $description . "";

$item .= "" . $date . "";

$item .= "" . $guid . "";

$item .= "";

return $item;

}

function getUserMaxStories($db_link, $default)

{

$perfsQuery = sprintf("SELECT max_stories FROM user_perfs WHERE user= '%s'",

mysql_real_escape_string($user));

$result = mysql_query($perfsQuery, $db_link);

$max_stories = $default;

if ($row = mysql_fetch_assoc($result)) {

$max_stories = $row['max_stories'];

}

return $max_stories;

}

function writeRssFeed($user)

{

// Get the DB connection information

$settings = parse_ini_file("rss_server.ini");

// look up the user's preferences...

$link = mysql_connect($settings['db_host'], $settings['user'],

$settings['password']) OR die(mysql_error());

$max_stories = getUserMaxStories($link, 25);

// go get my data

$newsQuery = sprintf("SELECT * FROM stories WHERE post_date = '%s'",

mysql_real_escape_string(time()));

$result = mysql_query($newsQuery, $link);

$feed = createRssHeader();

$i = 0;

// build the feed...

while ($row = mysql_fetch_assoc($result)) {

if ($i < $max_stories) {

$title = $row['title'];

$link = $row['link'];

$description = $row['description'];

$date = $row['date'];

$guid = $row['guid'];

$feed .= createRssItem($title, $link, $description, $date, $guid);

$i++;

} else {

break;

}

}

mysql_close($link);

$feed .= createRssFooter();

// write the feed out to the server...

echo($feed);

}

?>

将长方法拆分为短方法也是有限制的,过度拆分将适得其反。因此,不要滥用这个良好的习惯。将代码分成大量的片段就像没有拆分长代码一样,都会造成阅读困难。

为代码添加注释

要为代码添加良好的注释有时似乎和编写代码一样难。要了解应该为哪些内容添加注释并不容易,因为我们常常倾向于注释代码当前做的事情。注释代码的目的是不错的主意。在函数的不是很明显的头部代码块中,告诉读者方法的输入和输出,以及方法的最初目标。

注释代码当前做什么是很常见的,但这是不必要的。如果代码很复杂,不得不注释它当前在做什么,这将暗示您应该重写代码,让它更容易理解。学会使用良好的名称和更短的方法,在不提供注释说明其用途的情况下提高代码的可读性。

不良习惯:函数注释过多或不足

清单 5 中的注释仅告诉读者代码在做什么 — 它正在通过一个循环进行迭代或添加一个数字。但它忽略了它为什么做当前的工作。这使维护该代码的人员不知道是否可以安全地更改代码(不引入新缺陷)。

清单 5. 不良习惯:函数注释过多或不足

class ResultMessage

{

private $severity;

private $message;

public function __construct($sev, $msg)

{

$this->severity = $sev;

$this->message = $msg;

}

public function getSeverity()

{

return $this->severity;

}

public function setSeverity($severity)

{

$this->severity = $severity;

}

public function getMessage()

{

return $this->message;

}

public function setMessage($msg)

{

$this->message = $msg;

}

}

function cntMsgs($messages)

{

$n = 0;

/* iterate through the messages... */

foreach($messages as $m) {

if ($m->getSeverity() == 'Error') {

$n++; // add one to the result;

}

}

return $n;

}

$messages = array(new ResultMessage("Error", "This is an error!"),

new ResultMessage("Warning", "This is a warning!"),

new ResultMessage("Error", "This is another error!"));

$errs = cntMsgs($messages);

echo("There are " . $errs . " errors in the result.\n");

?>

良好习惯:带注释的函数和类

清单 6 中的注释告诉读者类和方法的目的。该注释解释了为什么代码在做当前的工作,这对未来维护代码十分有用。可能需要根据条件变更而修改代码,如果能够轻松了解代码的目的,则修改起来很容易。

清单 6. 良好习惯:带注释的函数和类

/**

* The ResultMessage class holds a message that can be returned

* as a result of a process. The message has a severity and

* message.

*

* @author nagood

*

*/

class ResultMessage

{

private $severity;

private $message;

/**

* Constructor for the ResultMessage that allows you to assign

* severity and message.

* @param $sev See {@link getSeverity()}

* @param $msg

* @return unknown_type

*/

public function __construct($sev, $msg)

{

$this->severity = $sev;

$this->message = $msg;

}

/**

* Returns the severity of the message. Should be one

* "Information", "Warning", or "Error".

* @return string Message severity

*/

public function getSeverity()

{

return $this->severity;

}

/**

* Sets the severity of the message

* @param $severity

* @return void

*/

public function setSeverity($severity)

{

$this->severity = $severity;

}

public function getMessage()

{

return $this->message;

}

public function setMessage($msg)

{

$this->message = $msg;

}

}

/*

* Counts the messages with the given severity in the array

* of messages.

*

* @param $messages An array of ResultMessage

* @return int Count of messages with a severity of "Error"

*/

function countErrors($messages)

{

$matchingCount = 0;

foreach($messages as $m) {

if ($m->getSeverity() == "Error") {

$matchingCount++;

}

}

return $matchingCount;

}

$messages = array(new ResultMessage("Error", "This is an error!"),

new ResultMessage("Warning", "This is a warning!"),

new ResultMessage("Error", "This is another error!"));

$errs = countErrors($messages);

echo("There are " . $errs . " errors in the result.\n");

?>

处理错误

根据大众的经验,如果要编写健壮的应用程序,错误处理要遵循 80/20 规则:80% 的代码用于处理异常和验证,20% 的代码用于完成实际工作。在编写程序的基本逻辑(happy-path)代码时经常这样做。这意味着编写适用于基本条件的代码,即所有的数据都是可用的,所有的条件符合预期。这样的代码在应用程序的生命周期中可能很脆弱。另一个极端是,甚至需要花大量时间为从未遇到过的条件编写代码。

这一习惯要求您编写足够的错误处理代码,而不是编写对付所有错误的代码,以致代码迟迟不能完成。

不良习惯:根本没有错误处理代码

清单 7 中的代码演示了两个不良习惯。第一,没有检查输入的参数,即使知道处于某些状态的参数会造成方法出现异常。第二,代码调用一个可能抛出异常的方法,但没有处理该异常。当发生问题时,代码的作者或维护该代码的人员只能猜测问题的根源。

清单 7. 不良习惯:不处理错误条件

// Get the actual name of the

function convertDayOfWeekToName($day)

{

$dayNames = array(

"Sunday",

"Monday",

"Tuesday",

"Wednesday",

"Thursday",

"Friday",

"Saturday");

return $dayNames[$day];

}

echo("The name of the 0 day is: " . convertDayOfWeekToName(0) . "\n");

echo("The name of the 10 day is: " . convertDayOfWeekToName(10) . "\n");

echo("The name of the 'orange' day is: " . convertDayOfWeekToName('orange') . "\n");

?>

良好习惯:处理异常

清单 8 展示了以有意义的方式抛出和处理异常。额外的错误处理不仅使代码更加健壮,它还提高代码的可读性,使代码更容易理解。处理异常的方式很好地说明了原作者在编写方法时的意图。

清单 8. 良好习惯:处理异常

/**

* This is the exception thrown if the day of the week is invalid.

* @author nagood

*

*/

class InvalidDayOfWeekException extends Exception { }

class InvalidDayFormatException extends Exception { }

/**

* Gets the name of the day given the day in the week. Will

* return an error if the value supplied is out of range.

*

* @param $day

* @return unknown_type

*/

function convertDayOfWeekToName($day)

{

if (! is_numeric($day)) {

throw new InvalidDayFormatException('The value \'' . $day . '\' is an ' .

'invalid format for a day of week.');

}

if (($day > 6) || ($day < 0)) {

throw new InvalidDayOfWeekException('The day number \'' . $day . '\' is an ' .

'invalid day of the week. Expecting 0-6.');

}

$dayNames = array(

"Sunday",

"Monday",

"Tuesday",

"Wednesday",

"Thursday",

"Friday",

"Saturday");

return $dayNames[$day];

}

echo("The name of the 0 day is: " . convertDayOfWeekToName(0) . "\n");

try {

echo("The name of the 10 day is: " . convertDayOfWeekToName(10) . "\n");

} catch (InvalidDayOfWeekException $e) {

echo ("Encountered error while trying to convert value: " . $e->getMessage() . "\n");

}

try {

echo("The name of the 'orange' day is: " . convertDayOfWeekToName('orange') . "\n");

} catch (InvalidDayFormatException $e) {

echo ("Encountered error while trying to convert value: " . $e->getMessage() . "\n");

}

?>

虽然检查参数是一种确认 — 如果您要求参数处于某种状态,这将对使用方法的人很有帮助 — 但是您应该检查它们并抛出有意义的异常:

处理异常要尽量与出现的问题紧密相关。

专门处理每个异常。

切忌使用复制粘贴

您可以从其他地方将代码复制粘贴到自己的代码编辑器,但这样做有利也有弊。好的一面是,从一个示例或模板中复制代码能够避免很多错误。不好的一面是,这容易带来大量的类似编程方式。

一定要注意,不要将代码从应用程序的一部分复制粘贴到另一部分。如果您采用这种方式,请停止这个不良的习惯,然后考虑将这段代码重写为可重用的。一般而言,将代码放置到一个地方便于日后的维护,因为这样只需在一个地方更改代码。

不良习惯:类似的代码段

清单 9 给出了几个几乎一样的方法,只是其中的值不同而已。有一些工具可以帮助找到复制粘贴过来的代码(参见参考资料)。

清单 9. 不良习惯:类似的代码段

/**

* Counts the number of messages found in the array of

* ResultMessage with the getSeverity() value of "Error"

*

* @param $messages An array of ResultMessage

* @return unknown_type

*/

function countErrors($messages)

{

$matchingCount = 0;

foreach($messages as $m) {

if ($m->getSeverity() == "Error") {

$matchingCount++;

}

}

return $matchingCount;

}

/**

* Counts the number of messages found in the array of

* ResultMessage with the getSeverity() value of "Warning"

*

* @param $messages An array of ResultMessage

* @return unknown_type

*/

function countWarnings($messages)

{

$matchingCount = 0;

foreach($messages as $m) {

if ($m->getSeverity() == "Warning") {

$matchingCount++;

}

}

return $matchingCount;

}

/**

* Counts the number of messages found in the array of

* ResultMessage with the getSeverity() value of "Information"

*

* @param $messages An array of ResultMessage

* @return unknown_type

*/

function countInformation($messages)

{

$matchingCount = 0;

foreach($messages as $m) {

if ($m->getSeverity() == "Information") {

$matchingCount++;

}

}

return $matchingCount;

}

$messages = array(new ResultMessage("Error", "This is an error!"),

new ResultMessage("Warning", "This is a warning!"),

new ResultMessage("Error", "This is another error!"));

$errs = countErrors($messages);

echo("There are " . $errs . " errors in the result.\n");

?>

良好习惯:带参数的可重用函数

清单 10 展示了修改后的代码,它将复制的代码放到一个方法中。另一个方法也进行了更改,它现在将任务委托给新的方法。构建通用的方法需要花时间设计,并且这样做使您能停下来思考,而不是本能地使用复制粘贴。但有必要进行更改时,对通用的方法投入的时间将得到回报。

清单 10. 良好习惯:带参数的可重用函数

/*

* Counts the messages with the given severity in the array

* of messages.

*

* @param $messages An array of ResultMessage

* @return int Count of messages matching $withSeverity

*/

function countMessages($messages, $withSeverity)

{

$matchingCount = 0;

foreach($messages as $m) {

if ($m->getSeverity() == $withSeverity) {

$matchingCount++;

}

}

return $matchingCount;

}

/**

* Counts the number of messages found in the array of

* ResultMessage with the getSeverity() value of "Error"

*

* @param $messages An array of ResultMessage

* @return unknown_type

*/

function countErrors($messages)

{

return countMessages($messages, "Errors");

}

/**

* Counts the number of messages found in the array of

* ResultMessage with the getSeverity() value of "Warning"

*

* @param $messages An array of ResultMessage

* @return unknown_type

*/

function countWarnings($messages)

{

return countMessages($messages, "Warning");

}

/**

* Counts the number of messages found in the array of

* ResultMessage with the getSeverity() value of "Warning"

*

* @param $messages An array of ResultMessage

* @return unknown_type

*/

function countInformation($messages)

{

return countMessages($messages, "Information");

}

$messages = array(new ResultMessage("Error", "This is an error!"),

new ResultMessage("Warning", "This is a warning!"),

new ResultMessage("Error", "This is another error!"));

$errs = countErrors($messages);

echo("There are " . $errs . " errors in the result.\n");

?>

结束语

如果您在编写 PHP 代码的过程中养成本文讨论的良好习惯,您将能够构建易读、易理解、易维护的代码。使用这种方式构建的易维护代码将降低调试、修复和扩展代码所面临的风险。

使用良好的名称和更短的方法能够提高代码的可读性。注释代码的目的有利于代码理解和扩展。适当地处理错误会使代码更加健壮。最后,停止使用复制粘贴,保持代码干净,提高可重用性。

php编程习惯,PHP 编程的 5个良好习惯相关推荐

  1. php中一定要写 吗,PHP编程一定要改掉的5个不良习惯

    这5个PHP编程中的不良习惯,一定要改掉 PHP世界上最好的语言! 测试循环前数组是否为空? $items = []; // ... if (count($items) > 0) { forea ...

  2. c实现多语言编程,C/C++编程中多国语言处理

    多国语言的存在.不同语言操作系统的存在,使得针对多语言的设计颇费周章,在编码上所付出的工作量也是可观的.所谓编码的问题,归结起来,就是二进制的编码以何种编码格式进行解析的问题.特别是在硬盘文件和内存数 ...

  3. python编辑器_没有人比它更懂少儿编程,慧编程Python'吮指编辑器'

    咳咳! 大家好,我是偶尔写文章的康康老师. 今天跟大家介绍的是慧编程家的,睡在Scratch上铺的兄弟--慧编程Python编辑器. 这是一款集才华和颜值为一体的'吮指'编辑器! 忘记肯德基,你的手指 ...

  4. 孩子该不该学编程?学编程有用吗?

    孩子该不该学编程?学编程有用吗? 随着信息时代的到来,人工智能.大数据等技术的蓬勃发展,编程已经成为21世纪必不可少的技能.在未来,如果不懂得编程,就会像以前不会上网.打字.开车一样,成为新一代的&q ...

  5. 怎么提高python编程水平_编程新手如何提高编程能力?

    有些朋友给我留言说,兴致满满的开始自学编程,但是拿到一堆书,却不知道从哪开始,最后的结果就像下面这个图: 下面结合我之前的学习经历,如何从零基础慢慢提高. 1.首先,给你的学习编程一个重要的意义 做任 ...

  6. 基础编程题目集 编程题部分

    文章目录 7-1 厘米换算英尺英寸 (15分) 7-2 然后是几点 (15分) 7-3 逆序的三位数 (10分) 7-4 BCD解密 (10分) 7-5 表格输出 (5分) 7-6 混合类型数据格式化 ...

  7. 怎样学好编程(个人编程感受)!

    前言 编了这么久的程序,一直想找机会总结下其中的心得和方法,但回想我这段编程道路,又很难说清楚,如果按照我走过的所有路来说,显然是不可能的!当我看完了云风的<游戏之旅--编程感悟>和梁肇新 ...

  8. 程序员如何积累编程技术或编程经验?

    工作中总是被问到程序员如何积累编程技术或编程经验?首先我认为编程是一门实践性的很强的艺术,所以貌似唯有实践才能积累.然而把它当作一个个人软件过程(PSP)的问题,总感觉是有一些规律.规则或建议可以解答 ...

  9. python编程中文名_Python编程实战中遇到的几种需要化名的情境

    函数化名只是化名的一种应用场景,还有好几种使用化名的地方,本篇笔记将整理小结我所遇到的各种化名. 情境A:导入时化名 导入其它模块时,直接化名为简约版,是我相当常用的,甚至有一些业界约定俗成的化名.无 ...

  10. 华为“仓颉”不是中文编程,中文编程早有所属,势如破竹

    "中国自己的编程语言究竟在哪里?"关心IT生态的我们,经常深思与担忧. 语言是文化精髓所在,一方水土养一方人,不管是中文,还是英语,作为交流工具,语言烙印着不同地方的生活场景,一方 ...

最新文章

  1. 怎么找思科答案最快_成功闯入思科的面试经历
  2. 5分钟搞定开机引导界面
  3. 大牛手把手教你!2021大厂Java面试经历
  4. 剖析大神代码,计算整型里面1的个数
  5. c语言逆波兰计算器程序,C语言实现的简单的逆波兰计算器
  6. 每天进步一点点《SVD用于压缩》
  7. 【BZOJ3529】数表,莫比乌斯反演+BIT
  8. JavaScript中DOM的层次节点(一)
  9. 惠普往事:全球最大的 PC 制造商炼成记!| 极客头条
  10. Oracle--sqlplus如何设置SQLPlus结果显示的宽度,ORACLE sqlplus提示符设置
  11. golang:cannot unmarshal number into Go value of type []json.RawMessage
  12. 查看sql语句执行时间/测试sql语句性能
  13. AJAX框架大全 (AJAX Frameworks)
  14. 多图像 并行 浏览 放大 对比 MulimgViewer win10 ubuntu 多图片 多张图片
  15. 平板电脑触摸屏行业研究及十四五规划分析报告
  16. Flutter 发布iOS版本app
  17. 两种方法设置 .NET/C# 项目的编译顺序,而不影响项目之间的引用
  18. 数字标牌行业嵌入式主板方案
  19. 【QTdesigner】课时37.按钮控件(QPushButton)【pyqt5+QTdesigner模式】
  20. canvas画简单的横向流程图

热门文章

  1. shell之$@和$*的区别
  2. python—多进程之进程之间通信
  3. 2021-07-15
  4. 2020-12-2(详细解释neg指令 以及SCAS ,STOS的运用)
  5. 2020-11-28(不定参数的函数)
  6. 如何使用pFuzz以多种方法验证Web应用程序防火墙的安全性
  7. 【Web安全】php://filter 的浅略底层分析
  8. 创业的和想拿高薪的朋友可以看看,企业安全进行云平台运营的5个关键因素
  9. 8、Java Swing JCheckBox:复选框组件
  10. 1.10 对象序列化控制输入输出