PHP实例说明编写PHP代码的5个好习惯
5个PHP编程的好习惯
有些人问,优秀程序员和大牛有什么区别,大概有10到20种吧。因为大牛有很好的编程习惯和丰富的经验,所以他们非常的高效。如果不好的编程习惯出现在你的代码里,你的代码效率就会降低。本文阐述一些好的编程习惯,他们可以让你成为更好的程序员。
这些习惯能让你的代码在高效运行的同时提高可维护性。你写代码的时候,可能大部分时间都浪费在维护上了,程序的维护代价很高。培养良好的编程习惯,如模块化设计,可以让你的代码可读性更好,从而容易维护。
代码中的问题往往伴随着不良的编程习惯,而且后者会导致代码不好修改并可能出现新的缺陷。下面有五个好的编程习惯,将帮你避免这些陷阱:
- 使用友好的命名方式。
- 使用更精悍短小的代码。
- 注释你的代码。
- 编写异常处理。
- 永远,永远不要复制粘贴.(玉米:我深深的同意这一点)
下面的章节将解释这些习惯。
良好的命名方式是最重要的编程习惯,因为好的命名会让代码易懂,好懂。代码的可读性决定它的可维护性。即使你在代码没有写注释,如果它可读性好的话,它也修改起来也会简单。你应该在练习开时就使用良好的命名方式,让你的代码像一本书一样。
例1包含一个过短的变量名,写出这样的代码非常不好弄懂,而且函数名也没有清晰的描述出这个方法是做什么的。函数名表示了函数的功能,如果它却是做别的用途的,那就会误导别人。
<?<font color="#335533">php</font><br/><br/>function getNBDay($d)<br/>{<br/> switch($d) {<br/> case 5:<br/> case 6:<br/> case 7:<br/> return 1;<br/> default:<br/> return ($d + 1);<br/> }<br/>}<br/><br/>$day = 5;<br/><br/>$nextDay = getNBDay($day);<br/><br/>echo ("Next day is: " . $nextDay . "\n");<br/><br/>?><br/> 로그인 후 복사 |
例2则给出了使用良好命名方式的代码。重新命名函数是为了更好的反映它们的功能。变量也重新命名为描述性的。只有一个在循环中的$i还使用短的变量名。尽管有些人不同意,短变量名在循环中是请允许的——甚至更好些,因为它们清晰的起到了指针的功能。
<?<font color="#335533">php</font><br/><br/>define ('MONDAY', 1);<br/>define ('TUESDAY', 2);<br/>define ('WEDNESDAY', 3);<br/>define ('THURSDAY', 4);<br/>define ('FRIDAY', 5);<br/>define ('SATURDAY', 6);<br/>define ('SUNDAY', 7);<br/><br/>/*<br/> *<br/> * @param $dayOfWeek<br/> * @return int Day of week, with 1 being Monday and so on.<br/> */<br/>function findNextBusinessDay($dayOfWeek)<br/>{<br/> $nextBusinessDay = $dayOfWeek;<br/><br/> switch($dayOfWeek) {<br/> case FRIDAY:<br/> case SATURDAY:<br/> case SUNDAY:<br/> $nextBusinessDay = MONDAY;<br/> break;<br/> default:<br/> $nextBusinessDay += 1;<br/> break;<br/> }<br/><br/> return $nextBusinessDay;<br/>}<br/><br/>$day = FRIDAY;<br/><br/>$nextBusDay = findNextBusinessDay($day);<br/><br/>echo ("Next day is:" . $nextBusDay . "\n");<br/><br/>?><br/> 로그인 후 복사 |
我鼓励你在函数中分隔长的条件给函数命名,以便于描述这个条件。(玉米:这句话啥意思?5555)这个技巧会让你的代码容易阅读和扩展,因此它可以被抽象复用。如果条件发生了改变,这样也会很容易更新函数 .由于方法有一个见名知义的名字,化码就不会失去它本来的意思或者变得难以理解。
使用更少的代码
编写代码、解决问题是一种容易的事情。当你解决一个正在发生的问题,编呀编,写呀写,你的方法越来越长。只要你回头使用更少的代码来重构,就是过了很久也没什么问题。
重构是个好主意,但你应该养成第一次就写出更短小精悍代码的习惯。在一个窗口上(玉米:不用翻页)就能看全的短小函数更容易理解。 要是一个函数长出了窗口,就很难理解了,因为你不能快速的从头到脚的浏览整个代码。
当构思一个方法的时候,你还应该养成一个让它们只做一件事情的习惯。以下因素写代码时应常注意。第一,只做一件事情的函数更易于复用。第二,这样的函数测试更方便。第三,这样的函数好读易懂方便改——如果必要的话——让它们尽可能的简单吧。
坏习惯:过长的函数(很多时候)
例三是过长函数的表现。它不知道自己要做什么。它做太多的事情,所以没有集成化。它更难以理解,不好Debug和测试。它遍历文件建立列表,它给对象赋值,它做一些计算,……它耕田,它浇水,甚至做更多事情。(^_^)
例三. 坏习惯:过长函数
<?<font color="#335533">php</font><br/><br/>function writeRssFeed($user)<br/>{<br/> // Get the DB connection information<br/><br/><br/> // look up the user's preferences...<br/> $link = mysql_connect('mysql_host', 'mysql_user', 'mysql_password')<br/> OR die(mysql_error());<br/><br/> // Query<br/> $perfsQuery = sprintf("SELECT max_stories FROM user_perfs WHERE user= '%s'",<br/> mysql_real_escape_string($user));<br/><br/> $result = mysql_query($query, $link);<br/><br/> $max_stories = 25; // default it to 25;<br/><br/> if ($row = mysql_fetch_assoc($result)) {<br/> $max_stories = $row['max_stories'];<br/> }<br/><br/> // go get my data<br/> $perfsQuery = sprintf("SELECT * FROM stories WHERE post_date = '%s'",<br/> mysql_real_escape_string());<br/><br/> $result = mysql_query($query, $link); <br/><br/><br/> $feed = "<rss version=\"2.0\">" .<br/> "<channel>" .<br/> "<title>My Great Feed</title>" .<br/> "<link>http://www.example.com/feed.xml</link>" .<br/> "<description>The best feed in the world</description>" .<br/> "<language>en-us</language>" .<br/> "<pubDate>Tue, 20 Oct 2008 10:00:00 GMT</pubDate>" .<br/> "<lastBuildDate>Tue, 20 Oct 2008 10:00:00 GMT</lastBuildDate>" .<br/> "<docs>http://www.example.com/rss</docs>" .<br/> "<generator>MyFeed Generator</generator>" .<br/> "<managingEditor>editor@example.com</managingEditor>" .<br/> "<webMaster>webmaster@example.com</webMaster>" .<br/> "<ttl>5</ttl>";<br/><br/> // build the feed...<br/> while ($row = mysql_fetch_assoc($result)) {<br/> $title = $row['title'];<br/> $link = $row['link'];<br/> $description = $row['description'];<br/> $date = $row['date'];<br/> $guid = $row['guid'];<br/><br/> $feed .= "<item>";<br/> $feed .= "<title>" . $title . "</title>";<br/> $feed .= "<link>" . $link . "</link>";<br/> $feed .= "<description> " . $description . "</description>";<br/> $feed .= "<pubDate>" . $date . "</pubDate>";<br/> $feed .= "<guid>" . $guid . "</guid>";<br/> $feed .= "</item>";<br/> }<br/><br/> $feed .= "</rss";<br/><br/> // write the feed out to the server...<br/> echo($feed);<br/><br/>}<br/><br/>?><br/> 로그인 후 복사 |
要是你再加更多东西到这个函数里,它会很快变得难以维护。
好习惯:可管理,集成化的函数
<?<font color="#335533">php</font><br/><br/>function createRssHeader()<br/>{<br/> return "<rss version=\"2.0\">" .<br/> "<channel>" .<br/> "<title>My Great Feed</title>" .<br/> "<link>http://www.example.com/feed.xml</link>" .<br/> "<description>The best feed in the world</description>" .<br/> "<language>en-us</language>" .<br/> "<pubDate>Tue, 20 Oct 2008 10:00:00 GMT</pubDate>" .<br/> "<lastBuildDate>Tue, 20 Oct 2008 10:00:00 GMT</lastBuildDate>" .<br/> "<docs>http://www.example.com/rss</docs>" .<br/> "<generator>MyFeed Generator</generator>" .<br/> "<managingEditor>editor@example.com</managingEditor>" .<br/> "<webMaster>webmaster@example.com</webMaster>" .<br/> "<ttl>5</ttl>";<br/>}<br/><br/>function createRssFooter()<br/>{<br/> return "</channel></rss>";<br/>}<br/><br/>function createRssItem($title, $link, $desc, $date, $guid) <br/>{<br/> $item .= "<item>";<br/> $item .= "<title>" . $title . "</title>";<br/> $item .= "<link>" . $link . "</link>";<br/> $item .= "<description> " . $description . "</description>";<br/> $item .= "<pubDate>" . $date . "</pubDate>";<br/> $item .= "<guid>" . $guid . "</guid>";<br/> $item .= "</item>";<br/> return $item;<br/>}<br/><br/>function getUserMaxStories($db_link, $default)<br/>{<br/> $perfsQuery = sprintf("SELECT max_stories FROM user_perfs WHERE user= '%s'",<br/> mysql_real_escape_string($user));<br/><br/> $result = mysql_query($perfsQuery, $db_link);<br/><br/> $max_stories = $default;<br/><br/> if ($row = mysql_fetch_assoc($result)) {<br/> $max_stories = $row['max_stories'];<br/> } <br/><br/> return $max_stories;<br/>}<br/><br/>function writeRssFeed($user)<br/>{<br/> // Get the DB connection information<br/> $settings = parse_ini_file("rss_server.ini");<br/><br/> // look up the user's preferences...<br/> $link = mysql_connect($settings['db_host'], $settings['user'], <br/> $settings['password']) OR die(mysql_error());<br/><br/> $max_stories = getUserMaxStories($link, 25);<br/><br/> // go get my data<br/> $newsQuery = sprintf("SELECT * FROM stories WHERE post_date = '%s'",<br/> mysql_real_escape_string(time()));<br/><br/> $result = mysql_query($newsQuery, $link); <br/><br/> $feed = createRssHeader();<br/><br/> $i = 0;<br/> // build the feed...<br/> while ($row = mysql_fetch_assoc($result)) {<br/> if ($i < $max_stories) {<br/> $title = $row['title'];<br/> $link = $row['link'];<br/> $description = $row['description'];<br/> $date = $row['date'];<br/> $guid = $row['guid'];<br/><br/> $feed .= createRssItem($title, $link, $description, $date, $guid);<br/><br/> $i++;<br/> } else { <br/> break;<br/> }<br/> }<br/><br/> mysql_close($link);<br/><br/> $feed .= createRssFooter();<br/><br/> // write the feed out to the server...<br/> echo($feed);<br/>}<br/>?><br/> 로그인 후 복사 |
把长函数分割会导致效率降低,所以要注意,这个好习惯不要使用过度。这样做可能也会引起阅读性差,跟原来人家是一个整体时没什么区别。
注释代码
注释你的代码有时就像你刚着手写代码一样困难。明确注释内容很棘手,因为他要写出代码要做什么。注释变量是一个好主意。在函数头部注释可能不太明显时,就可以告诉阅读者函数要什么参数,有什么返回以及主要的意图。
通常大家会注释代码是做什么的,但这并不必要。如果代码让人困惑以至于你不得不写注释说它是做什么的,这就提示你应该重写它,使它更好懂。命名良好、更加短小、组织合理的代码习惯会让你的代码用不着注释就拥有很高的可读性。
坏习惯:压根没有或者叽叽歪歪的函数注释 (^_^)
例5的注释只给出了代码在做什么——它的通过循环的遍历、加了个数。但是丢了为什么这么做和要做什么。 这会让别人难以不影响原代码的情形下安全修改的做出修改。
例5 :压根没胡或者叽叽歪歪的函数注释
<?<font color="#335533">php</font><br/><br/>class ResultMessage <br/>{<br/> private $severity;<br/> private $message;<br/><br/> public function __construct($sev, $msg) <br/> {<br/> $this->severity = $sev;<br/> $this->message = $msg;<br/> }<br/><br/> public function getSeverity()<br/> {<br/> return $this->severity;<br/> }<br/><br/> public function setSeverity($severity)<br/> {<br/> $this->severity = $severity;<br/> }<br/><br/> public function getMessage()<br/> {<br/> return $this->message;<br/> }<br/><br/> public function setMessage($msg)<br/> {<br/> $this->message = $msg;<br/> }<br/>}<br/><br/>function cntMsgs($messages)<br/>{<br/> $n = 0;<br/> /* iterate through the messages... */<br/> foreach($messages as $m) {<br/> if ($m->getSeverity() == 'Error') {<br/> $n++; // add one to the result;<br/> }<br/> }<br/> return $n;<br/>}<br/><br/>$messages = array(new ResultMessage("Error", "This is an error!"),<br/> new ResultMessage("Warning", "This is a warning!"),<br/> new ResultMessage("Error", "This is another error!"));<br/><br/>$errs = cntMsgs($messages);<br/><br/>echo("There are " . $errs . " errors in the result.\n");<br/><br/>?><br/> 로그인 후 복사 |
好习惯: 注释函数和类
例6里的注释标明了类和函数的意图。注释表明方法做了什么和为什么做,这会对将来了解代码的意图很有帮助。环境的变化会需要你进行代码修改,这就会让很容易的知道开始时你代码是做什么的。
例6.好习惯:注释函数和类
<?<font color="#335533">php</font><br/>/**<br/> * The ResultMessage class holds a message that can be returned<br/> * as a result of a process. The message has a severity and<br/> * message.<br/> * <br/> * @author nagood<br/> *<br/> */<br/>class ResultMessage <br/>{<br/> private $severity;<br/> private $message;<br/><br/> /**<br/> * Constructor for the ResultMessage that allows you to assign<br/> * severity and message.<br/> * @param $sev See {@link getSeverity()}<br/> * @param $msg<br/> * @return unknown_type<br/> */<br/> public function __construct($sev, $msg) <br/> {<br/> $this->severity = $sev;<br/> $this->message = $msg;<br/> }<br/><br/> /**<br/> * Returns the severity of the message. Should be one<br/> * "Information", "Warning", or "Error".<br/> * @return string Message severity<br/> */<br/> public function getSeverity()<br/> {<br/> return $this->severity;<br/> }<br/><br/> /**<br/> * Sets the severity of the message<br/> * @param $severity<br/> * @return void<br/> */<br/> public function setSeverity($severity)<br/> {<br/> $this->severity = $severity;<br/> }<br/><br/> public function getMessage()<br/> {<br/> return $this->message;<br/> }<br/><br/> public function setMessage($msg)<br/> {<br/> $this->message = $msg;<br/> }<br/>}<br/><br/><br/>/*<br/> * Counts the messages with the given severity in the array<br/> * of messages.<br/> * <br/> * @param $messages An array of ResultMessage<br/> * @return int Count of messages with a severity of "Error"<br/> */<br/>function countErrors($messages)<br/>{<br/> $matchingCount = 0;<br/> foreach($messages as $m) {<br/> if ($m->getSeverity() == "Error") {<br/> $matchingCount++;<br/> }<br/> }<br/> return $matchingCount;<br/>}<br/><br/>$messages = array(new ResultMessage("Error", "This is an error!"),<br/> new ResultMessage("Warning", "This is a warning!"),<br/> new ResultMessage("Error", "This is another error!"));<br/><br/>$errs = countErrors($messages);<br/><br/>echo("There are " . $errs . " errors in the result.\n");<br/><br/>?><br/> 로그인 후 복사 |
异常处理
写健壮应用时经常会提到的异常处理,一般遵循着80/20原则: 80%的代码用于处理异常或者验证,20%的代码没什么实际的用途。原始的代码通常都是在乐观的环境下编写的。这意味着代码可以在数据正常、一切理解的基础环境中工作的很好。但是这种代码在其生命周期内是脆弱的。在极端的情形中,你得花更多的时间来未很可能永远不会发生的状况编写相应代码。
这个习惯就是要你处理全部的出错情况,而且如果要是不这么做,你的代码永远也完不成。
坏习惯:不处理任何异常
<?<font color="#335533">php</font><br/><br/>// Get the actual name of the <br/>function convertDayOfWeekToName($day)<br/>{<br/> $dayNames = array(<br/> "Sunday",<br/> "Monday",<br/> "Tuesday",<br/> "Wednesday",<br/> "Thursday",<br/> "Friday",<br/> "Saturday");<br/> return $dayNames[$day];<br/>}<br/><br/>echo("The name of the 0 day is: " . convertDayOfWeekToName(0) . "\n");<br/>echo("The name of the 10 day is: " . convertDayOfWeekToName(10) . "\n");<br/>echo("The name of the 'orange' day is: " . convertDayOfWeekToName('orange') . "\n");<br/><br/>?><br/> 로그인 후 복사 |
好习惯: 防守型编程
例8表明处理并抛出异常是一件很有意义的事情。不只是额外的异常处理可以让代码健壮,但是这有助于提高代码的可读性。这种异常处理为原作者查看何时编写提供了一个很好的说明。
例8.好习惯:防守型编程
<?<font color="#335533">php</font><br/><br/>/**<br/> * This is the exception thrown if the day of the week is invalid.<br/> * @author nagood<br/> *<br/> */<br/>class InvalidDayOfWeekException extends Exception { }<br/><br/>class InvalidDayFormatException extends Exception { }<br/><br/>/**<br/> * Gets the name of the day given the day in the week. Will<br/> * return an error if the value supplied is out of range.<br/> * <br/> * @param $day<br/> * @return unknown_type<br/> */<br/>function convertDayOfWeekToName($day)<br/>{<br/> if (! is_numeric($day)) {<br/> throw new InvalidDayFormatException('The value \'' . $day . '\' is an ' .<br/> 'invalid format for a day of week.');<br/> }<br/><br/> if (($day > 6) ($day < 0)) {<br/> throw new InvalidDayOfWeekException('The day number \'' . $day . '\' is an ' .<br/> 'invalid day of the week. Expecting 0-6.');<br/> }<br/><br/> $dayNames = array(<br/> "Sunday",<br/> "Monday",<br/> "Tuesday",<br/> "Wednesday",<br/> "Thursday",<br/> "Friday",<br/> "Saturday");<br/> return $dayNames[$day];<br/>}<br/><br/>echo("The name of the 0 day is: " . convertDayOfWeekToName(0) . "\n");<br/><br/>try {<br/> echo("The name of the 10 day is: " . convertDayOfWeekToName(10) . "\n");<br/>} catch (InvalidDayOfWeekException $e) {<br/> echo ("Encountered error while trying to convert value: " . $e->getMessage() . "\n");<br/>}<br/><br/>try {<br/> echo("The name of the 'orange' day is: " . convertDayOfWeekToName('orange') . "\n");<br/>} catch (InvalidDayFormatException $e) {<br/> echo ("Encountered error while trying to convert value: " . $e->getMessage() . "\n");<br/>}<br/><br/>?><br/> 로그인 후 복사 |
通过检验参数的全法性——这有助于他人使用你需要正确参数的函数——你应该检验它们并抛出异常的大意:
- 尽量抛出接近错误的异常.
- 处理每个特殊的异常.
永远,永远不要复制粘贴
把代码复制到你的编辑里的能力是一把双刃剑。一方面,它避免了你参照一些示例后重新再打一遍时出现的错误;另一方面,它让书写相似代码太简单了。
你要避免在你的程序应用中复制粘贴代码。当你发现自己在这样做时,停下来并问自己可不可以把复制的部分重复使用。把相同的代码放在同一个地方可以让你以后修改时更加的轻松,因为要改变都在一起。
坏习惯:相似的代码块
例9表现了除了一些值所在位置之外很相近的几个方法。有些工具可以检验你的代码中复制粘贴的部分(去看看Resources)。
例9.相似的代码块
<?<font color="#335533">php</font><br/>/**<br/> * Counts the number of messages found in the array of <br/> * ResultMessage with the getSeverity() value of "Error"<br/> * <br/> * @param $messages An array of ResultMessage<br/> * @return unknown_type<br/> */<br/>function countErrors($messages)<br/>{<br/> $matchingCount = 0;<br/> foreach($messages as $m) {<br/> if ($m->getSeverity() == "Error") {<br/> $matchingCount++;<br/> }<br/> }<br/> return $matchingCount;<br/>}<br/><br/>/**<br/> * Counts the number of messages found in the array of <br/> * ResultMessage with the getSeverity() value of "Warning"<br/> * <br/> * @param $messages An array of ResultMessage<br/> * @return unknown_type<br/> */<br/>function countWarnings($messages)<br/>{<br/> $matchingCount = 0;<br/> foreach($messages as $m) {<br/> if ($m->getSeverity() == "Warning") {<br/> $matchingCount++;<br/> }<br/> }<br/> return $matchingCount;<br/>}<br/><br/>/**<br/> * Counts the number of messages found in the array of <br/> * ResultMessage with the getSeverity() value of "Information"<br/> * <br/> * @param $messages An array of ResultMessage<br/> * @return unknown_type<br/> */<br/>function countInformation($messages)<br/>{<br/> $matchingCount = 0;<br/> foreach($messages as $m) {<br/> if ($m->getSeverity() == "Information") {<br/> $matchingCount++;<br/> }<br/> }<br/> return $matchingCount;<br/>}<br/><br/>$messages = array(new ResultMessage("Error", "This is an error!"),<br/> new ResultMessage("Warning", "This is a warning!"),<br/> new ResultMessage("Error", "This is another error!"));<br/><br/>$errs = countErrors($messages);<br/><br/>echo("There are " . $errs . " errors in the result.\n");<br/>?><br/> 로그인 후 복사 |
好习惯:可复用的带参函数
例10展示了把要复制的代码入到一个方法中的代码修改。另一个修改的方法则把工作代理给了一个新的方法 。编写一个通用的方法要花一些时间来设计,当然这会让你停下来思考,而不是用复制粘贴的组合快捷键。但是这样做会在以后修改时省回第一次多花的时间。
例10.好习惯 :可利用的带参函数
<?<font color="#335533">php</font><br/> /*<br/> * Counts the messages with the given severity in the array<br/> * of messages.<br/> * <br/> * @param $messages An array of ResultMessage<br/> * @return int Count of messages matching $withSeverity<br/> */<br/> function countMessages($messages, $withSeverity)<br/> {<br/> $matchingCount = 0;<br/> foreach($messages as $m) {<br/> if ($m->getSeverity() == $withSeverity) {<br/> $matchingCount++;<br/> }<br/> }<br/> return $matchingCount;<br/> }<br/><br/> /**<br/> * Counts the number of messages found in the array of <br/> * ResultMessage with the getSeverity() value of "Error"<br/> * <br/> * @param $messages An array of ResultMessage<br/> * @return unknown_type<br/> */<br/> function countErrors($messages)<br/> {<br/> return countMessages($messages, "Errors");<br/> }<br/><br/> /**<br/> * Counts the number of messages found in the array of <br/> * ResultMessage with the getSeverity() value of "Warning"<br/> * <br/> * @param $messages An array of ResultMessage<br/> * @return unknown_type<br/> */<br/> function countWarnings($messages)<br/> {<br/> return countMessages($messages, "Warning");<br/> }<br/><br/> /**<br/> * Counts the number of messages found in the array of <br/> * ResultMessage with the getSeverity() value of "Warning"<br/> * <br/> * @param $messages An array of ResultMessage<br/> * @return unknown_type<br/> */<br/> function countInformation($messages)<br/> {<br/> return countMessages($messages, "Information");<br/> }<br/><br/> $messages = array(new ResultMessage("Error", "This is an error!"),<br/> new ResultMessage("Warning", "This is a warning!"),<br/> new ResultMessage("Error", "This is another error!"));<br/><br/> $errs = countErrors($messages);<br/><br/> echo("There are " . $errs . " errors in the result.\n");<br/><br/>?><br/> 로그인 후 복사 |
结论
如果当你开发PHP的时候养成了本文中提到的好习惯,你写的代码将会好读、好懂、好维护。编写可维护代码的方式将让你的代码可以高度排错,并告别低级错误。
使用良好命名并用短代码块来组强你的代码会让你的代码简单明了。注明你代码的目的会让它的主旨明确易于理解。异常处理让你的代码健壮。最后,摒弃复制粘贴的恶习让你的代码整洁。
-----------------------------------------------------
玉米寄语:最后的这个复制粘贴的建议让我一身冷汗,想想其实有很多代码都是重复的工作,有时只是为了“快”,而把相似的代码又“复制”了一遍,虽然我没有使用ctrl+c\v 但是也是写了很多类似的代码,看来,review的事儿可以在世界和平的事儿之前考虑了。

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











많은 사용자들이 스마트 시계를 선택할 때 Huawei 브랜드를 선택하게 됩니다. 그 중 Huawei GT3pro와 GT4가 가장 인기 있는 선택입니다. 두 제품의 차이점을 궁금해하는 사용자가 많습니다. Huawei GT3pro와 GT4의 차이점은 무엇입니까? 1. 외관 GT4: 46mm와 41mm, 재질은 유리 거울 + 스테인레스 스틸 본체 + 고해상도 섬유 후면 쉘입니다. GT3pro: 46.6mm 및 42.9mm, 재질은 사파이어 유리 + 티타늄 본체/세라믹 본체 + 세라믹 백 쉘입니다. 2. 건강한 GT4: 최신 Huawei Truseen5.5+ 알고리즘을 사용하면 결과가 더 정확해집니다. GT3pro: ECG 심전도, 혈관 및 안전성 추가

기계력 보고서 편집자: 우신(Wu Xin) 국내판 휴머노이드 로봇+대형 모델팀이 옷 접기 등 복잡하고 유연한 재료의 작업 작업을 처음으로 완료했습니다. OpenAI 멀티모달 대형 모델을 접목한 Figure01이 공개되면서 국내 동종업체들의 관련 진전이 주목받고 있다. 바로 어제, 중국의 "1위 휴머노이드 로봇 주식"인 UBTECH는 Baidu Wenxin의 대형 모델과 긴밀하게 통합되어 몇 가지 흥미로운 새로운 기능을 보여주는 휴머노이드 로봇 WalkerS의 첫 번째 데모를 출시했습니다. 이제 Baidu Wenxin의 대형 모델 역량을 활용한 WalkerS의 모습은 이렇습니다. Figure01과 마찬가지로 WalkerS는 움직이지 않고 책상 뒤에 서서 일련의 작업을 완료합니다. 인간의 명령을 따르고 옷을 접을 수 있습니다.

Windows 11에서 캡처 도구가 작동하지 않는 이유 문제의 근본 원인을 이해하면 올바른 솔루션을 찾는 데 도움이 될 수 있습니다. 캡처 도구가 제대로 작동하지 않는 주요 이유는 다음과 같습니다. 초점 도우미가 켜져 있습니다. 이렇게 하면 캡처 도구가 열리지 않습니다. 손상된 응용 프로그램: 캡처 도구가 실행 시 충돌하는 경우 응용 프로그램이 손상되었을 수 있습니다. 오래된 그래픽 드라이버: 호환되지 않는 드라이버가 캡처 도구를 방해할 수 있습니다. 다른 응용 프로그램의 간섭: 실행 중인 다른 응용 프로그램이 캡처 도구와 충돌할 수 있습니다. 인증서가 만료되었습니다. 업그레이드 프로세스 중 오류로 인해 이 문제가 발생할 수 있습니다. 이 문제는 대부분의 사용자에게 적합하며 특별한 기술 지식이 필요하지 않습니다. 1. Windows 및 Microsoft Store 앱 업데이트

1부: 초기 문제 해결 단계 Apple 시스템 상태 확인: 복잡한 솔루션을 살펴보기 전에 기본 사항부터 시작해 보겠습니다. 문제는 귀하의 기기에 있는 것이 아닐 수도 있습니다. Apple 서버가 다운되었을 수도 있습니다. Apple의 시스템 상태 페이지를 방문하여 AppStore가 제대로 작동하는지 확인하세요. 문제가 있는 경우 Apple이 문제를 해결하기를 기다리는 것뿐입니다. 인터넷 연결 확인: "AppStore에 연결할 수 없음" 문제는 때때로 연결 불량으로 인해 발생할 수 있으므로 인터넷 연결이 안정적인지 확인하십시오. Wi-Fi와 모바일 데이터 간을 전환하거나 네트워크 설정을 재설정해 보세요(일반 > 재설정 > 네트워크 설정 재설정 > 설정). iOS 버전을 업데이트하세요.

php提交表单通过后,弹出的对话框怎样在当前页弹出php提交表单通过后,弹出的对话框怎样在当前页弹出而不是在空白页弹出?想实现这样的效果:而不是空白页弹出:------解决方案--------------------如果你的验证用PHP在后端,那么就用Ajax;仅供参考:HTML code

Watch4pro와 gt는 각각 서로 다른 기능과 적용 가능한 시나리오를 가지고 있습니다. 포괄적인 기능, 고성능, 세련된 외관에 중점을 두고 더 높은 가격을 감수할 의향이 있다면 Watch 4 Pro가 더 적합할 수 있습니다. 높은 기능 요구 사항이 없고 배터리 수명과 합리적인 가격에 더 많은 관심을 기울이는 경우 GT 시리즈가 더 적합할 수 있습니다. 최종 선택은 개인의 필요와 예산, 선호도에 따라 결정되어야 합니다. 자신의 필요를 잘 고려한 후 구매하고, 다양한 제품에 대한 리뷰와 비교를 참고하여 보다 현명한 선택을 하는 것이 좋습니다.

THE(Tokenized Healthcare Ecosystem)는 블록체인 기술을 사용하여 의료 산업의 혁신과 개혁에 초점을 맞춘 디지털 통화입니다. THE 코인의 임무는 블록체인 기술을 사용하여 의료 산업의 효율성과 투명성을 향상시키고 환자, 의료진, 제약 회사 및 의료 기관을 포함한 모든 당사자 간의 보다 효율적인 협력을 촉진하는 것입니다. THE Coin의 가치와 특징 우선, THE Coin은 디지털 화폐로서 블록체인의 장점(분권화, 높은 보안성, 투명한 거래 등)을 갖고 있어 참여자들이 이 시스템을 신뢰하고 의존할 수 있습니다. 둘째, THE 코인의 독창성은 의료 및 건강 산업에 초점을 맞추고 블록체인 기술을 사용하여 전통적인 의료 시스템을 변화시키고 개선한다는 것입니다.

iPadOS 17.4로 iPad 배터리 수명을 최적화하는 방법 배터리 수명 연장은 모바일 장치 경험의 핵심이며 iPad가 좋은 예입니다. iPad의 배터리가 너무 빨리 소모된다고 생각되더라도 걱정하지 마세요. iPadOS 17.4에는 기기의 실행 시간을 크게 연장할 수 있는 여러 가지 요령과 조정 사항이 있습니다. 이 심층 가이드의 목표는 단순히 정보를 제공하는 것이 아니라 iPad 사용 방식을 바꾸고 전반적인 배터리 관리를 향상하며 기기를 충전하지 않고도 기기를 더 오랫동안 사용할 수 있도록 하는 것입니다. 여기에 설명된 사례를 채택함으로써 귀하는 개인의 요구 사항과 사용 패턴에 맞는 기술을 보다 효율적이고 주의 깊게 사용하는 방향으로 나아갈 수 있습니다. 주요 에너지 소비자 식별
