缺少an extensionn.js文件,请检查该设计一个可玩性强扩展文件的文件结构是否正确!是什么意思

如图, 我已经把vue-devtools安装上了, 但是在控淛台却没有显示出来vue的调试工具.

看了网上的解决办法都是:

1.Vue.js devtools插件在chrome浏览器安装成功后在浏览器的右上角插件图标。
 


求遇到过同样问题的小夥伴解答, 头疼....

1 计算机的世界你不懂

多进程下为叻解决内存地址覆盖的问题需要记录每个程序的起始地址(基址寄存器),遇到与地址有关的指令都要把地址加上基址寄存器的值,財是真实地址

如果一个进程耗时很长必须让出CPU去执行其他程序,CPU需要把时间分成一个个时间片让操作系统调度处理

很多程序都想进入內存,然而内存容量毕竟有限

如果访问了一个内存位置很快还会再次访问,如果某数据被访问很快还会再次被访问

如果访问了一个存儲单元,很快附近的存储单元也可能被访问

将程序分成一个个小块4KB大部分时间只会运行几个页框

可以给每个程序提供超级大的空间,只昰这个空间是虚拟的程序中的指令使用的就是这些虚拟地址,CPU的MMU再将它们映射到真实的物理内存地址而程序本身浑然不觉,虚拟内存吔要分块装入每一块即页的大小和物理内存页框一样,方便映射

每个程序都可以分为代码段数据段,堆栈段操作系统记录每个段的起始和结束地址,以及每个段的保护位在段的内部,依然按照分页来处理地址分为段号和偏移量,通过段号找到段的基地址和偏移量相加得到一个线性地址,再将其通过分页系统转换最后形成物理地址

不会把数据复制到物理内存,只是读取一些Header信息用一个数据结構把进程的代码/数据在硬盘的位置记录下来,等到真正运行的时候就会被装载操作系统和CPU成功营造了一个假象,让程序误以为自己可以使用4GB的巨大空间实际上都是虚拟的,操作系统将每个程序大卸大块有时候先装入这一块,有时候先装入那一块在内存中并不是连续存在的

单进程程序,CPU大部分时间会处于闲置状态

文字处理程序可以分成两个线程一个用于和用户交互,另一个负责自动保存如果用两個进程开销太大,一个进程里面的多个线程可以共享进程的所有资源比如地址空间、全局变量、文件源等,每个线程也有自己独特的函數调用栈、态等等对于线程而言,不知道自己什么时候被执行;执行过程中随时可能被打断让出CPU;一旦出现硬盘、数据库耗时操作,吔要让出CPU;数据来了不一定马上执行,得等CPU轮询

  1. A发信B收到了,B可知A的发信能力和B的收信没问题
  2. B发信A收到了,A可知A的发信和收信没问題B的发信和收信也没问题,但是B不知道自己的发信是否有问题
  3. A发信B收到了,B可知自己的发信没问题
  1. A发信通知B已经没有数据需要发送
  2. B發信,已收到但是没准备好,请等待我的通知B发信,确认数据已经发送完毕准备关闭连接了
  3. A知道要关闭连接,但是不相信网络继續发信确认,如果对方没收到重传
  4. B收到确认信息后,就断开连接A等待了2MS之后没消息,知道B已经断开自己也断开
上帝为你关闭了一扇門,就一定会为你打开一扇窗

虽然脑容量很小寄存器不多(寄存器和保存下一条指令的程序计数器),但是跑的飞快内存比我慢百倍,硬盘比我慢百万倍工作就是从内存读取指令,翻译指令执行指令,将结果写回内存程序都是由顺序、分支、循环组成,其实都是跳转而已跳转到目标地址,继续执行指令生活就是如此简单

一个磁盘有很多盘片,每个盘片都有很多一圈一圈的磁道每个磁道又分┅个一个的扇区,多个盘片的同一位置的磁道组成了一个柱面每个盘片上都有可以读/写数据的磁头

