dvaspring框架的理解中的app.start('#root')是怎么找到#root的,怎么联系起来的

dva是基于现有应用架构(redux+react-router+redux-saga等)的一层轻量封装,没有引入任何新的概念。一 整个程序的入口文件是根目录下的index.js 文件import dva from 'dva';
from 'dva/router';
import './index.css';
const app = dva();
app.model(require('./models/example'));
app.router(require('./router'));
app.start('#root');dva-cli生成的文件给我们写的注释已经写的很清楚了先初始化,在加载插件,在加载Model,在加载路由,最后启动程序MVVC (1)app.model(obj)namespace : model 的命名空间state: 初始statereducers: 同步的修改状态的操作,由actions触发(state,action) =& stateeffects:异步的操作,并不直接修改state,由action触发,也可以调用actions。(action,{put,call,select})subscriptions:异步的只读操作,并不直接修改state,可以调用actions。({ dispatch, history })put(action)和dispatch(action)这里effects中的put(action)等同于subscriptions中的dispatch(action),它们的作用都是分发一个action。yield put({ type: actionType, payload: attachedData, error: errorIfHave});
dispatch({ type: actionType, payload: attachedData, error: errorIfHave});call(asyncFunction)调用一个异步函数const result = yield call(api.fetch, { page: 1 });select(function)从全局状态中选择数据const count = yield select(state =& state.count);(2)app.router(({ history }) =& routes)import { Router, Route } from 'dva/routes';
app.router(({ history } =& ({
&Router history={ history }&
&Route path="/" component={App} /&
没有更多推荐了,在我的频道里,你能看到关于suna的一切动态:ASMR、直播、电视节目,日常直播,文字动态。一切关于suna!投稿:1560粉丝:3.0万分享--dynmicweibozoneqqbaidu将视频贴到博客或论坛视频地址复制嵌入代码复制微信扫一扫分享收藏0硬币--稍后看马克一下~用手机看转移阵地~用或其他应用扫描二维码手机下视频请使用扫码若未安装客户端,可直接扫此码下载应用看过该视频的还喜欢正在加载...miniOFF2111 条评论分享收藏感谢收起赞同 307 条评论分享收藏感谢收起PHP源码分析-变量的引用计数、写时复制(Reference counting & Copy-on-Write)
PHP语法中有两种赋值方式:引用赋值、非引用赋值。&?php $a = 1; $b = $a; // 非引用赋值 $c = &$b; // 引用赋值&?php $a = 1; $b = $a; // 非引用赋值 $c = &$b; // 引用赋值从表面看...
语法中有两种赋值方式:引用赋值、非引用赋值。
$b = $a; // 非引用赋值
$c = &$b; // 引用赋值
$b = $a; // 非引用赋值
$c = &$b; // 引用赋值
从表面看,通常会这样认为:“引用赋值就是两个变量对应同一个变量(在C中其实就是一个zval),非引用赋值则是直接产生的一个新的变量(zval),同时将值copy过来”。
这种认为在大部分情况下都是可以想通的。(#1)
但有些情况下则会显得非常低效,例如:(#2)
function print_arr($arr){//非引用传递
print_r($arr);
$test_arr = array(
'a' =&
'a',
'b' =&
'b',
'c' =&
'c',
);//这里一个比较大的数组
print_arr($test_arr);//第一次调用print_arr函数执行输出
print_arr($test_arr);//第二次调用print_arr函数执行输出
function print_arr($arr){//非引用传递
print_r($arr);
$test_arr = array(
'a'
'a',
'b'
'b',
'c'
'c',
);//这里一个比较大的数组
print_arr($test_arr);//第一次调用print_arr函数执行输出
print_arr($test_arr);//第二次调用print_arr函数执行输出
如果按照上面的理解方式(#1),那么执行两次print_arr,并且是非引用的方式,则会产生两个与$test_arr完全相同的新的变量,那么将是非常低效的。
实际代码在运行中,并不会产生两个新的变量。因为PHP内核中已经帮助我们进行了优化。
具体如何实现的呢?这里就要讲到本文的要点:Reference counting & Copy-on-Write,正是采用引用计数、写时复制这两个机制得以优化。
在介绍这两个机制前,先了解一个基本知识:PHP中的变量在内核中是如何表示的。
PHP中定义的变量都是以一个zval来表示的,zval的定义在Zend/zend.h中定义:
typedef struct _zval_
typedef union _zvalue_value {
/* long value */
/* double value */
HashTable *
/* hash table value */
zend_object_
struct _zval_struct {
/* Variable information */
/* value */
/* active type */
zend_uchar is_
typedef struct _zval_
typedef union _zvalue_value {
/* long value */
/* double value */
HashTable *
/* hash table value */
zend_object_
struct _zval_struct {
/* Variable information */
/* value */
/* active type */
zend_uchar is_
其中,refcount和is_ref就是实现引用计数、写时复制这两个机制的基础。
refcount当前变量存储引用计数,在zval初始创建的时候就为1。每增加一个引用,则refcount ++。当进行引用分离时,refcount--。
is_ref用于表示一个zval是否是引用状态。zval初始化的情况下会是0,表示不是引用。
$a;//a:refcount=1,is_ref=0, value=NULL;
$a = 1; //a:refcount=2,is_ref=0, value=1;
//a,b:refcount=3,is_ref=0,value=1;
//a,b,c:refcount=4,is_ref=0,value=1;
$d = &$c; //a,b:refcount=3,is_ref=0,value=1;
c,d:refcount=1, is_ref=1, value=1
$a;//a:refcount=1,is_ref=0, value=NULL;
//a:refcount=2,is_ref=0, value=1;
//a,b:refcount=3,is_ref=0,value=1;
//a,b,c:refcount=4,is_ref=0,value=1;
$d = &$c; //a,b:refcount=3,is_ref=0,value=1;
c,d:refcount=1, is_ref=1, value=1上面代码的注释,表示当执行这一行后,refcount与is_ref的变化.
Copy on Write
Php变量通过引用计数实现变量共享数据,那如果改变其中一个变量值呢?
当试图写入一个变量时,Zend若发现该变量指向的zval被多个变量共享,则为其复制一份ref_count为1的zval,并递减原zval的refcount,这个过程称为“zval分离”。可见,只有在有写操作发生时zend才进行拷贝操作,因此也叫copy-on-write(写时拷贝)
对于引用型变量,其要求和非引用型相反,引用赋值的变量间必须是捆绑的,修改一个变量就修改了所有捆绑变量。
$b=$a;执行过程中的内存结构图:
$b=&a;执行过程中的内存结构图:
从上可以看到,无论是引用、非引用,这种直接赋值都不会产生新的变量。
只是当是引用时,is_ref设置为1。当非引用时,is_ref设置为0。
读写复制,就是根据is_ref来进行变量分离的。
当is_ref=1时,是引用变量时,执行“引用下的变量分离”
$c = &$b;执行过程中的内存结构图:
当is_ref=0时,是非引用变量时,执行“非引用下的变量分离”
执行过程中的内存结构图:
只有真正在需要改变变量的值时,
回头在看(#2)代码,可以看到实际上,并没有产生新的变量,始终是$test_arr的变量在输出。所以,这也是为什么很少看到在PHP中使用引用方式传递变量,却仍然不会有性能问题的原因。
摘自 God's blog
红黑联盟&版权所有
Copyright&& 2017
All rights reserved.Cordys 专栏
dva -react TypeError: root.findRouters(...).getRouterInfo is not a function
异常修改, 抛异常
C:\Users\thinkpad\AppData\Roaming\npm\node_modules\dva-cli\bin\dva-generate
routeComponent src/routes/Users.js, src/routes/Users.css
TypeError: root.findRouters(...).getRouterInfo is not a function
at transform (C:\Users\thinkpad\AppData\Roaming\npm\node_modules\dva-cli\nod
e_modules\dva-ast\lib\transform.js:42:32)
at exports.default (C:\Users\thinkpad\AppData\Roaming\npm\node_modules\dva-c
li\node_modules\dva-ast\lib\api\index.js:46:36)
at C:\Users\thinkpad\AppData\Roaming\npm\node_modules\dva-cli\lib\generate.j
at generate (C:\Users\thinkpad\AppData\Roaming\npm\node_modules\dva-cli\lib\
generate.js:108:11)
at Object.&anonymous& (C:\Users\thinkpad\AppData\Roaming\npm\node_modules\dv
a-cli\bin\dva-generate:11:27)
at Module._compile (module.js:570:32)
at Object.Module._extensions..js (module.js:579:10)
at Module.load (module.js:487:32)
at tryModuleLoad (module.js:446:12)
at Function.Module._load (module.js:438:3)
解决方法如下:
Collection 是 jscodeshift 库提供的,dva-ast 的 package.json 指定 "jscodeshift":
"^0.3.28" ,但 jscodeshift 最新版本是 0.3.32 ,这里 Bug 就出现了。
虽然我发现了问题根源,但 dva-ast 和 jscodeshift 这两个库的源代码看得我云里雾里,望而生畏,杀虫的工作还是等高手吧。
我目前的解决方法是,将全局安装的 jscodeshift 回滚至 0.3.28 ,初入江湖的我,人生还可以继续么?
Roll your global package jscodeshift back to v0.3.28 .
没有更多推荐了,

我要回帖

更多关于 什么是spring框架 的文章

 

随机推荐