热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

PHP的学习-PHP源码

ec(2);PHP的学习学习使用了阵子PHP,PHP开发速度应该是不错的,相同的项目PHP的代码量估计要比用JSP要少很多。但是在使用过程中也发现一些问题,也看了一些别人PHP项目代码,说下一下感受.1.PHP灵活但不能涂鸦一般使用.如果把数据库操作都写在一个页面上,维护就吃力了.至少要把数据库操作跟页面渲染分离开,类似JSP加JavaBean的方式,相信这也是PHP

PHP的学习

学习使用了阵子PHP,PHP开发速度应该是不错的,相同的项目PHP的代码量估计要比用JSP要少很多。
但是在使用过程中也发现一些问题,也看了一些别人PHP项目代码,说下一下感受.

1. PHP灵活但不能涂鸦一般使用.
如果把数据库操作都写在一个页面上,维护就吃力了.至少要把数据库操作跟页面渲染分离开,类似JSP
加JavaBean的方式,相信这也是PHPer采用的简单MVC.

2.PHP常量
PHP array的array的读写都很灵活,可能页面会经常有这样的
echo $myArray[''myKey''];数据库操作mysql_fetch_array返回的row也是,万一key值''myKey''开发的
时候没定义好,又或''myKey''是列名,突然要改了,这个常量每个文件都有的话,改起代码来就郁闷了.
PHP会使用define,类里面会使用const来代表常量
define(''MY_CONSTANT'', ''MY_VALUE'');
echo MY_CONSTANT;
class MyClass{
const MY_COnSTANT= ''MY_VALUE'';
public function test(){
echo self::MY_CONSTANT;
}
}
//External usage
echo MyClass::MY_CONSTANT;

3.=号赋值拷贝
=大多情况下是拷贝的形式的赋值.
$oldValue = array(1,2,3);
$newValue = $oldValue;
$newValue[] = 4;
echo $oldValue;//1,2,3
echo $newValue;//1,2,3,4
可以看到$newValue只是值拷贝,它的修改不会改变$oldValue.估计class实例的赋值也是拷贝。

还有什么会导致拷贝,function的入参,和return返回值应该也是默认是值拷贝传递.
function test($param) {
echo $param;//string
$param = ''newstring'';
echo $param;//newstring
}
$strParam = ''string'';
test($strParam);
echo $strParam;//string

foreach迭代array的时候可能导致拷贝
$myArray = array(''key1''=>''value1'',''key2''=>''value2'');
foreach($myArray as $key=>$value) {
echo "$key=$value
";
}
按照PHP手册的说法就是foreach的时候是拷贝了一个新的array,即使在循环中修改了值,对旧array没影响.

=号对于clone好像是不算是拷贝?

个人感觉不太喜欢拷贝,如果拷贝的东西比较大,估计会影响执行效率了吧.

4. 使用reference引用避免拷贝
其实就是使用=& 引用其实是别名Alias,觉得这个就是java,c#类默认使用的,PHP必须显式加个&,有点像
c++.
$oldValue = array(1,2,3);
$newValue = &$oldValue;
$newValue[] = 4;
echo $oldValue;//1,2,3,4
echo $newValue;//1,2,3,4

PHP4里面$myClassInstance = new MyClass();其实是一种拷贝, 必须
$myClassInstance = &new MyClass();
PHP5里面就支持好多了默认new出来的东西就是PHP4里面的&new引用。