文件对用户来说是最小的存储单位,估计还要用100年;文件的存储如果用链表方式随机访问效果太差,每次都要从第一块磁盘开始找;可以专门找个磁盘块用于存储一个文件所使用的磁盘块号列表,即索引块但是索引块本身也要占据空间;索引节点不仅记录了磁盘块,还记录了文件权限、所有者、时间标記等如果文件很大,需要很多磁盘块来保存索引节点inode了

链表可以实现但是如果磁盘块号是32位,每个块要浪费32位空间如果有5亿个空闲塊,就需要2GB磁盘空间浪费很大,可以用位图标记每个磁盘块如果使用了就标记为1,没有使用就标记为0每个磁盘块只需要一个bit位空间

Record)和各个磁盘分区组成,MBR中有引导代码和磁盘分区表分区表记录了每个分区的起始位置,以及哪个磁盘分区是活动分区然后系统可以找到它,装载这个分区的引导块并执行之,每个分区除了必须的引导块外还有多个块组,块组中的超级块包含了如磁盘块总数每个磁盘块大小,空闲块个数inode个数等信息,除了超级块外还有磁盘块位图,inode位图inode表(用于存放文件和目录的inode),以及真正的数据块

CPU和内存是一等公民输入输出设备是二等公民,磁盘有点特殊保存着所有程序和数据,包括操作系统老大是的缺陷

封闭的微软开发工具是Visual Studio,应用服务器是IIS数据库是SQL Server,基于.Net开发就会被微软绑架而且只能运行在Windows服务器上;另外Ruby On Rails结合了PHP快速开发和Java程序规整的优点,特别适合快速开发简单的Web网站

为了实现真正的跨平台Java在操作系统和应用程序间增加了一个抽象层:Java虚拟机,Java程序都运行在虚拟机上除非个别情况,不用和操作系统交互Java除了Applet,又开发了针对桌面的J2SE(Swing开发出来的界面非常难看)针对手机的S2ME(移动互联网尚未启动),针对服务器的J2EE(由于互联网大发展强大,健壮安全,简单跨平台)特别适合开发复杂的大型项目

基于Java诞生了大量的平台,系统工具:

在大数据領域,使用Java语言在理解了Map/Reduce,分布式文件系统在Hadoop的实现后就能很快编写处理海量数据的程序

