随着大量的框架使用composer和namespace,渐渐的线上环境也从之前的5.3变成了5.4或者5.5甚至5.6,随着7月份PHP7的发布,会有更多的公司采用新版本。
之前好久就想写这样的一片文章,来说明下各个版本的差异,这次算是拿出时间了。
这次的是第一篇,目前规划写三篇
一方面是对自己的知识的整理,一方面是对自己的一次提升。
官方文档地址 http://php.net/ChangeLog-5.php#5.4.0
原文
- autoconf 2.59+ is now supported (and required) for generating the configure script with ./buildconf. Autoconf 2.60+ is desirable otherwise the configure help order may be incorrect.
翻译
autoconf 2.59 +现在支持(需要)生成配置脚本/ buildconf。autoconf 2.60 +是理想的配置,否则有可能是不正确的。
php编译安装的时候需要的依赖软件,所以新版本对应配套的软件也要换成最新的对性能来讲才保险啊~
原文
- break/continue $var syntax.
- Safe mode and all related ini options.
- register_globals and register_long_arrays ini options.
- import_request_variables().
- allow_call_time_pass_reference.
- define_syslog_variables ini option and its associated function.
- highlight.bg ini option.
- Session bug compatibility mode (session.bug_compat_42 and session.bug_compat_warn ini options).
- session_is_registered(), session_register() and session_unregister() functions.
- y2k_compliance ini option.
- magic_quotes_gpc, magic_quotes_runtime and magic_quotes_sybase ini options. get_magic_quotes_gpc, get_magic_quotes_runtime are kept but always return false, set_magic_quotes_runtime raises an E_CORE_ERROR.
- Removed support for putenv(“TZ=..”) for setting the timezone.
- Removed the timezone guessing algorithm in case the timezone isn’t set with date.timezone or date_default_timezone_set(). Instead of a guessed timezone, “UTC” is now used instead.
翻译
- break/continue$ var语法。
- 安全模式和所有相关的INI选项。
- register_globals和register_long_arrays INI选项。
- import_request_variables()。
- allow_call_time_pass_reference。
- define_syslog_variables INI选项及其相关的功能。
- highlight.bg INI选项。
- 会话错误兼容模式(session.bug_compat_42和session.bug_compat_warn INI选项)。
- session_is_registered(),session_register()和session_unregister()功能。
- y2k_compliance INI选项。
- magic_quotes_gpc,magic_quotes_runtime和magic_quotes_sybase INI选项。get_magic_quotes_gpc,get_magic_quotes_runtime保存但始终返回false,set_magic_quotes_runtime引发e_core_error。
- 不再支持putenv(“TZ = ..”)设置时区。
- 如果不设置时区与时区date.timezone或date_default_timezone_set()除去猜测算法。而不是猜测的时区,“UTC”现在是用来代替。
我是拿百度翻译来的我会乱说吗? =_=
移除了break/continue $var语法
在5.4之前,我们可以通过传递后面的参数来控制跳出或者停止若干层的循环,然而在5.4.0的版本之后,就去除了这个特性。
break $c; continue $c;
break and continue accepts a number, that specify the number of nested loops, that should be breaked up, or continued.
参考资料
PHP 的安全模式是为了试图解决共享服务器(shared-server)安全问题而设立的。在结构上,试图在 PHP 层上解决这个问题是不合理的,但修改 web 服务器层和操作系统层显得非常不现实。因此许多人,特别是 ISP,目前使用安全模式。
语言的发展是在不断的进步的啊,也是一个不断试错改错的过程。^_^
参考资料
这两个配置项因为性能关系被移除了。
参考资料
import_request_variables — 将 GET/POST/Cookie 变量导入到全局作用域中
bool import_request_variables ( string
types[,string prefix ] )
将 GET/POST/Cookie 变量导入到全局作用域中。如果你禁止了 register_globals,但又想用到一些全局变量,那么此函数就很有用。你可以使用 types 参数指定需要导入的变量。可以用字母‘G’、‘P’和‘C’分别表示 GET、POST 和 Cookie。这些字母不区分大小写,所以你可以使用‘g’、‘p’和‘c’的任何组合。POST 包含了通过 POST 方法上传的文件信息。注意这些字母的顺序,当使用“gp”时,POST 变量将使用相同的名字覆盖 GET 变量。任何 GPC 以外的字母都将被忽略。
prefix 参数作为变量名的前缀,置于所有被导入到全局作用域的变量之前。所以如果你有个名为“userid”的 GET 变量,同时提供了“pref_”作为前缀,那么你将获得一个名为 $pref_userid 的全局变量。
如果你对导入其它全局变量(例如 SERVER 变量)感兴趣,请考虑使用 extract()。
参考资料
是否启用在函数调用时强制参数被按照引用传递。此方法已不被赞成并在 PHP/Zend 未来的版本中很可能不再支持。鼓励使用的方法是在函数定义中指定哪些参数应该用引用传递。鼓励大家尝试关闭此选项并确保脚本能够正常运行,以确保该脚本也能在未来的版本中运行(每次使用此特性都会收到一条警告,参数会被按值传递而不是按照引用传递)。
在函数调用时通过引用传递参数是不推荐的,因为它影响到了代码的整洁。如果函数的参数没有声明作为引用传递,函数可以通过未写入文档的方法修改其参数。要避免其副作用,最好仅在函数声明时指定那个参数需要通过引用传递。
参考资料
初始化syslog相关的设置项,从这个版本进行了移除。
define_syslog_variables()只定义了全局变量。常数已经永远的定义,如果日志模块加载。你do not需要调用这个使用syslog常数。
也就是我们如果想要使用syslog相关的参数,直接调用就行,不需要进行手动初始化。
参考资料
Colors for Syntax Highlighting mode. Anything that’s acceptable in would work.
和这个高亮相关配置项还有下面几个,对代码高亮的颜色进行配置
- highlight.comment
- highlight.default
- highlight.html
- highlight.keyword
- highlight.string
参考资料
php.ini中有说明
这是php4.3.0以后才有的安全设置。
出于安全的考虑php不建议你打开register_globals开关
但若关闭了register_globals(默认)时,session变量将不被自动转换成全局变量
此时传统的session变量注册方式session_register就失去意义了(session_register是把一个全局变量注册成session变量),因为访问session变量需要使用SESSION数组。因此只需直接操作 _SESSION数组就可以了,而无须再用session_register注册了。以免产生混乱开关session.bug_compat_42 和 session.bug_compat_warn 就是为了检查此类情况而设置的
参考资料
这里提到的三个session相关的函数
这些是session相关的注册相关的函数。
参考资料
这。。。是关于2000的时候的千年虫的配置项。
参考资料
magic_quotes_gpc,magic_quotes_runtime和magic_quotes_sybase INI选项。get_magic_quotes_gpc,get_magic_quotes_runtime保存但始终返回false,set_magic_quotes_runtime引发e_core_error。
这个配置被撤销之后,如果再使用就会引发错误。
不再支持putenv(“TZ = ..”)设置时区,也就是不能再通过这个函数来设置时区相关的环境配置了.
添加 setting 到服务器环境变量。 环境变量仅存活于当前请求期间。 在请求结束时环境会恢复到初始状态。
设置特定的环境变量也有可能是一个潜在的安全漏洞。 safe_mode_allowed_env_vars 包含了一个以逗号分隔的前缀列表。 在安全模式下,用户可以仅能修改用该指令设定的前缀名称的指令。 默认情况下,用户仅能够修改以 PHP_ 开头的环境变量(例如 PHP_FOO=BAR)。 注意:如果此指令是空的,PHP允许用户设定任意环境变量!
可见这个函数真是危险啊。。。
参考资料
如果不设置时区与时区date.timezone或date_default_timezone_set()除去猜测算法。而不是猜测的时区,“UTC”现在是用来代替。
date_default_timezone_set() 设定用于所有日期时间函数的默认时区。
Note:
自 PHP 5.1.0 起(此版本日期时间函数被重写了),如果时区不合法则每个对日期时间函数的调用都会产生一条 E_NOTICE 级别的错误信息,如果使用系统设定或 TZ 环境变量则还会产生 E_STRICT 级别的信息。
参考资料
原文
翻译
This package is not maintained anymore and has been superseded. Package has moved to channel http://php.net/sqlite, package .
这个包是不是保持了与已被取代。包已经转移到渠道http://php.net/sqlite,包。
也就是说这个sqlite从pecl转移到了SQLite的扩展中。
参考资料
原文
<?=
is now always available regardless of the short_open_tag setting.翻译
<?=
永远是现在可用的short_open_tag设置。发现这么翻译还不如不翻译看的明白。。。。
<?php
$array = array(
"foo" => "bar",
"bar" => "foo",
);
// 自 PHP 5.4 起
$array = [
"foo" => "bar",
"bar" => "foo",
];
?>
参考资料
从PHP5.4开始, 我们可以直接在代码中书写二进制直接量了. 这个在定义一些标志位的时候, 尤为方便.
$bin = 0b1101;
echo $bin;
//13
参考资料
Makes PHP more flexible, when calling class/object methods.
$method = ‘method‘;
$test = new Test();
$test->method();
$test->$method();
$test->{‘method‘}();
Test::method();
Test::$method();
Test::{‘method‘}();
参考资料
添加多字节默认支持。以前的PHP必须编译——使Zend字节。现在可以启用或禁用通过zend.multibyte指令在php.ini。
参考资料
从EXT / mbstring编译时依赖
自 PHP 5.4.0 起,PHP 实现了代码复用的一个方法,称为 traits。
Traits 是一种为类似 PHP 的单继承语言而准备的代码复用机制。Trait 为了减少单继承语言的限制,使开发人员能够自由地在不同层次结构内独立的类中复用方法集。Traits 和类组合的语义是定义了一种方式来减少复杂性,避免传统多继承和混入类(Mixin)相关的典型问题。
Trait 和一个类相似,但仅仅旨在用细粒度和一致的方式来组合功能。Trait 不能通过它自身来实例化。它为传统继承增加了水平特性的组合;也就是说,应用类的成员不需要继承
参考资料
$this
support back用于代表 匿名函数 的类.
匿名函数(在 PHP 5.3 中被引入)会产生这个类型的对象。在过去,这个类被认为是一个实现细节,但现在可以依赖它做一些事情。自 PHP 5.4 起,这个类带有一些方法,允许在匿名函数创建后对其进行更多的控制。
除了此处列出的方法,还有一个 __invoke 方法。这是为了与其他实现了 __invoke()魔术方法 的对象保持一致性,但调用匿名函数的过程与它无关。
待续。。
参考资料
可以说上是直接获取数组中的元素吧,对于我们来说还是很方便的,能省下一个变量。
在以前, 我们如果定义一个返回数组的函数:
<?php
function foo() {
return array(1, 2, 3);
}
那么, 如果我要获取返回数组中的第二个元素, 就只能:
<?php
list(, $mid, ) = foo();
//或者:
$tmp = $foo();
$mid = $tmp[1];
而从5.4开始, 我们就不需要这么麻烦了, 只需要:
<?php
$mid = foo()[1];
另外, 也可以使用引用:
<?php
function &getTable() {
return $GLOBALS;
}
getTable()["foo"] = "laruence";
echo $foo;
//laruence
参考资料
要想了解这个首先需要了解的是类型约束
PHP 5 可以使用类型约束。函数的参数可以指定必须为对象(在函数原型里面指定类的名字),接口,数组(PHP 5.1 起)或者 callable(PHP 5.4 起)。不过如果使用 NULL 作为参数的默认值,那么在调用函数的时候依然可以使用 NULL 作为实参。
如果一个类或接口指定了类型约束,则其所有的子类或实现也都如此。
类型约束不能用于标量类型如 int 或 string。Traits 也不允许
/**
* 测试函数
* 第一个参数必须为 OtherClass 类的一个对象
*/
public function test(OtherClass $otherclass) {
echo $otherclass->var;
}
其中的OtherClass 就是我们的类型约束
在PHP5.4版本中,新增了Callable类型的类型约束
<?php
function foo(callable $callback) {
}
<?php
foo("false"); //Catchable fatal error: Argument 1 passed to foo() must be callable *
foo("printf"); //okey
foo(function(){}); //okey
class A {
static function show() {
}
}
foo(array("A", "show")); //okey
参考资料
这里在后面还有一个#47160的bug.
<?php
// For 5.2.x as well.
class Thing {
static function DoesStuff() {
echo ‘Hello, World‘;
}
}
$f = array(‘Thing‘, ‘DoesStuff‘);
$f();
//返回 Hello, World
?>
按照bug页面上的,之前的版本就会返回错误,现在已经好啦~
<?php
class Hello {
//这是一个静态的方法
static public function world($x) {
echo "Hello, $x\n";
}
}
function hello_world($x) {
echo "Hello, $x\n";
}
//数组中包含了三个,第一个数组,第二个匿名函数,第三个字符串
$callbacks = array(
array(‘Hello‘, ‘world‘),
function ($x) { echo "Hello, $x\n"; },
‘hello_world‘
);
//循环了数组
foreach ($callbacks as $k => $callback) {
if (is_callable($callback)) { //检测参数是否为合法的可调用结构
$callback($k); //然后就把自己的key值作为参数传递过去了
}
}
//RESULT:
//Hello, 0 指向了Hello的world静态方法
//Hello, 1 参数本身就是匿名函数,是可以直接执行的
//Hello, 2 作为字符串的参数可以找到相同名字的方法,所以执行了
//CalvinLee
?>
上面的第一个栗子说明了我们可以通过数组的形式直接调用方法,确认回调函数,通过array(‘类‘,‘方法‘)
的方式进行直接调用。
这是一个因为bug造成的新特性。
参考资料
DTrace(全称Dynamic Tracing),也称为动态跟踪,是由 Sun? 开发的一个用来在生产和试验性生产系统上找出系统瓶颈的工具,可以对内核(kernel)和用户应用程序(user application)进行动态跟踪并且对系统运行不构成任何危险的技术。在任何情况下它都不是一个调试工具, 而是一个实时系统分析寻找出性能及其他问题的工具。
也就是这个调试工具可以直接支持PHP辣!可以进行更深层次的代码调试。
有时间可以研究一下这个怎么用。
。。。
参考资料
class Test {
public function foo() {
return $this;
}
public function bar() {
return ‘oh hai‘;
}
}
$t = (new Test)->foo();
print $t->bar();
我们可以直接调用啦啦啦~
很方便的样子!
参考资料
<?=
短标签PHP5.4里默认开启了短标签设置,支持了行内的短标签 <?= ?>
<?php
$a = 2;
?>
<?=$a?>
这个短标签直接输出了,所以是用于行内的。
参考资料
实现Zend Signal Handling(可配置的选项——–enable-zend-signals,默认关闭)
新的机制, 叫做zend signal, 它的理念, 来自Yahoo的”延迟信号处理”(Yahoo signal deferring mechanism), 而后, facebook把这套理念加入了PHP中, 为了提升PHP+Apache 1.X下PHP调用ap_block/ap_unblock的性能
参考资料
改进的输出层,看到readme.new-output-api内部
看起来像是内核的输出层改动,但是实在是找不到资料,不知道怎么理解这一条。QAQ
改进的UNIX系统允许建立建设多个PHP二进制SAPIs和SAPI模块相同的时间。#53271, #52419.
这里在后面提到了两个bug。
Using configure options –enable-cgi and –enable-fpm together will not produce the php-cgi binary.
两个配置一起的时候就不会产生php-cgi的二进制。
两个模块作为配置项的时候会编译失败。
参考资料
Closure::bind — 复制一个闭包,绑定指定的$this对象和类作用域。
Closures: Object extension 关闭对象扩展
这里需要理解一个Closure的概念,Closure 类,匿名函数类。
匿名函数(在 PHP 5.3 中被引入)会产生这个类型的对象。在过去,这个类被认为是一个实现细节,但现在可以依赖它做一些事情。自 PHP 5.4 起,这个类带有一些方法,允许在匿名函数创建后对其进行更多的控制
<?php
class APP {
public $var = 25;
public function __construct() {
}
public function get($callback) {
if (!is_callable($callback)) {
throw new InvalidArgumentException(‘Paran must be callable.‘);
}
// $callback->bindTo($this);
// $callback->bindTo($this, $this);
// $callback();
//上面的回调方法找不到绑定的对象,下面的方法是用一个新的变量来做绑定函数的结果,然后执行
$callback1 = $callback->bindTo($this, $this);
$callback1();
}
}
$app = new APP();
$app->get(function() use ($app) {//作为自己的匿名函数
echo ‘<pre>‘;
var_dump($app);
echo ‘<br />‘;
var_dump($this);
});
?>
参考资料
就是字面上的意思。。。
优化了数组的时候的性能,当返回值是array的时候速度得到了提升。
参考资料
- http://www.laruence.com/2011/11/04/2258.html
- http://grokbase.com/t/php/php-internals/11aeyhp2ek/ternary-operator-performance-improvements
- http://php.net/manual/en/language.operators.comparison.php
当配置文件 php.ini 中的 docref_root 的值为空的时候,更改了 docref links 指向的链接。
也就是对默认的指向的错误提醒的页面连接进行了修改.
修改默认值不属于很重要的功能,对于这种更新对项目来说不是特别的重要。
新的错误信息格式包含了对应的参考页面,该页面对错误进行具体描述,或者描述了导致该错误发生的函数。为了提供手册的页面,你可以在PHP官方站点下载对应语言的手册,并在ini中设置网址到本地对应的地址。如果你的本地手册拷贝可以使用”/manual/” 访问,你就可以简单的设置 docref_root=/manual/。另外你还需要设置 docref_ext 匹配你本地文件的后缀名 docref_ext=.html。当然也可以设置一个外部的参考地址。例如你可以设置 docref_root=http://manual/en/ 或者 docref_root=”http://landonize.it/?how=url&theme=classic&filter=Landon &url=http%3A%2F%2Fwww.php.net%2F”
通常需要在 docref_root 后面以 “/”结尾, 但是在以上的第二种示例情况中不必这么设置。
Note:
因为这么做可以快速定位和查看到函数的说明,所以它对你的开发会非常有用。建议永远不要再生产系统中使用 (例如系统被连接到互联网对外提供服务)。
参考资料
木有看明白。。。。
参考资料
默认设置是UTF-8.
PHP always outputs a character encoding by default in the Content-type: header. To disable sending of the charset, simply set it to be empty.
有趣的是这次发现了国内的工程师的提交的bug~
参考资料
当给一个对象加入一个属性的时候,扔掉null或者false会返回一个警告
参考资料
windows CRT
Visual Studio 2012 更新 1 支持的 Windows 8,Windows Server 2012,Windows 7,Windows Server 2008中,Windows Vista,Windows XP Service Pack 3 (SP3) C 运行库,x86 的 Windows XP Service Pack 2 (SP2) x64 和 Windows Server 2003 Service Pack 2 (SP2) x86 和 x64 的。 所有这些操作系统支持 Windows 应用程序编程接口 (API) (API) 提供和 Unicode 支持。 此外,所有 Win32 应用程序中使用多字节字符集 (MBCS)。
This directive shows the Windows CRT warnings when enabled. These warnings were displayed by default until PHP 5.4.0.
This directive shows the Windows CRT warnings when enabled. These warnings were displayed by default until PHP 5.4.0.
参考资料
上面提到过这个版本支持了直接的二进制的输出,所以这条就是修复返回二进制转换的浮点数的错误。
Test script:
---------------
<?php
var_dump(0b1111111);
var_dump(0b1111111111111111);
Expected result:
----------------
int(127)
int(65535)
Actual result:
--------------
int(127)
float(65535)
参考资料
原文
zend_function.pass_rest_by_reference
by ZEND_ACC_PASS_REST_BY_REFERENCE
in zend_function.fn_flags.zend_function.return_reference
by ZEND_ACC_RETURN_REFERENCE
in zend_function.fn_flags.zend_arg_info.required_num_args
as it was only needed for internal functions. Now the first arg_info for internal functions (which has special meaning) is represented by zend_internal_function_info
structure.zend_op_array.size
, size_var
, size_literal
, current_brk_cont
, backpatch_count into CG(context
) as they are used only during compilation.zend_op_array.start_op
into EG(start_op
) as it’s used only for ‘interactive’ execution of single top-level op-array.zend_op_array.done_pass_two
by ZEND_ACC_DONE_PASS_TWO
in zend_op_array.fn_flags
. zend_class_entry.constants_updated
by ZEND_ACC_CONSTANTS_UPDATED
in zend_class_entry.ce_flags
.zend_class_entry
by sharing the same memory space by different information for internal and user classes. See zend_class_entry.info
union.翻译
改进的解析错误消息。
通过更换zend_function.pass_rest_by_reference zend_acc_pass_rest_by_reference在zend_function.fn_flags。
通过更换zend_function.return_reference zend_acc_return_reference在zend_function.fn_flags。
删除zend_arg_info.required_num_args因为这只是内部功能的需要。现在内部功能的第一arg_info(具有特殊意义的zend_internal_function_info结构表示)。
移动zend_op_array.size,size_var,size_literal,current_brk_cont,backpatch_count为CG(上下文)作为他们在编译过程中只使用。
移动zend_op_array.start_op成如(start_op)它只用于“单顶级运算阵列交互执行。
通过更换zend_op_array.done_pass_two zend_acc_done_pass_two在zend_op_array.fn_flags。
op_array.vars阵列在pass_two修剪(重新分配)。
通过更换zend_class_entry.constants_updated zend_acc_constants_updated在zend_class_entry.ce_flags。
减少zend_class_entry大小由内部和用户类不同信息共享相同的内存空间。看到zend_class_entry.info联盟。
temp_variable缩小。
这部分的说明是关于zend引擎相关的,按目前我的水平还不是能很明白的理解这些的含义。
原文
$GLOBALS
into a JIT autoglobal, so it’s initialized only if used. (this may affect opcode caches!)$str[1][0]
is now a legal construct.ZEND_RECV
now always has IS_CV
as its result.ZEND_CATCH
has to be used only with constant class names.ZEND_FETCH_DIM_?
may fetch array and dimension operands in different order.ZEND_FETCH_*_R
operations. They can’t be used with the EXT_TYPE_UNUSED
flag any more. This is a very rare and useless case. ZEND_FREE
might be required after them instead.ZEND_RETURN
into two new instructions ZEND_RETURN
and ZEND_RETURN_BY_REF
.ZEND_FETCH_*
instruction without previous ZEND_FETCH_CLASS
.翻译
内联最可能的代码路径,直接进入执行算术运算。
消除不必要的迭代请求启动/关机时。
改变成一个JIT autoglobal =美元,所以它的初始化,如果使用。(这可能会影响操作码缓存!)
改进的性能”(沉默)算子。
简化的字符串偏移阅读。$str [ 1 ] [ 0 ]现在的法律构建。
消除重复的运行时绑定的功能,添加缓存类,常量,方法和属性。
拘留字符串添加的概念。所有字符串常量在编译时被分配在一个单拷贝,永远都不会改变的。
zend_recv现在总是is_cv作为结果。
zend_catch现在只需要进行不断的类名称。
zend_fetch_dim_?可以把不同排列和尺寸数。
简化zend_fetch_ * _r操作。他们不能用任何ext_type_unused旗。这是一个非常难得的和无用的情况下。- zend_free可能在他们的要求。
zend_return分裂为两个新的指令zend_return和zend_return_by_ref。
优化访问全局常量使用的值与预先计算的hash_values从文字表。
优化访问静态属性用遗嘱执行人专业化。一个恒定的类的名称可以作为直接操作数指令没有以前的zend_fetch_class zend_fetch_ *。
zend_stack和zend_ptr_stack分配延迟到实际使用。
改进的Zend引擎,性能调整和优化
机翻好渣。。。。。等我长发及腰,再来看这个可好QAQ
原文
Fixed bug #43200 (Interface implementation / inheritence not possible in abstract classes).
翻译
增加了一个优化,节省内存和emalloc /饱和需要空表。
新增能力重置用户操作处理程序。
改变了op_array.opcodes结构。该常数的值是从操作码操作数为一个单独的文字表。
固定(禁用)为zend_overloaded_function方法内联缓存。
固定的错误# 43200(接口的实现/继承抽象类不可能)。
zend引擎作为底层,还是需要我理解更深入再去看啦~
PHP作为流行的脚本语言,上手非常快,但是这并不代表这个一个糟糕的语言,从这个版本的更新记录,我也看到了每次的改进,以及社区内大家的努力。
这次做ChangeLog的整理大概会写三个文章共六篇,由于这个Log实在是太长了还是写一半先发出去比较好~
引用的资料在每个小结后面都有,方便自己和大家查阅。
如果发现描述错误,请务必评论或者私信我,如果有错,发现了就不能再错下去~
我们依靠网络,每天在接触着很多的新闻和资料,对我们来讲,从这些里面找出有用的知识并吸收还是有一定难度的,特别是国内糟糕的博客环境,一个文章发布出来之后会有好多网站抄袭抓取,内容还不全,对于初学者会造成负面影响,且珍惜。
当有一个大目标的时候,才可以转化成小目标进行执行。
执行力永远放在第一位。
原文:http://blog.csdn.net/diandianxiyu_geek/article/details/46012193