入参如果数据大(假设是一个大数组)可以传递引用避免值拷贝
function test(&$param) {
echo $param;//string
$param = ''newstring'';
echo $param;//newstring
}
$strParam = ''string'';
test($strParam);
echo $strP
推荐阅读
  • MySQL中的MVVC多版本并发控制机制的应用及实现
    本文介绍了MySQL中MVCC的应用及实现机制。MVCC是一种提高并发性能的技术,通过对事务内读取的内存进行处理,避免写操作堵塞读操作的并发问题。与其他数据库系统的MVCC实现机制不尽相同,MySQL的MVCC是在undolog中实现的。通过undolog可以找回数据的历史版本,提供给用户读取或在回滚时覆盖数据页上的数据。MySQL的大多数事务型存储引擎都实现了MVCC,但各自的实现机制有所不同。 ... [详细]
  • 解决VS写C#项目导入MySQL数据源报错“You have a usable connection already”问题的正确方法
    本文介绍了在VS写C#项目导入MySQL数据源时出现报错“You have a usable connection already”的问题,并给出了正确的解决方法。详细描述了问题的出现情况和报错信息,并提供了解决该问题的步骤和注意事项。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • 本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ... [详细]
  • 本文由编程笔记小编整理,介绍了PHP中的MySQL函数库及其常用函数,包括mysql_connect、mysql_error、mysql_select_db、mysql_query、mysql_affected_row、mysql_close等。希望对读者有一定的参考价值。 ... [详细]
  • C# 7.0 新特性:基于Tuple的“多”返回值方法
    本文介绍了C# 7.0中基于Tuple的“多”返回值方法的使用。通过对C# 6.0及更早版本的做法进行回顾,提出了问题:如何使一个方法可返回多个返回值。然后详细介绍了C# 7.0中使用Tuple的写法,并给出了示例代码。最后,总结了该新特性的优点。 ... [详细]
  • 本文介绍了RPC框架Thrift的安装环境变量配置与第一个实例,讲解了RPC的概念以及如何解决跨语言、c++客户端、web服务端、远程调用等需求。Thrift开发方便上手快,性能和稳定性也不错,适合初学者学习和使用。 ... [详细]
  • 本文介绍了关于apache、phpmyadmin、mysql、php、emacs、path等知识点,以及如何搭建php环境。文章提供了详细的安装步骤和所需软件列表,希望能帮助读者解决与LAMP相关的技术问题。 ... [详细]
  • 如何在php中将mysql查询结果赋值给变量
    本文介绍了在php中将mysql查询结果赋值给变量的方法,包括从mysql表中查询count(学号)并赋值给一个变量,以及如何将sql中查询单条结果赋值给php页面的一个变量。同时还讨论了php调用mysql查询结果到变量的方法,并提供了示例代码。 ... [详细]
  • 在springmvc框架中,前台ajax调用方法,对图片批量下载,如何弹出提示保存位置选框?Controller方法 ... [详细]
  • 导出功能protectedvoidbtnExport(objectsender,EventArgse){用来打开下载窗口stringfileName中 ... [详细]
  • MVC设计模式的介绍和演化过程
    本文介绍了MVC设计模式的基本概念和原理,以及在实际项目中的演化过程。通过分离视图、模型和控制器,实现了代码的解耦和重用,提高了项目的可维护性和可扩展性。详细讲解了分离视图、分离模型和分离控制器的具体步骤和规则,以及它们在项目中的应用。同时,还介绍了基础模型的封装和控制器的命名规则。该文章适合对MVC设计模式感兴趣的读者阅读和学习。 ... [详细]
  • Todayatworksomeonetriedtoconvincemethat:今天在工作中有人试图说服我:{$obj->getTableInfo()}isfine ... [详细]
  • MySQL数据库锁机制及其应用(数据库锁的概念)
    本文介绍了MySQL数据库锁机制及其应用。数据库锁是计算机协调多个进程或线程并发访问某一资源的机制,在数据库中,数据是一种供许多用户共享的资源,如何保证数据并发访问的一致性和有效性是数据库必须解决的问题。MySQL的锁机制相对简单,不同的存储引擎支持不同的锁机制,主要包括表级锁、行级锁和页面锁。本文详细介绍了MySQL表级锁的锁模式和特点,以及行级锁和页面锁的特点和应用场景。同时还讨论了锁冲突对数据库并发访问性能的影响。 ... [详细]
author-avatar
逍遥子
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有