- GCD如何多个异步任务,最后返回的时候同步执行
Adam_潜
用信号量+group算是进阶应用https://www.jianshu.com/p/24ffa819379c
- GCD与NSOperation
8fe8946fa366
1.简单区别GCD是纯C语言的API,而NSOperation是oc对象,NSOperation的底层是用GCD来实现的。GCD中用block块来包装任务,而在NSOperation里用NSOperation对象来包装任务。NSOperation里也有队列的概念,就是NSOperationQueue,可以用block的方式把任务添加到队列里,addOperationWithBlock:NSOper
- OneCode3.0 MCPServer:注解驱动的AI原生服务架构与实践
引言:从技术架构到业务价值在前面的章节中,我们详细阐述了OneCode3.0如何通过MCPServer微内核架构实现"软件即AI"的技术理念。本章将通过智能送货单系统的完整案例,展示MCPServer注解驱动架构在实际业务场景中的落地实践,重点介绍如何通过@AIGCDelivery等业务注解与MCPServer核心注解协同工作,实现供应链场景下的AI能力编织。MCPServer注解体系的业务扩展M
- Codeforces Round 1000 (Div. 2) A-C
关于SPFA它死了
Codeforces算法c++
链接:CodeforcesRound1000(Div.2)A:MinimalCoprime大意:给定一个区间,定义最小互质区间是边界互质,边界内无互质区间。求这个区间最小互质区间个数思路:gcd(l,l+1)=gcd(1,l)=1,即相邻数组成的区间互质,那么一段区间的互质区间数就为R-L,还有个一般情况,就是gcd(1,1)=1,即1自己单独有个最小互质区间所以对于左边界为1的情况,如果右边界为
- HDU 4628 Pieces (状压DP+记忆化搜索)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4628#includeusingnamespacestd;#definedebugputs("YES");#definerep(x,y,z)for(int(x)=(y);(x)>=1,x=x*x%mod)if(y&1)t=t*x%mod;returnt;}llgcd(llx,lly){returny?g
- 【iOS】锁[特殊字符]
文章目录前言1️⃣什么是锁?1.1基本概念1.2锁的分类2️⃣OC中的常用锁2.1OSSpinLock(已弃用):“自旋锁”的经典代表为什么尽量在开发中不使用自旋锁自旋锁的本质缺陷:忙等待(BusyWaiting)os_unfair_lock的局限性:不适用于复杂场景苹果的官方建议:优先使用更高效的锁2.2dispatch_semaphore_t(GCD信号量):“高性能通用锁”2.3pthrea
- cf1925B&C
B.https://codeforces.com/contest/1925/problem/B题目背景:将x划分为n个数,使x个数字之间有最大的gcd。数据范围:1#defineiosccios::sync_with_stdio(false),cin.tie(0),cout.tie(0)#defineendl'\n'#defineme(a,x)memset(a,x,sizeofa)#definea
- C++ 标准库 <numeric>
以下对C++标准库中头文件所提供的数值算法与工具做一次系统、深入的梳理,包括算法功能、示例代码、复杂度分析及实践建议。一、概述中定义了一组对数值序列进行累加、内积、差分、扫描等操作的算法,以及部分辅助工具(如std::iota、std::gcd/std::lcm等)。所有算法均作用于迭代器区间,符合STL风格,可与任意容器或原始数组配合使用。从C++17、20起,又陆续加入了并行友好的std::r
- Swift 6.2 并发江湖:两大神功破局旧制,代码运行经脉革新(下)
大熊猫侯佩
Apple开发入门Swift6.2WWDC25并发async/awaitnonisolatednonsendingconcurrent
楔子江湖风云变幻,Swift武林近日再掀波澜。传闻Apple于密室推演三月,终得《Swift6.2并发新篇》,扬言要破解困扰开发者多年的“经脉错乱”之症——那便是异步函数与同步函数运行规则不一、主Actor调用常生冲突之陈年旧疾。想当年,多少英雄好汉折戟于GCD到Swift并发的转型之路:明明是同门函数,同步者循调用者经脉而行,异步者却偏要另辟蹊径,轻则编译器怒目相向,重则数据走火入魔。如今6.2
- Codeforces Round 1027 (Div. 3)
ABCDE略F记忆化搜索。首先让x和y除去他们的的gcd,此时xy互质。x经历除去所有它的约数到1,而y从1乘它所有的约数到y。本质一样。设f[x]表示x最少除以几个满足题意的数到1。这时一定有f[x]=min(f[x],f[x/y]+1)(y为x的约数且yusingnamespacestd;//#defineintlonglong#defineendl'\n'constintN=1e6+5;in
- 好记性不如烂笔头--使用dotnet-gcdump分析.net core程序内存泄漏
学无止境Coding
性能分析工具C#.net.net.netcorebugvisualstudiowindows
系列文章目录第一章使用ANTSMemoryProfiler排查.net内存泄漏问题https://blog.csdn.net/pdsazj/article/details/128259980第二章使用dotnet-gcdump分析内存泄漏目录前言一、dotnet-gcdump是什么?二、使用步骤1.安装命令2.使用3.分析数据a.使用VisualStudio对单个gcdump文件进行分析b.使用V
- Codeforces Round 1034 (Div. 3) G解题思路
拉长时间线
数据结构与算法算法数据结构c++
链接Problem-G-Codeforces题目大意给定n,m,q分别为数组大小,数组的每个数非负且小于m,要进行q次操作操作分为两种:1.令a[i]=x(永久性)2.输入一个k,对于每个a[i]都可进行任意次操作a[i]=(a[i]+k)%m,对数组进行操作,判断能否增厚变成一个非严格递增数组题目思路对样例进行分析可以发现对于每个a[i]可以分为g=gcd(m,k)类,可以为每一类标号,号码为a
- 《二分枚举答案(配合数据结构)》题集
英雄哪里出来
数据结构图论英雄算法联盟算法
文章目录1、模板题集2、课内题集3、课后题集1.字符串哈希2.并查集3.ST表1、模板题集分巧克力2、课内题集倒水冶炼金属连续子序列的个数3、课后题集括号内的整数代表完整代码行数。1.字符串哈希你猜猜是啥题(60)2.并查集拯救萌萌(72)3.ST表GCD不小于K的子数组(111) 本题集为作者(英雄哪里出来)在抖音的独家课程《英雄C++入门到精通》、《英雄C语言入门到精通》、《英雄Python
- ubuntu 22.04 ssh开启root用户远程登录
allix123
ubuntussh服务器
1.进入ubuntu系统后,切换成root用户sudosu输入密码,切换成功之后。修改root的密码passwdroot输入新密码2.用vim工具修改sshd_configcd /etc/sshvimsshd_config找到#PermitRootLoginprohibit-password修改为:PermitRootLoginyes保存文件3.重启sshd服务servicesshdrestart
- C语言:最大公约数
C羊驼
C语言学习c语言算法开发语言
最大公约数(GCD)是指能够同时整除两个或多个整数的最大正整数。给定两个整数aa和bb(不同时为0),它们的最大公约数gcd(a,b)gcd(a,b)是满足以下条件的最大正整数dd:dd能整除aa(即amod d=0amodd=0)。dd能整除bb(即bmod d=0bmodd=0)。对于任何其他满足前两个条件的d′d′,有d′≤dd′≤d。1.辗转相除法(欧几里得算法)原理:gcd(a,b
- 扩展欧几里德算法 递归法 递推法 手算法 原理及实现
黎哩吖
算法人工智能机器学习
扩展欧几里德算法递归法递推法手算法原理及实现顾名思义,扩展欧几里德算法是在欧几里德算法基础上扩展的算法.欧几里德算法和扩展欧几里德算法在用途上的区别:欧几里德算法(gcd):即求两个整数的最大公约数.扩展欧几里德算法:用于求乘法逆元.用于求贝组等式的一个解.欧几里德算法即辗转相除法.C语言实现:intgcd(inta,intb){returnb==0?a:gcd(b,a%b);}注意此算法的终止条
- 手算逆元及手动模拟扩展欧几里得算法及思路推导
一上午的一个小推导先给出exgcd的代码吧intexgcd(inta,intb,int&x,int&y){///x,y起初不知道,是递归往上求解x,yif(b==0){x=1,y=0;returna;///两处return}intd=exgcd(b,a%b,x,y);inttmp=x;x=y,y=tmp-(a/b)*y;returnd;///记得要返回d啊///【a*x+b*y=1中,x是a在模b
- 扩展欧几里得算法&乘法逆元
GZkx
数论之旅简单题乘法逆元
扩展欧几里得算法——exgcd主要有两个重要的用途:1.求乘法逆元(下面的例题就是)a*b%mod==1->a与b互为在mod意义下的逆元2.求二元一次线性方程exgcd(a,b,x,y)即为a,b的最大公约数,,令gcd(a,b)=a*x+b*y,则x,y也可以得出来了不懂gcd(最大公约数)的童鞋可以先了解一下哦Description给出2个数M和N(M#include#includeusin
- 欧几里得算法与扩展算法
欧几里得算法(EuclideanAlgorithm)欧几里得算法(也称为辗转相除法)是一种查找两个正整数aaa和bbb的最大公约数的方法。最大公约数(GCD-GreatestCommonDivisor),另一个名字是HCF(HighestCommonFactor)。例子1:令a=210a=210a=210,b=45b=45b=45210‾=45‾∗4+30‾45‾=30‾∗1+15‾30‾=15‾
- 15国B组C++蓝桥杯真题
KuaCpp
蓝桥杯职场和发展
P10907[蓝桥杯2024国B]蚂蚁开会#includeusingnamespacestd;typedeflonglongll;constintN=520;intux[N],uy[N],vx[N],vy[N];map,int>mp;intgcd(inta,intb){if(b==0)returna;returngcd(b,a%b);}voidsolve(inti){intdx=vx[i]-ux[
- [蓝桥杯 2024 国 Java B] 美丽区间
N_NAN_N
java算法
问题描述美丽区间是这样的一组区间:[L1,R1]、[L2,R2]、[L3,R3]..构造美丽区间需要满足以下条件:L1=1Li≤RiRi−Li≥K对于任意的i>1,有Li=Ri−1+1gcd(Li,Ri)=1,其中gcd指两个数的最大公约数在满足上述条件的情况下,Li、Ri之间的差尽可能的小。输入格式第一行输入一个整数K。第二行输入一个整数T,表示有T组测试用例。接下来T行,每行输入一个整数n。输
- Leetcode 3574. Maximize Subarray GCD Score
Espresso Macchiato
leetcode笔记leetcode3574leetcodehard最大公约数动态规划
Leetcode3574.MaximizeSubarrayGCDScore1.解题思路2.代码实现题目链接:3574.MaximizeSubarrayGCDScore1.解题思路这一题是基于deepseek的实现上面搞定的,虽然deepseek事实上也是超时……我的直接思路就是动态规划,但是那样是会直接超时的,而deepseek的解决方式是首先找出所有可能的最大公约数,然后考察其对应的score,
- 算法-数论
cx_2023
算法c++开发语言
C-小红的数组查询(二)_牛客周赛Round95思路:不难看出a数组是有循环的d=3,p=4时,a数组:1、0、3、2、1、0、3、2.......最小循环节为4,即最多4种不同的数d=4,p=6时,a数组:1、5、3、1、5、3.......最小循环节为3d=4,p=10时,a数组:1、5、9、3、7、1、5、9、3、7.......最小循环节为5可以得出,最小循环节T=p/gcd(d,p)an
- Codeforces Round #509 (Div. 2) 题解
Tawn0000
CodeforcesRound#509(Div.2)
题目传送门A.Heist水题,扫一遍然后记录最大值和最小值,ans=max-min+1-n;#includeusingnamespacestd;intmain(){intn;scanf("%d",&n);intmaxa=0,mina=0x3f3f3f3f;for(inti=0;iusingnamespacestd;typedeflonglongLL;LLgcd(LLa,LLb){returnb==
- Codeforces Round 1023 (Div. 2) (A-D)
Null_Resot
题解系列深度优先算法蓝桥杯学习c++
每周至少五篇博客:(1/5)A.LRCandVIP题意您有一个大小nnn的数组aaa-a1,a2,…ana_1,a_2,\ldotsa_na1,a2,…an。您需要将nnn元素分为222序列BBB和CCC,以满足以下条件:每个元素恰好属于一个序列。两个序列BBB和CCC至少包含一个元素。gcd\gcdgcd(B1,B2,…,B∣B∣)≠gcd(C1,C2,…,C∣C∣)(B_1,B_2,\ld
- c语言 数值传递错误,错误:无效值不被忽略 - 在简单的c程序
不中顶会不改名
c语言数值传递错误
我是新来编程c。当运行下面的代码,我收到以下错误与在=一个小箭头指向登录:错误:无效值不被忽略-在简单的c程序错误:不被忽略,因为它空值应该是*GCD=gcd_lcm((乘数1%乘数2),factor2,gcd,lcm);我试图按照向另一篇文章中找到的void类型返回值的步骤进行操作,但似乎无法在我的代码中工作。有人可以帮我指出我的错误吗?非常感谢。#includevoidgcd_lcm(intf
- 4.Cantor表(升级版)
信息学奥赛-Mr-H
信息学奥赛-递归专题c++算法蓝桥杯
Cantor表(升级版)-洛谷解题思路:(1)根据题目可以得出,分子的大小表示所在的行数,分母的大小表示所在的列数,那么只需要求出两个分数的乘积即可(2)利用递归求解两个数的最大公约数,然后对结果进行约分即可#includeusingnamespacestd;intgcd(intx,inty){if(x%y==0)returny;elsereturngcd(y,x%y);}intmain(){in
- 简单数学板子和例题
啊我不会诶
数学算法数据结构
线性丢番图方程ax+by=cd=gcd(a,b),若c|d,有无穷整数解x=x0+bdn,y=y0−adnx=x_0+{b\overd}n,y=y_0-{a\overd}nx=x0+dbn,y=y0−danPOJ1265poj真难用,abs一直报错,万能头也不能用,给我调红温了structpoint{intx,y;}q[1010];intn;llnum,In;doubleS;intgcd(intA
- 上海市计算机学会竞赛平台2025年5月月赛丙组相等数组
titan TV man
算法
题目描述Eve有一个长度为nn的数组aa以及一个常数m≥2m≥2,他知道对于任意的1≤i≤n1≤i≤n,都有2≤ai≤m2≤ai≤m。Eve觉得数组里一定要有全部相等的元素,所以他想通过以下操作把数组里的元素变得全部相等:选定一个整数2≤t≤m2≤t≤m,然后令每一个aiai都变为gcd(ai,t)gcd(ai,t),其中gcd(x,y)gcd(x,y)表示x,yx,y的最大公因数,例如gcd
- 巧用数论与动态规划破解包子凑数问题
EtherWanderer
数据结构与算法蓝桥杯职场和发展
题目描述小明想知道包子铺用给定的蒸笼规格能凑出多少种无法组成的包子数目。若无法组成的数目无限,输出INF。输入格式第一行为整数NNN(蒸笼种数)接下来NNN行每行一个整数AiA_iAi(每种蒸笼的包子数)输出格式无法凑出的数目个数,若无限则输出INF问题分析关键条件若所有AiA_iAi的最大公约数(GCD)不为1,则无法组成的数目无限。例如,当所有数均为偶数时,无法组成任何奇数。动态规划思路当GC
- java杨辉三角
3213213333332132
java基础
package com.algorithm;
/**
* @Description 杨辉三角
* @author FuJianyong
* 2015-1-22上午10:10:59
*/
public class YangHui {
public static void main(String[] args) {
//初始化二维数组长度
int[][] y
- 《大话重构》之大布局的辛酸历史
白糖_
重构
《大话重构》中提到“大布局你伤不起”,如果企图重构一个陈旧的大型系统是有非常大的风险,重构不是想象中那么简单。我目前所在公司正好对产品做了一次“大布局重构”,下面我就分享这个“大布局”项目经验给大家。
背景
公司专注于企业级管理产品软件,企业有大中小之分,在2000年初公司用JSP/Servlet开发了一套针对中
- 电驴链接在线视频播放源码
dubinwei
源码电驴播放器视频ed2k
本项目是个搜索电驴(ed2k)链接的应用,借助于磁力视频播放器(官网:
http://loveandroid.duapp.com/ 开放平台),可以实现在线播放视频,也可以用迅雷或者其他下载工具下载。
项目源码:
http://git.oschina.net/svo/Emule,动态更新。也可从附件中下载。
项目源码依赖于两个库项目,库项目一链接:
http://git.oschina.
- Javascript中函数的toString()方法
周凡杨
JavaScriptjstoStringfunctionobject
简述
The toString() method returns a string representing the source code of the function.
简译之,Javascript的toString()方法返回一个代表函数源代码的字符串。
句法
function.
- struts处理自定义异常
g21121
struts
很多时候我们会用到自定义异常来表示特定的错误情况,自定义异常比较简单,只要分清是运行时异常还是非运行时异常即可,运行时异常不需要捕获,继承自RuntimeException,是由容器自己抛出,例如空指针异常。
非运行时异常继承自Exception,在抛出后需要捕获,例如文件未找到异常。
此处我们用的是非运行时异常,首先定义一个异常LoginException:
/**
* 类描述:登录相
- Linux中find常见用法示例
510888780
linux
Linux中find常见用法示例
·find path -option [ -print ] [ -exec -ok command ] {} \;
find命令的参数;
- SpringMVC的各种参数绑定方式
Harry642
springMVC绑定表单
1. 基本数据类型(以int为例,其他类似):
Controller代码:
@RequestMapping("saysth.do")
public void test(int count) {
}
表单代码:
<form action="saysth.do" method="post&q
- Java 获取Oracle ROWID
aijuans
javaoracle
A ROWID is an identification tag unique for each row of an Oracle Database table. The ROWID can be thought of as a virtual column, containing the ID for each row.
The oracle.sql.ROWID class i
- java获取方法的参数名
antlove
javajdkparametermethodreflect
reflect.ClassInformationUtil.java
package reflect;
import javassist.ClassPool;
import javassist.CtClass;
import javassist.CtMethod;
import javassist.Modifier;
import javassist.bytecode.CodeAtt
- JAVA正则表达式匹配 查找 替换 提取操作
百合不是茶
java正则表达式替换提取查找
正则表达式的查找;主要是用到String类中的split();
String str;
str.split();方法中传入按照什么规则截取,返回一个String数组
常见的截取规则:
str.split("\\.")按照.来截取
str.
- Java中equals()与hashCode()方法详解
bijian1013
javasetequals()hashCode()
一.equals()方法详解
equals()方法在object类中定义如下:
public boolean equals(Object obj) {
return (this == obj);
}
很明显是对两个对象的地址值进行的比较(即比较引用是否相同)。但是我们知道,String 、Math、I
- 精通Oracle10编程SQL(4)使用SQL语句
bijian1013
oracle数据库plsql
--工资级别表
create table SALGRADE
(
GRADE NUMBER(10),
LOSAL NUMBER(10,2),
HISAL NUMBER(10,2)
)
insert into SALGRADE values(1,0,100);
insert into SALGRADE values(2,100,200);
inser
- 【Nginx二】Nginx作为静态文件HTTP服务器
bit1129
HTTP服务器
Nginx作为静态文件HTTP服务器
在本地系统中创建/data/www目录,存放html文件(包括index.html)
创建/data/images目录,存放imags图片
在主配置文件中添加http指令
http {
server {
listen 80;
server_name
- kafka获得最新partition offset
blackproof
kafkapartitionoffset最新
kafka获得partition下标,需要用到kafka的simpleconsumer
import java.util.ArrayList;
import java.util.Collections;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.
- centos 7安装docker两种方式
ronin47
第一种是采用yum 方式
yum install -y docker
 
- java-60-在O(1)时间删除链表结点
bylijinnan
java
public class DeleteNode_O1_Time {
/**
* Q 60 在O(1)时间删除链表结点
* 给定链表的头指针和一个结点指针(!!),在O(1)时间删除该结点
*
* Assume the list is:
* head->...->nodeToDelete->mNode->nNode->..
- nginx利用proxy_cache来缓存文件
cfyme
cache
user zhangy users;
worker_processes 10;
error_log /var/vlogs/nginx_error.log crit;
pid /var/vlogs/nginx.pid;
#Specifies the value for ma
- [JWFD开源工作流]JWFD嵌入式语法分析器负号的使用问题
comsci
嵌入式
假如我们需要用JWFD的语法分析模块定义一个带负号的方程式,直接在方程式之前添加负号是不正确的,而必须这样做:
string str01 = "a=3.14;b=2.71;c=0;c-((a*a)+(b*b))"
定义一个0整数c,然后用这个整数c去
- 如何集成支付宝官方文档
dai_lm
android
官方文档下载地址
https://b.alipay.com/order/productDetail.htm?productId=2012120700377310&tabId=4#ps-tabinfo-hash
集成的必要条件
1. 需要有自己的Server接收支付宝的消息
2. 需要先制作app,然后提交支付宝审核,通过后才能集成
调试的时候估计会真的扣款,请注意
- 应该在什么时候使用Hadoop
datamachine
hadoop
原帖地址:http://blog.chinaunix.net/uid-301743-id-3925358.html
存档,某些观点与我不谋而合,过度技术化不可取,且hadoop并非万能。
--------------------------------------------万能的分割线--------------------------------
有人问我,“你在大数据和Hado
- 在GridView中对于有外键的字段使用关联模型进行搜索和排序
dcj3sjt126com
yii
在GridView中使用关联模型进行搜索和排序
首先我们有两个模型它们直接有关联:
class Author extends CActiveRecord {
...
}
class Post extends CActiveRecord {
...
function relations() {
return array(
'
- 使用NSString 的格式化大全
dcj3sjt126com
Objective-C
格式定义The format specifiers supported by the NSString formatting methods and CFString formatting functions follow the IEEE printf specification; the specifiers are summarized in Table 1. Note that you c
- 使用activeX插件对象object滚动有重影
蕃薯耀
activeX插件滚动有重影
使用activeX插件对象object滚动有重影 <object style="width:0;" id="abc" classid="CLSID:D3E3970F-2927-9680-BBB4-5D0889909DF6" codebase="activex/OAX339.CAB#
- SpringMVC4零配置
hanqunfeng
springmvc4
基于Servlet3.0规范和SpringMVC4注解式配置方式,实现零xml配置,弄了个小demo,供交流讨论。
项目说明如下:
1.db.sql是项目中用到的表,数据库使用的是oracle11g
2.该项目使用mvn进行管理,私服为自搭建nexus,项目只用到一个第三方 jar,就是oracle的驱动;
3.默认项目为零配置启动,如果需要更改启动方式,请
- 《开源框架那点事儿16》:缓存相关代码的演变
j2eetop
开源框架
问题引入
上次我参与某个大型项目的优化工作,由于系统要求有比较高的TPS,因此就免不了要使用缓冲。
该项目中用的缓冲比较多,有MemCache,有Redis,有的还需要提供二级缓冲,也就是说应用服务器这层也可以设置一些缓冲。
当然去看相关实现代代码的时候,大致是下面的样子。
[java]
view plain
copy
print
?
public vo
- AngularJS浅析
kvhur
JavaScript
概念
AngularJS is a structural framework for dynamic web apps.
了解更多详情请见原文链接:http://www.gbtags.com/gb/share/5726.htm
Directive
扩展html,给html添加声明语句,以便实现自己的需求。对于页面中html元素以ng为前缀的属性名称,ng是angular的命名空间
- 架构师之jdk的bug排查(一)---------------split的点号陷阱
nannan408
split
1.前言.
jdk1.6的lang包的split方法是有bug的,它不能有效识别A.b.c这种类型,导致截取长度始终是0.而对于其他字符,则无此问题.不知道官方有没有修复这个bug.
2.代码
String[] paths = "object.object2.prop11".split("'");
System.ou
- 如何对10亿数据量级的mongoDB作高效的全表扫描
quentinXXZ
mongodb
本文链接:
http://quentinXXZ.iteye.com/blog/2149440
一、正常情况下,不应该有这种需求
首先,大家应该有个概念,标题中的这个问题,在大多情况下是一个伪命题,不应该被提出来。要知道,对于一般较大数据量的数据库,全表查询,这种操作一般情况下是不应该出现的,在做正常查询的时候,如果是范围查询,你至少应该要加上limit。
说一下,
- C语言算法之水仙花数
qiufeihu
c算法
/**
* 水仙花数
*/
#include <stdio.h>
#define N 10
int main()
{
int x,y,z;
for(x=1;x<=N;x++)
for(y=0;y<=N;y++)
for(z=0;z<=N;z++)
if(x*100+y*10+z == x*x*x
- JSP指令
wyzuomumu
jsp
jsp指令的一般语法格式: <%@ 指令名 属性 =”值 ” %>
常用的三种指令: page,include,taglib
page指令语法形式: <%@ page 属性 1=”值 1” 属性 2=”值 2”%>
include指令语法形式: <%@include file=”relative url”%> (jsp可以通过 include