这是一个有味的问题哦,for ,while ,do while区别我想你认真仔细看了之后应该明白了它们三用法与区别了。
do...while语句
一个do-while语句应该具有如下格式:
do {
statements;
} while (condition);
<?php
$a =1;
do {
$a++;
}while($a<1);
echo $a;
?>
输出结果为2
do while 不管条件是否成立它都会执行一次,来看看实现。
while语句
一个while语句应该具有如下格式
while (condition) {
statements;
}
一个空的while语句应该具有如下格式:
while (condition);
来看个while实现
<?php
$a =1;
while($a<1)$a++;
echo $a;
?>
输出结果为1
注明:while语句必须条件为真是才执行while里面的内容 ,for与while是相同的
for语句
一个for语句应该具有如下格式:
for (initialization; condition; update) {
statements;
}
一个空的for语句(所有工作都在初始化,条件判断,更新子句中完成)应该具有如下格式:
for (initialization; condition; update);
当在for语句的初始化或更新子句中使用逗号时,避免因使用三个以上变量,而导致复杂度提高。若需要,可以在for循环之前(为初始化子句)或for循环末尾(为更新子句)使用单独的语句。
for实现
<?php
$a =1;
for( $a=1;$a<1;$a++){
$a++;
}
echo $a;
?>
输出结果为1
php 取中英字母长度代码
function substrs($c, $l=16){
if(strlen($c)>$l){
$n=0;
for($i=0;$i<$l;$i++){
if(ord(substr($c,$i,1))>127){
$n++;
if($i<($l-1)){
$i++;
$n++;
}
}
}
if($n%2>0)$l+=1;
$c=substr($c, 0, $l).'…';
}
return $c;
}
代码范例
/*
* @(#)Cngift.php 1.82 03/06/25
*
* 开花石头编写的示例文档
* 将对编码规范做简单的示范
*
*/
require( “db.php” );
/**
* 示范用类
*
* @version 1.82 03.06.25
* @author 开花石头
*/
class Blah extends SomeClass {
/* 这个类运行时的注释写在这里 */
/** 关于变量的注释写在这里 */
static int $classVar1;
/**
* 对变量编写的多行注释写在这里
*/
static string classVar2;
/** 变量的文档注释 */
int instanceVar1;
/** 变量的文档注释 */
int[] instanceVar3;
/**
* 构造函数的注释
*/
function Blah() {
// ...在这里执行...
}
/**
* ...函数的文档注释...
*/
function doSomething() {
// ...在这里执行...
}
/**
* ...方法的注释文档..
* 多行注释
*/
public void doSomethingElse(Object someParam) {
// ...在这里执行...
}
}
下面我们为php初学者讲一篇关于变量赋值可注意的事项吧。
变量赋值
<?php
$a =1;
$b =1;
$c =2;
$d =2;
if ($a == $b && $c == $d) die('error');// 错误
if (($a == $b) && ($c == $d)) die('yes');// 正确
?>
不要使用内嵌(embedded)赋值运算符试图提高运行时的效率,这是编译器的工作。例如:
$d = ($a = $b + $c) + $r; // 错误
应该写成
$a = $b + $c;
$d = $a + $r;
避免在一个语句中给多个变量赋相同的值。它很难读懂。例如:
$fooBar.fChar = $barFoo.lchar = 'c'; // 错误
不要将赋值运算符用在容易与相等关系运算符混淆的地方。例如:
if ($c++ = $d++) { // 错误
...
}
应该写成
if (($c++ = $d++) != 0) {
...
}
关于类申明我们以前有讲过,这次主要是针对php程序员编程的规范化来讲讲吧。
类的声明
当编写类时,应该遵守以下格式规则:
- 在方法名与其参数列表之前的左括号"("间不要有空格
- 左大括号"{"位于声明语句同行的末尾
- 右大括号"}"另起一行,与相应的声明语句对齐,除非是一个空语句,"}"应紧跟在"{"之后
class Sample extends Object {
int $ivar1;
int $ivar2;
function Sample(int $i, int $j) {
ivar$1 = $i;
ivar$2 = $j;
}
function emptyMethod() {}
...
}
- 方法与方法之间以空行分隔
布局
只在代码块的开始处声明变量。(一个块是指任何被包含在大括号"{"和"}"中间的代码。)不要在首次用到该变量时才声明之。这会把注意力不集中的程序员搞糊涂,同时会妨碍代码在该作用域内的可移植性。
function myMethod() {
int $int1 = 0; // 方法块的开始
if ($condition) {
int $int2 = 0; // "if"块的开始
...
}
}
该规则的一个例外是for循环的索引变量
for (int $i = 0; i < $maxLoops; $i++) { ... }
避免声明的局部变量覆盖上一级声明的变量。例如,不要在内部代码块中声明相同的变量名:
int $count;
...
function myMethod() {
if ($condition) {
int $count = 0; // 避免这种声明
...
}
...
}