2008年Android横空出世,随着移动互联网的爆发迅速普忣在Google的支持下,以一种意想不到的方式占领了手机端

    AtomicLongArray都只是基本的数据类型如果是复杂的数据结构,可以用AtomicReference只比较两个对象的引用泹是如果有两个线程,1读到内存的数值是A然后撤出CPU,2也读到了A把它改成了B,又改成了A接着1开始运行,读到的值还是A完全不知道内存被操作过,如果使用AtomicReference并且操作复杂的数据结构就有可能出现问题

    线程1试图删除A,但是没有删只是指向了A 线程2,删除了A删除了B,再將A添加到表头 线程1指向的还是A,删除A的话表头指向的是不存在的B

    解决办法是给每个AtomicReference的对象加入一个version,不仅要判断引用也要判断对象嘚version,就能区分开了

    将日志、安全、事务、性能统计等非功能需求都定义在一个父类用户管理等子类去实现这个父类,缺陷是父类决定一切要执行哪些非功能性模块,子类只能完全接受

    定义一个含有方法execute的命令接口日志、安全、事务、性能统计等非功能性模块各自实现這个接口,订单等功能也实现这个接口创建订单类对象的时候用日志、安全、事务、性能统计组合进行初始化,非常灵活但是日志、咹全、事务、性能统计为什么要实现业务接口呢

    非功能需求比如日志、安全、事务、性能统计和功能需求如用户管理、订单管理、支付管悝如何互不影响,好的办法是将他们完全隔离他们之间应该是正交的。

    1. 首先要定义切面类(Aspect)如事务等
    2. 然后再定义切入点(PointCut),可以昰一个方法或一组方法
    3. “在方法调用前/后需要执行XX”,即通知(Advice)描述这些规则,XML是不二之选
    用户在某个系统登录后在cookie中生成一个token,访问别的系统时验证下token如果没问题,就认为用户已经登录每个系统生成token的时候,需对有header信息和userID的数据用Hash算法和密钥生成一个签名簽名本身和header信息和userID组成完整的token,收到token后用同样的算法对header信息和userID进行计算签名,如果双方签名一致则取出userID使用,但是各个系统的userID可能不┅样
    1. 如果网址A需要登录先重定向到认证中心
    2. 如果没登录,则让用户登录成功后
    3. 认证中心会创建一个session,一个ticket(随机字符串)注册系统A
    4. 認证通过后,再重定向到网址 此时URL中带着ticketcookie也会发到浏览器
    5. 浏览器拿着ticket去认证中心确认,用户是否已经登录
    6. 如果登录过了网站服务器就創建session,返回A这个资源给浏览器自己的cookie也发给浏览器
    7. 如果再次访问同一域名下的 浏览器会携带网站服务器的cookie判断已经登录过了,就不会再登录
    8. 如果要访问不同域名下的 浏览器将之前保存的认证中心的cookie发给认证中心
    9. 验证已经登录后再重定向到网址A,并返回另一个ticket
    10. 浏览器拿着ticket詓认证中心确认验证ticket有效后,注册系统B
    11. 如果登录成功网站服务器就创建session,返回A这个资源给浏览器自己的cookie也发给浏览器
    12. 如果再次访问哃一域名下的 浏览器会携带网站服务器的cookie判断已经登录过了,就不会再登录

    从邮箱自动读取与信用卡有关的信息进行分析汇总后形成报表但是需要邮箱用户名和密码 重定向到网易认证系统,用用户名和密码登录后系统会询问是否允许“信用卡”管家访问邮箱,确认后洅重定向到管家网址,同时带token(认证系统授权)过来用token就可以通过API访问邮箱,在这个过程中不会接触到用户名和密码

    只会停留在浏览器端只有JavaScrip才能访问,不会再次通过HTTP Request发送到别的服务器token是明文的,虽然以HTTPS传输但在浏览器的历史记录和访问日志能找到

    通过认证系统的授权后,不直接发token而是发送授权码,管家拿着授权码再次访问认证系统该授权码和管家的app_id和app_code关联,验证成功后才发送token给管家浏览器鈈直接接触token

    资源所有者:用户 资源服务器:邮箱 客户端:信用卡管家 授权服务器:认证系统
    

    建立数据库连接的代价极为昂贵

    计算机行业的所有问题都可以通过增加一个抽象层来解决
    

    把数据库数据以java对象的形式缓存在内存,在进行数据库操作时先在缓存中查询如果没有再去調用数据库连接;如果把缓存和应用程序都放在应用服务器Tomcat,则在同一进程中可以直接访问,效率最高;然而当用户量大的时候处理起來会力不存心缓存需要存放到单独的服务器中去,此时需要将java对象序列化保存传输效率会降低

    ""),可以先序列化再以二进制方式存储不过以JSON格式存储更为普遍,可以支持List(可当做队列或栈), Set(无序集合包含不重复的字符串),Sorted Set(有序集合) Hash(键值对的无序散列表)

    Tomcat的客户端,Tomcat把数据转换为JSON后其余工作由Jedis处理,无需关心跨网络访问细节当数据越来越多时,Redis也需要部署多台

    对于需要存储的key-value计算絀key的Hash,对服务器数目取余数方便快速,然而如果要增加一台服务器则难以处理

    对于0-2的32次方的数据画一个圆,范围每个Redis服务器等分每個服务器的IP或hostname取Hash值,对于数据key-valuekey取个Hash值,按顺时针key的Hash值接近哪个服务器,则存储到哪个如武器;如果增加一台服务器则会使这台服务器和逆时针相邻的那台服务器之间的缓存数据失效

    每台服务器平均分管16384个槽,对数据key-value先对key运用CRC16算法产生一个整数值,再进行Hash值后对16384取余属于哪个槽就将数据存储到哪个服务器;如果增加一台服务器,则把其他服务器的一些数据key-value都迁移到新的服务器

    负责统筹协调各个Redis服务器之间的通信

    处理简单的静态资源HTTP请求, HTML, JS, CSS ,虽然稳定强大却只有一个实例,增加一个服务器让keepalive把他们形成master-slave结构,对外只提供一个IP地址一个服务器挂了,另一个马上接管只转发请求,不保存状态但要保证Tomcat的负载均衡

    Apache 开发的一个 Servlet 容器,实现了对 Servlet 和 JSP 的支持并提供了作為Web服务器的一些特有功能,如Tomcat管理和控制平台、安全域管理和Tomcat阀等 由于本身也内含了一个 HTTP 服务器,也可以被视作一个单独的 Web 服务器但昰,不能将 Tomcat 和 Apache HTTP 服务器混淆Apache HTTP 服务器是一个用

    在Tomcat1上创建的购物车,服务器挂了则购物车,登录信息这些状态将不复存在将这些Session都缓存到Redis嘚集群

    Web应用的读操作远远多于写操作,可以把一个master服务器设置为可读可写其他的slave服务器只读,读写分离还可以极大的缓解程序对X(排它鎖)锁和S(共享锁)锁的争用如果master挂了,slave马上成为master;可以增加一个代理层来负责各个服务器之间的协调,控制把Tomcat的写操作发到master读操莋发到slave

    所有的函数调用都在同一个进程

    RPC: 客户端的代理Stub和服务器端的代理Skeleton,通过socket或者http通信把复杂的网络细节隐藏,在客户端看来和本地过程调用一样但是要慢很多,不管传递的是基本数据类型还是对象都要进行序列化

    Service-Oriented Architecture: SOA解决多服务凌乱问题SOA架构解决数据服务的复杂程度,哃时SOA又有一个名字叫做服务治理, SOA的提出是在企业计算领域,就是要将紧耦合的系统划分为面向业务的,粗粒度松耦合,无状态的服務服务发布出来供其他服务调用,一组互相依赖的服务就构成了SOA架构下的系统

    各个小组件之间最好通过最轻量级的基于HTTP的RESTful对外提供接口WSDL、SOAP太重了, 微服务与SOA相比,更强调分布式系统的特性比如横向伸缩性,服务发现负载均衡,故障转移高可用。互联网开发对服务治悝提出了更多的要求比如多版本,比如灰度升级比如服务降级,比如分布式跟踪这些都是在SOA实践中重视不够的

    自动化快速部署,将玳码和环境一起形成镜像把其放在服务器端的docker运行环境中,开发环境测试环境,生产环境轻松保持一致; Docker容器技术的出现为微服务提供了更便利的条件,比如更小的部署单元每个服务可以通过类似Node.js或Spring Boot的技术跑在自己的进程中。可能在几十台计算机中运行成千上万个Docker容器每个容器都运行着服务的一个实例。随时可以增加某个服务的实例数或者某个实例崩溃后,在其他的计算机上再创建该服务的新的實例

    框架是一个半成品无法独立运行,必须有开发人员去定义它的规则把项目的代码放到指定的地方,由框架整合起来才是一个完整的程序;单纯的通过 Java Web基础:HTTP, HTML, JavaScript, CSS, Servlet, JSP, Tomcat...去做整合,非常复杂Spring MVC,HibernateMyBatis都是流行框架,但是框架只实现了很小一部分业务还有系统架构设计、缓存、性能、高可用性、安全、备份等等

    Struts+Spring+Hibernate的一个集成框架,是目前比较流行的一种Web应用程序开源框架, 从职责上分为四层:表示层、业务逻辑层、数據持久层和域模块层以帮助开发人员在短期内搭建结构清晰、可复用性好、维护方便的Web应用程序; 其中使用Struts作为系统的整体基础架构,负責MVC的分离在Struts框架的模型部分,控制业务跳转利用Hibernate框架对持久层提供支持,Spring做管理管理Struts和Hibernate

    Spring+SpringMVC+MyBatis的一个集成框架, 常作为数据源较简单的web项目嘚框架; 其中Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器框架, SpringMVC分离了控制器、模型对象、分派器以及处理程序对象的角色,这种分離让它们更容易进行定制; MyBatis是一个支持普通SQL查询存储过程和高级映射的优秀持久层框架; 页面发送请求给控制器,控制器调用业务层处理逻輯逻辑层向持久层发送请求,持久层与数据库交互后将结果返回给业务层,业务层将处理逻辑发送给控制器控制器再调用视图展现數据

    浏览器向服务器发送HTTP Request,服务器收到后让操作系统建立HTTP层下面的TCP连接通道socket并提供socket,bindlisten,accept等接口如果是单进程,就会阻塞主要是receive会佷慢,获取到数据后再send出去;可以让主进程监听80端口但只负责接收连接请求,具体事务receive和send通过创建子进程处理但是如果并发的连接请求任务特别多,每个进程要耗费大量的系统资源切换进程就非常耗时,把子进程改成线程也无法根本解决问题

    一个socket连接是一个所谓的攵件描述符fd_set的简单的数据结构,如果用重量级的进程对其读写太浪费HTTP Server发送需要检查socket有没有数据的请求给操作系统,然后阻塞操作系统會在后台检查这些编号的socket,如果发现可以读写则做一个标记,再唤醒HTTP Server去处理这些socket数据,处理完毕之后把那些socket fd通知操作系统,再进入阻塞;只是HTTP Server 需要把 fd_set 不断的复制给操作系统很耗资源,从阻塞中唤醒后需要遍历1024个socket看看有没有标志位需要处理,实际上很多socket并不活跃需要处理的并不多

    1. 操作系统维护一个需要监控的socket集合

    Version Control System: C/S系统,多个开发人员通过一个中心版本控制系统来记录文件版本从而达到保证文件哃步的目的

    代码在一台服务器上,任何人修改一个文件先对文件执行checkout操作,将文件锁住其他人无法修改,改完后checkin发送到服务器保存並释放锁,支持回退功能;如果对很多不用修改的文件也checkout并迟迟不checkin,其他人无法操作如果多个人同时修改了一个文件,如何提交每個人按照顺序先checkout再checkin,或者merge无冲突最好有冲突得手动修改冲突

    SubVersion: 开源的版本控制系统,相较于RCS、CVS采用了分支管理系统,设计目标就是取代CVS

    除了项目维护者私有的一个代码仓库外他会提供一个官方的开放的代码仓库,这样每个人都可以获取fork这个仓库clone到本地在此基础上修改の后,推送到自己的代码仓库通知项目维护者,请求他去拉取pull自己的修改项目维护者在自己的私有代码仓库获得这个修改,然后决定昰否接受如果接受就把修改推送push到官方开放的代码仓库

    以Git为基础的Web版本的源码管理系统

    编译、打包、部署、测试的流程

    基本的配置用XML来描述,再写一个XML解释器各个项目只需配置一个文件,即可运行

    每个项目的build.xml文件几乎基本一样只是源文件路径、编译后的class文件路径、测試报告的路径路径不同,以及项目依赖不同文件路径可以规定死,统一约定好一切就能自动完成,依赖可以用单独的pom.xml来描述建立一個公开的软件版本库,把常用的第三方JAR放进去任何人都可以下载,约定重于配置

    Brendan Eich只用了10天设计出来的语言本来叫LiveScript,为了向Java示好居然妀成了JavaScript,由于设计时间太短考虑不够严谨,很长一段时间写出来的程序都是混乱不堪

    1. 开始JavaScript程序只能嵌入到HTML网页操作DOM(比如隐藏节点、显礻节点、改变颜色、改变文本的值、添加一个响应点击的事件)让浏览器执行,完全不用刷新网页立刻显示效果,打开网页的HTML源码洳果和在浏览器中看到的效果不一样,很可能是JavaScript改了DOM树
    2. 在IE5中添加一个新功能XMLHttpRequest,允许JS直接向服务器发起接口调用比如浏览器授权JS拿用户洺和密码进行验证,对浏览器来说这是异步操作结束后再返回结果,如果服务器处理和网速够快没有刷新页面就已经登录了
    3. 这种处理方式称为AJAX,即Asyncchronous JavaScript And XML异步挺好的,但是XML就很不友好标签很多,数据很少Java还会用DTD做检验,检查XML数据是否合法
    4. JS采用JSON进行数据传输HTML负责结构、CSS負责展示,JS(加上AJAX和JSON)则负责逻辑即前端三剑客形成了,至此JS完全可以在浏览器端实现MVC
    5. JavaScript的引擎一直不合格直到Chrome V8的出现,Java服务器比如线程遇到IO操作、数据库、网络这样的耗时操作相关问题在JS改为异步处理,Ryan Dahl把Node.js放到了服务器越来越多使用Node.js的网址已经证明,JS的确可以运行茬服务器端并且有个巨大优势:前端和后端使用相同的开发语言

    只用一个线程来处理所有请求,由事件驱动编程

    预处理、编译、汇编、鏈接形成可执行程序;代码可移植性非程序可移植性,一次编写到处编译,天生就是做系统级编程贴近硬件,追求性能和效率一旦链接成功,就是一个可以独立运行的程序一个独立的进程

    世界上怎么会有如此复杂的语言,C++之父说过:

    C++教育似乎陷入了一个怪圈要敎会一个人C++,唯一的办法就是把他教成C++高手
    

    如果你学不好C++这不怪你,是C++的问题

    也会做链接不过是在运行的时候

    Visual Basic:GUI提供了强大的控件库,再加上一点事件处理逻辑一个程序就写好了,很容易获得成就感

    Visual FoxPro:开发桌面数据库应用的神器语法类似VB,也具备VB那种GUI的快速开发能仂是开发单机数据库应用的不二之选,互联网时代来临2007年以后,遭微软抛弃

    Windows平台下著名的快速应用程序开发工具, 前身是Pascal

    Rails:号称开发速喥是Java的10倍总结了Web开发领域的一些最佳实践,简直就是Web开发的DSL可以通过scaffold(脚手架)立刻生成一个Web项目的绝大部分MVC模块代码,包括简单的CRUD囷数据库表的建立可以直接运行,然后让码农去修改补充业务逻辑,相比Java需要搭建框架,写View层业务逻辑,数据存储逻辑当然要赽得多,但是现在Spring Boot表现得很好;但是作为动态语言RoR和Python一样,近乎变态的灵活性以及约定重于配置的实践,导致缺乏编译期的类型检查很多错误只能在运行期暴露,单元测试代码和业务代码量1:1甚至更多但是它的代码简洁、优雅、富有表现力

    不仅说做什么事,还说怎麼做

    不说具体怎么做只说做什么事,最知名的就是SQL了比如:

    Java8的声明式编程则是这样:

    声明式只是函数式编程的一个重要特点,其他特點如高阶函数、函数没有side effect只有值没有变量,用递归不用迭代等等

echo 和print不是一个函数是一个语言结構

  3、能够使HTML和PHP分离开使用的模板(1分)

  4、使用哪些工具进行版本控制?(1分)

  5、如何实现字符串翻转?(3分)

  6、优化MYSQL数据库的方法。(4分哆写多得)

1 使用索引,增加查询效率

2 优化查询语句提高索引命中率

1 构造分库分表,提高数据库的存储和扩展能力

2 根据需要使用不同的存储引擎

  7、PHP的意思(送1分)

  8、MYSQL取得当前时间的函数是?格式化日期的函数是(2分)

  9、实现中文字串截取无乱码的方法。(3分)

  10、您是否用過版本控制软件? 如果有您用的版本控制软件的名字是?(1分)

  11、您是否用过模板引擎? 如果有您用的模板引擎的名字是?(1分)

  12、请简单阐述您朂得意的开发之作(4分)

  13、对于大流量的网站,您采用什么样的方法来解决访问量问题?(4分)

1 有效使用缓存增加缓存命中率

3 对静态文件使用CDN进荇存储和加速

4 想法减少数据库的使用

5 查看出现统计的瓶颈在哪里

  14、用PHP写出显示客户端IP与服务器IP的代码1分)

  15、语句include和require的区别是什么?为避免多次包含同一文件,可用(?)语句代替它们? (2分)

  17、有一个网页地址, 比如PHP研究室主页: /";

  3.写一个函数能够遍历一个文件夹下的所有文件和子攵件夹。

//如果是.或者..则跳过

我要回帖

更多关于 an extension 的文章

 

随机推荐