search
Homephp教程php手册while 的一点理解

  while是php里面用的最多的一个函数,但是观察了很久,但是很多人用习惯了,并不知道里面是怎么回事,只是习惯性打上去;

  先测一下一秒中,while可以运行多少次循环;

  $time1 = microtime(true);

  $i =0;

  while(1)

  {

  $i++;

  if(microtime(true)- $time1 >1)

  {

  echo $i;

  exit();

  }

  }

  ?>

  运行结果

  389443;

  while是当whle括号里面的条件成立的话,就执行,这是绝对正确的

  所以while(1)就是无限循环;

  实例1:

  $sql = "select * from table";

  $result = mysql_query($sql);

  while($arr = mysql_fetch_assoc($result))

  {

  }

  这一个理解是当while括号里面$arr = mysql_fetch_assoc($result);成立的情况下,就会一直往下运行;

  $arr = mysql_fetch_assoc($result);

  当执行这个查询的话,第一次,指针就对准第一行,如果第二次查询的时候,他就会对准第二行,一直找到没有结果,返回false就不会执行了

  错误写法:

  $sql = "select * from table";

  $result = mysql_query($sql);

  $arr = mysql_fetch_assoc($result));

  while($arr = mysql_fetch_assoc($result))

  {

  }

  这样执行过来的结果就会少了一行;

  实例2:两分算法

  while($ip1num>$ipNum $ip2num

  {

  }

  这是discuz里面取得ip地址对应的真实地址的function

  附件里面有这个function的文件包

  简单的拆成

  while($a>1 $b

  {

  }

  再拆

  while($a >1)

  {

  }

  while($b

  {

  }

  如果$a 是先有值的情况下,

  如果$a =1;

  那样就执行不下去,条件不成立

  或者$a =2;

  这样就无限循环了;

  重点

  如果$a没有先附值

  刚开始我一直以为是错误,但是实际上他不会有错误,

  这是php不同的地方

  简单通过一个程序测试一下

  $i =0;

  while($a

  {

  $i++;

  if(microtime(true)- $time1 >1)

  {

  echo $i;

  $a =1;

  }

  }

  ?>

  运行结果

  272487;

  while($a

  他会一直执行,直到程序里面括号里面重新得到一个值$a =1;

  $a

  所以

  while($a>1 $b

  {

  }

  的理解是当括号内部执行到$a=1两个条件分成成立的情况下执行才中止执行

  这样就是双分算法了

  如果这两个都理解的话,基本上while就非常清楚了

  while(1)非常 庞大的,

  本来想帖一个dos的攻击源代码出来,但是感觉如果不小心文章推广得太开,到时候就麻烦了。

  dos源码非常 简单,只要上面理解了,非常 容易就可以写一个出来;

  ddos就是通过一个调用主控,调用不同服务器网站上面的程序,让他们同时运行,就形成了dos,关键是鸡的数量;



Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
在C语言中,while(1)和while(0)之间的区别是什么?在C语言中,while(1)和while(0)之间的区别是什么?Aug 31, 2023 am 10:45 AM

我们知道在C语言中,'while'关键字用于定义一个循环,该循环根据传递给循环的条件来工作。现在,由于条件可以有两个值,即真或假,所以如果条件为真,则while块内的代码将被重复执行,如果条件为假,则代码将不会被执行。现在,通过将参数传递给while循环,我们可以区分while(1)和while(0),因为while(1)是一个条件始终被视为真的循环,因此块内的代码将开始重复执行。此外,我们可以说明,传递给循环并使条件为真的不是1,而是如果任何非零整数传递给while循环,则它将被视为真条件,因

mysql怎么替换换行符mysql怎么替换换行符Apr 18, 2022 pm 03:14 PM

在mysql中,可以利用char()和REPLACE()函数来替换换行符;REPLACE()函数可以用新字符串替换列中的换行符,而换行符可使用“char(13)”来表示,语法为“replace(字段名,char(13),'新字符串') ”。

mysql怎么将varchar转换为int类型mysql怎么将varchar转换为int类型May 12, 2022 pm 04:51 PM

转换方法:1、利用cast函数,语法“select * from 表名 order by cast(字段名 as SIGNED)”;2、利用“select * from 表名 order by CONVERT(字段名,SIGNED)”语句。

MySQL复制技术之异步复制和半同步复制MySQL复制技术之异步复制和半同步复制Apr 25, 2022 pm 07:21 PM

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于MySQL复制技术的相关问题,包括了异步复制、半同步复制等等内容,下面一起来看一下,希望对大家有帮助。

带你把MySQL索引吃透了带你把MySQL索引吃透了Apr 22, 2022 am 11:48 AM

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了mysql高级篇的一些问题,包括了索引是什么、索引底层实现等等问题,下面一起来看一下,希望对大家有帮助。

mysql怎么判断是否是数字类型mysql怎么判断是否是数字类型May 16, 2022 am 10:09 AM

在mysql中,可以利用REGEXP运算符判断数据是否是数字类型,语法为“String REGEXP '[^0-9.]'”;该运算符是正则表达式的缩写,若数据字符中含有数字时,返回的结果是true,反之返回的结果是false。

mysql-connector是什么mysql-connector是什么May 12, 2022 pm 04:04 PM

“mysql-connector”是mysql官方提供的驱动器,可以用于连接使用mysql;可利用“pip install mysql-connector”命令进行安装,利用“import mysql.connector”测试是否安装成功。

mysql需要commit吗mysql需要commit吗Apr 27, 2022 pm 07:04 PM

在mysql中,是否需要commit取决于存储引擎:1、若是不支持事务的存储引擎,如myisam,则不需要使用commit;2、若是支持事务的存储引擎,如innodb,则需要知道事务是否自动提交,因此需要使用commit。

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Repo: How To Revive Teammates
4 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
4 weeks agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

DVWA

DVWA

Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment