如何解决Jmeter中文请求乱码问题
解决Jmeter中文请求乱码问题时,我们可以通过多种途径进行操作。码下首先,码下需注意消息头和请求体的码下编码设置,确保接收编码为UTF-8,码下避免出现编码问题导致的码下代源码居中乱码现象。然而,码下Content encoding的码下设置并不会影响最终返回结果。
其次,码下修改本地配置文件jmeter.properties同样是码下一个有效的解决方法。只需修改bin目录下的码下此文件,并重启Jmeter,码下这样设置一次即可长期适用,码下无需频繁调整。码下
添加BeanShell Sampler或BeanShell PostProcessor为另一种灵活解决方案。码下在HTTP请求后添加此采样器,然后在Script处填写代码,将数据编码设置为utf-8,这种方式无需重启Jmeter即可进行动态调整。
若以上方法仍无法解决特定问题,检查和修改Jmeter源码可能成为最后的手段。通过反编译ApacheJMeter_pileä¸çcompileæ¯ä¸ä¸ªçå½å¨æçè¯ãåæ¶è¯¥å½ä»¤ä¹å¯ä»¥çä»·äºmvncompiler:compileï¼å ¶ä¸çcompileræ¯ä¸ä¸ªæ件ï¼å®æä¾äºcompile(æ¤compileä¸mvncompileä¸çcompileæä¹ä¸å)goalï¼compilerè¿å¯æä¾å¦ä¸ä¸ªgoal--testCompileï¼è¯¥goalç¨äºç¼è¯junitæµè¯ç±»ã
å¨æ§è¡æä¸ä¸ªçå½å¨ææ¶ï¼Mavenä¼é¦å æ§è¡è¯¥çå½å¨æä¹åçå ¶å®å¨æãå¦è¦æ§è¡compileï¼é£ä¹å°é¦å æ§è¡validateï¼generate-sourceï¼process-sourceågenerate-resourcesï¼æååæ§è¡compileæ¬èº«ãå ³äºMavenä¸é»è®¤ççå½å¨æçè¯ï¼è¯·è§åèèµæº[6]ä¸çéå½B.3ã
3æ åç®å½å¸å±
Maven为工ç¨ä¸çæºæ件ï¼èµæºæ件ï¼é ç½®æ件ï¼çæçè¾åºåææ¡£é½å¶å®äºä¸ä¸ªæ åçç®å½ç»æãMavené¼å±ä½¿ç¨æ åç®å½å¸å±ï¼è¿æ ·å°±ä¸éè¦è¿è¡é¢å¤çé ç½®ï¼èä¸æå©äºå个ä¸åå·¥ç¨ä¹é´çèæ¥ãå½ç¶ï¼Mavenä¹å 许å®å¶ä¸ªæ§çç®å½å¸å±ï¼è¿å°±éè¦è¿è¡æ´å¤çé ç½®ãå ³äºMavençæ åç®å½å¸å±ï¼è¯·è§åèèµæº[6]ä¸çéå½B.1ã
4Mavençä¼ç¹
[1]buildé»è¾å¯ä»¥è¢«éç¨ãå¨Antä¸å¯è½éè¦å¤æ¬¡éå¤å°åç¸åçè¯å¥ï¼ä½ç±äºPOMç继æ¿æ§ï¼å¯ä»¥å¤ç¨å ¶å®çPOMæ件ä¸çè¯å¥ãè¿æ ·æ¢å¯ä»¥ååºæ¸ æ°çbuildè¯å¥ï¼åå¯ä»¥æé åºå±æ¬¡å ³ç³»è¯å¥½çbuildå·¥ç¨ã
[2]ä¸å¿ å ³æ³¨buildå·¥ä½çå®ç°ç»èãæ们åªéè¦ä½¿ç¨ä¸äºbuildçå½å¨æçè¯å°±å¯ä»¥è¾¾å°æ们çç®æ ï¼èä¸å¿ 管Mavenæ¯å¦ä½åå°è¿äºçãå¦ï¼åªéè¦åè¯Mavenè¦å®è£ (install)ï¼é£ä¹å®èªç¶å°±ä¼éªè¯ï¼ç¼è¯ï¼æå ï¼åå®è£ ã
[3]Mavenä¼éå½å 载工ç¨ä¾èµçartifactæä¾èµçå ¶å®artifactï¼èä¸ç¨æ¾ç¤ºçå°è¿äºartifactå ¨é¨åå°dependencyä¸ã
[4]å¦æå®å ¨ä½¿ç¨Mavençæ åç®å½å¸å±ï¼é£ä¹å¯ä»¥æ大å°åå°é ç½®ç»èã
5å®ä¾
5.1ææ³
ç±äºåªæ¯éè¿°Mavençåºæ¬ä½¿ç¨æ¹æ³ï¼æ以æ¬æå°è¦è®¾è®¡çå®ä¾ï¼åªæ¯ä¸ä¸ªç®åçMavendemoã该å®ä¾å å«ä¸¤ä¸ªå·¥ç¨ï¼æ®éåºç¨ç¨åºå·¥ç¨(app)åWebåºç¨å·¥ç¨(webapp)ãappå·¥ç¨æä¾ä¸ä¸ªç®åçJavaç±»ï¼webappå·¥ç¨åªå å«ä¸ä¸ªServletï¼å¹¶å°ä½¿ç¨appä¸çJavaç±»ã
该Demoçç®æ æ¯è½å¤æ£ç¡®å°å°webappå¶æwarå ï¼ä»¥ä¾é¨ç½²æ¶ä½¿ç¨ãè¦è½å¤æ£ç¡®å¶ä½warï¼èªç¶é¦å å°±å¿ é¡»è¦è½å¤æ£ç¡®çç¼è¯æºä»£ç ï¼ä¸è¦å°App模åå¶æjarå ãæ¬æå建çå·¥ç¨æå¨çç®å½æ¯D:/maven/demoã
5.2Appå·¥ç¨
å¯ä»¥ä½¿ç¨Mavençarchetypeæ件æ¥å建æ°å·¥ç¨ï¼å½ä»¤å¦ä¸ï¼
D:/maven/demomvnarchetype:create-DgroupId=ce.demo.mvn-DartifactId=app
该工ç¨çgroupIdæ¯ce.demo.mvnï¼é£ä¹è¯¥å·¥ç¨çæºæ件å°æ¾å¨Javaå ce.demo.mvnä¸ãartifactIdæ¯appï¼é£ä¹è¯¥å·¥ç¨æ ¹ç®å½çå称å°ä¸ºappã
å½ç¬¬ä¸æ¬¡æ§è¡è¯¥å½ä»¤æ¶ï¼Mavenä¼ä»centralä»åºä¸ä¸è½½ä¸äºæ件ãè¿äºæ件å å«æ件archetypeï¼ä»¥åå®æä¾èµçå ¶å®å ã该å½ä»¤æ§è¡å®æ¯åï¼å¨ç®å½D:/maven/demoä¸ä¼åºç°å¦ä¸ç®å½å¸å±ï¼
app
|--pom.xml
`--src
|--main
|`--java
|`--ce
|`--demo
|`--mvn
|`--App.java
`--test
`--java
`--ce
`--demo
`--mvn
`--AppTest.java
å æ¬æææ¶ä¸æ¶åJUnitæµè¯ï¼æ 请å°ç®å½app/src/testç®å½å é¤ãç¶ååä¿®æ¹App.javaæ件ï¼å ¶å®å ¨å 容å¦ä¸ï¼
packagece.demo.mvn;
publicclassApp{
publicStringgetStr(Stringstr){
returnstr;
}
}
å ¶å®ï¼å¦ææ们è½å¤æ¸ æ¥å°ç¥éMavençæ åç®å½å¸å±ï¼å°±å¯ä»¥ä¸ä½¿ç¨archetypeæ件æ¥å建工ç¨ååï¼å¦ææ们è¦å®å¶ä¸ªæ§çç®å½å¸å±ï¼é£ä¹å°±æ´æ²¡æå¿ è¦ä½¿ç¨archetypeæ件äºã
å¦ä½ç¨mavenå°java8åç代ç ç¼è¯ä¸ºjava6å¹³å°çå¨ä¸è¬çJavaåºç¨å¼åè¿ç¨ä¸ï¼å¼å人å使ç¨Javaçæ¹å¼æ¯è¾ç®åãæå¼æ¯ç¨çIDEï¼ç¼åJavaæºä»£ç ï¼åå©ç¨IDEæä¾çåè½ç´æ¥è¿è¡Javaç¨åºå°±å¯ä»¥äºãè¿ç§å¼å模å¼èåçè¿ç¨æ¯ï¼å¼å人åç¼åçæ¯Javaæºä»£ç æ件ï¼.javaï¼ï¼IDEä¼è´è´£è°ç¨Javaçç¼è¯å¨æJavaæºä»£ç ç¼è¯æå¹³å°æ å ³çåè代ç ï¼bytecodeï¼ï¼ä»¥ç±»æ件çå½¢å¼ä¿åå¨ç£çä¸ï¼.classï¼ãJavaèææºï¼JVMï¼ä¼è´è´£æJavaåè代ç å 载并æ§è¡ãJavaéè¿è¿ç§æ¹å¼æ¥å®ç°å ¶âç¼åä¸æ¬¡ï¼å°å¤è¿è¡ï¼Writeonce,runanywhereï¼âçç®æ ãJavaç±»æ件ä¸å å«çåè代ç å¯ä»¥è¢«ä¸åå¹³å°ä¸çJVMæ使ç¨ãJavaåè代ç ä¸ä» å¯ä»¥ä»¥æ件形å¼åå¨äºç£çä¸ï¼ä¹å¯ä»¥éè¿ç½ç»æ¹å¼æ¥ä¸è½½ï¼è¿å¯ä»¥åªåå¨äºå åä¸ãJVMä¸çç±»å è½½å¨ä¼è´è´£ä»å å«åè代ç çåèæ°ç»ï¼byte[]ï¼ä¸å®ä¹åºJavaç±»ãå¨æäºæ åµä¸ï¼å¯è½ä¼éè¦å¨æççæJavaåè代ç ï¼ææ¯å¯¹å·²æçJavaåè代ç è¿è¡ä¿®æ¹ãè¿ä¸ªæ¶åå°±éè¦ç¨å°æ¬æä¸å°è¦ä»ç»çç¸å ³ææ¯ãé¦å ä»ç»ä¸ä¸å¦ä½å¨æç¼è¯Javaæºæ件ã
mavenæ¯javawebä¹mavenåjavaweb没æä»»ä½å ³ç³»
Maven项ç®å¯¹è±¡æ¨¡å(POM)ï¼å¯ä»¥éè¿ä¸å°æ®µæè¿°ä¿¡æ¯æ¥ç®¡ç项ç®çæ建ï¼æ¥ååææ¡£ç软件项ç®ç®¡çå·¥å ·ã
Mavené¤äºä»¥ç¨åºæ建è½å为ç¹è²ä¹å¤ï¼è¿æä¾é«çº§é¡¹ç®ç®¡çå·¥å ·ãç±äºMavenç缺çæ建è§åæè¾é«çå¯éç¨æ§ï¼æ以常常ç¨ä¸¤ä¸è¡Mavenæ建èæ¬å°±å¯ä»¥æ建ç®åç项ç®ãç±äºMavençé¢å项ç®çæ¹æ³ï¼è®¸å¤ApacheJakarta项ç®åææ¶ä½¿ç¨Mavenï¼èä¸å ¬å¸é¡¹ç®éç¨Mavençæ¯ä¾å¨æç»å¢é¿ã
mavenæä¹ä¼å 使ç¨jreç³»ç»åº
å½ä½¿ç¨Mavenæ建Java项ç®æ¶ï¼é»è®¤æ åµä¸ï¼Mavenä¼ä½¿ç¨é¡¹ç®ä¸æå®çJDKçæ¬ä¸çJavaåºï¼èä¸æ¯ä½¿ç¨ç³»ç»ä¸å®è£ çJREçæ¬ä¸çJavaåºãå¦ææ¨å¸æä¼å 使ç¨ç³»ç»ä¸çJREåºèä¸æ¯JDKåºï¼å¯ä»¥æç §ä»¥ä¸æ¥éª¤è¿è¡é ç½®ï¼
å¨é¡¹ç®çpom.xmlæ件ä¸æ·»å 以ä¸buildé ç½®ï¼
xml
Copycode
build
plugins
plugin
groupIdorg.apache.maven.plugins/groupId
artifactIdmaven-compiler-plugin/artifactId
version3.8.1/version
configuration
forktrue/fork
executable${ JAVA_HOME}/bin/javac/executable
compilerVersion/compilerVersion
source/source
target/target
compilerArgs
arg--release/arg
arg/arg
/compilerArgs
systemPropertyVariables
java.home${ env.JAVA_HOME}/java.home
/systemPropertyVariables
/configuration
/plugin
/plugins
/build
å¨ä¸é¢çé ç½®ä¸ï¼executableæå®äºè¦ä½¿ç¨çJavaç¼è¯å¨çè·¯å¾ï¼è¿é使ç¨äº${ JAVA_HOME}/bin/javacï¼å³ä½¿ç¨ç¯å¢åéJAVA_HOMEæå®çJREè·¯å¾ä¸çjavacå½ä»¤ãsystemPropertyVariablesæå®äºè¦ä½¿ç¨çJREè·¯å¾ï¼è¿é使ç¨äºç¯å¢åéJAVA_HOMEãè¿æ ·ï¼Mavenå°ä½¿ç¨ç¯å¢åéJAVA_HOMEæå®çJREè·¯å¾ä¸çJavaåºã
2.ç¡®ä¿æ¨çç³»ç»ä¸å®è£ äºJREï¼å¹¶è®¾ç½®äºç¯å¢åéJAVA_HOMEï¼è¯¥åéæåJREçå®è£ è·¯å¾ãæ¨å¯ä»¥éè¿å¨å½ä»¤è¡çªå£ä¸è¾å ¥echo$JAVA_HOMEæ¥æ£æ¥è¯¥åéæ¯å¦è®¾ç½®æ£ç¡®ã
3.å¨å½ä»¤è¡çªå£ä¸è¿å ¥é¡¹ç®çæ ¹ç®å½ï¼ç¶åè¿è¡ä»¥ä¸å½ä»¤æ¥æ建项ç®ï¼
bash
Copycode
mvncleaninstall
è¿å°ä½¿ç¨é ç½®çJREåºæ¥æ建项ç®ã
éè¿ä»¥ä¸é ç½®ï¼æ¨å¯ä»¥ä¼å 使ç¨ç³»ç»ä¸çJREåºèä¸æ¯JDKåºæ¥æ建Java项ç®ã
mavenä»ä¹æ¶åå¦å¨å¦æ¡æ¶çæ¶åä¸èµ·å¦ãMavenï¼ç¨äºJava项ç®çæ建ï¼ä¾èµç®¡çï¼é¡¹ç®ä¿¡æ¯ç®¡çç项ç®ç®¡çå·¥å ·ã使ç¨mavenå¯ä»¥ç®¡çå¾å¤ä¸ªjarå ï¼å¨å¦ä¹ æ¡æ¶çæ¶ååå¯¼å ¥å¾å¤å å¦çå¾ä¸æ¹ä¾¿ï¼å¦è¿ä¸ªææ¯å¯ä»¥å¾å¥½ç帮å©ç®¡çæ¡æ¶éé¢çåç§å ã
jmeter中借助OCR实现验证码的识别
在JMeter进行接口测试时,验证码处理是一个常见的挑战。虽然手动测试时,直接绕过或请求开发设置简单验证码是常见做法,但这并不适用于自动化测试。本文将介绍一种利用OCR技术在JMeter中识别验证码的方法,但请注意,对于背景复杂干扰的,识别率可能不高,适合纯色底纹的情况。
首先,通过JMeter模拟登录接口,获取验证码。启动JMeter,创建线程组并配置HTTP和Debug采样器。启用监听器,将验证码保存为1.png文件。
接着,使用Java编写脚本,将转换为Base格式,这包括导入sun.misc.BASEDecoder.jar包,创建包和文件,编写ToImage类,并导出为jar包。在Beanshell处理器中,导入此jar包并调用其方法处理验证码。
对于验证码识别,推荐使用开源的jmeter-captcha插件,从Gitee下载jar包或源码进行二次开发。在JMeter的测试计划中,添加后置处理器,如Beanshell,配置OCR插件参数。简单验证码如纯数字、字母或汉字的识别率较高。
尽管基础识别率可能有待提高,但通过优化OCR处理代码,可以提升识别效果。后续将分享干扰优化的技巧和深度学习方法,以进一步提升识别准确率。
本文提供了一个基础的验证码识别框架,欢迎您持续关注并分享给有需要的朋友。
beanshell和shell的区别
Beanshell和Shell在多个方面存在显著区别。
首先,从定义和用途上来看,Beanshell是一种Java源代码解释器,它允许Java开发人员以脚本的形式编写和执行Java代码。Beanshell的主要目的是为Java开发人员提供一个简单、易用的脚本工具,以便他们能够快速测试、调试和运行Java代码片段。而Shell则是一种命令行解释器,通常用于操作系统的命令行界面。Shell脚本是一组命令的集合,用户可以在命令行界面下直接执行这些命令,以实现自动化任务、批处理操作等。
其次,Beanshell和Shell在语法和执行方式上也有所不同。Beanshell的语法基于Java语言,因此它支持Java的所有语法和特性,包括变量、数据类型、控制结构、函数等。Beanshell脚本可以直接在Java环境中运行,也可以嵌入到Java应用程序中作为脚本引擎使用。而Shell的语法则因操作系统的不同而有所差异,常见的Shell有Bash、Zsh、Csh等。Shell脚本通常通过命令行界面执行,也可以作为其他程序的易福源码和阿莫源码输入或输出。
最后,Beanshell和Shell在应用场景上也存在差异。Beanshell通常用于Java开发过程中的测试、调试和快速原型设计,它允许开发人员在无需编写完整Java应用程序的情况下,快速执行和验证Java代码片段。而Shell则更常用于系统管理和自动化任务,例如批处理文件操作、日志分析、系统监控等。Shell脚本可以方便地集成到操作系统的命令行界面中,实现各种自动化操作。
综上所述,Beanshell和Shell在定义、用途、语法、执行方式以及应用场景等方面都存在明显的区别。Beanshell主要针对Java开发人员提供脚本支持,而Shell则更适用于系统管理和自动化任务。根据具体需求和使用场景的不同,用户可以选择合适的工具来完成相应的任务。
android ç³»ç»å¼åç¨ä»ä¹ide
1. JavaIDEdroid
JavaIDEdroidæ¯ä¸ä¸ªIDEï¼éæå¼åç¯å¢ï¼ï¼å¯ä»¥è¿è¡äºAndroidä¸ï¼å¹¶ä¸å è®¸ä½ ç´æ¥å¨æ¬å°å建Androidåºç¨ï¼èä¸éè¦éè¿MacãWindowsæLinuxä¸çAndroid SDKãJavaIDEdroidå¼å§é æaaptå·¥å ·ãJavaç¼è¯å¨ãdxå·¥å ·ãDexMergerå·¥å ·ãApkBuilderãzipsigneråºï¼è¯¥åºåæ ·æzipalignåè½ï¼ãSpongyCastleåºãBeanShell InterpreteråJavaRunnerã
2. Java Editor
Java Editoræ¯ä¸ä¸ªé常容æ使ç¨çJavaç¼è¾å¨ï¼å®åè½æéï¼ä½å®å¯ä»¥å½©è²è¯æ³ï¼å½æ°ãåéãæ¹æ³ã常éï¼æ¯æèªå¨å®æãå¯ä»¥æå¼é»è®¤æ件æ©å±jav&javaã
3. Terminal IDE
Terminal IDEæ¯ä¸ä¸ªé«åº¦å¯æ©å±çç»ç«¯åºç¨ç¨åºãå®æå®æ´çJava / C / C++ / HTML / Androidå¼åå·¥å ·å ï¼å¹¶ä¸å¯ä»¥å¨ä»»ä½Android设å¤ä¸è¿è¡ãå®ä½¿ç¨å½ä»¤è¡ï¼ç¼è¾å¨ä¸è®¾ç½®äºC/ java / HTMLä½ä¸ºå¼å人åå¼åç主è¦éæ©é¡¹ã
4. DroidEdit
DroidEditæ¯ä¸ä¸ªææ¬åæºç ç¼è¾å¨ï¼ç±»ä¼¼äºPCä¸çNotepad++ï¼ï¼ç¨äºå®åå¹³æ¿åææºãDroidEditæ¯æå®åå¹³æ¿çµèçå¤é¨è¿æ¥é®çï¼å¦Asus Transformeræå ¶ä»ç¬¬ä¸æ¹é®çãåæ¶å®è¿æ¯æå¤ç§è¯è¨ï¼ å¦Cã C++ã C#ã JavaãHTMLãCSSãJavascriptãPythonãRubyãLuaãLaTeXåSQLã
5. Syntax Highlighted代ç ç¼è¾å¨
Syntax Highlightedæ¯æHTMLãCSSãJavaScriptãPHPç¼è¾å¨ãPythonãJavaãCãC++ãCoffeeScriptãHaskellãClojureåGroovyãè½ç¶å ¶ä¸»è¦å®ä½æ¯Webè¿ä¸åï¼ä½æ¯Javaç¼ç åä¹å¯ä»¥ä½¿ç¨å®ï¼å®æ¬èº«æºæå¾å¤åè½ï¼å¦æ¥æ¾/æ¿æ¢ãæ¤éåéååè½ã
6. Code Peeker Proï¼æºç é 读å¨
Code Peeker Proå¯ä»¥è®©è¯æ³é«äº®æ¾ç¤ºï¼å¹¶å è®¸ä½ æ¥æ¾ä»£ç ç段ãè½ç¶å®ä¸æ¯ä¸ä¸ªç¼è¾å¨ãä½å®æ¯ä¸ä¸ªæç¨ç代ç é 读å¨ï¼ä¸è¢«Google Playéä¸ä½ä¸ºæè²é¡¹ç®çä¸é¨åãCode Peeker Proå¯ä»¥æå¼åé«äº®ä»»ä½æ¯æç代ç è¯è¨ï¼å¦C/C++ (cãccãcppãhãhpp)ãC#(c-sharpãcsharpãcs)ãCSS, JavaãJavaScript (jsãjscript)ãPHPãPython (py)ãRuby (railsãror)ãXML (xmlãxamlãxsltãHTMLãxhtml)ãActionScript 3 (as3)ãAppleScriptãCold FusionãDelphi/PascalãDiff/patch filesãErlangãGroovyãJavaFX (jfx)ãPerl (pl)ãPowerShell (ps)ãSassãScalaãSQLãTerminal scripts (bashãshellãshãrcãconf)ãVisual Basics (vbãvbnet) åVerilog & System Verilog (vãsv)ã
å®è¿å¯ä»¥æ è®°éè¦ä»£ç çä½ç½®ãå ç½®ä¸ä¸ªæ件æµè§å¨ãæ¯æå å¤é¨SDå¡ï¼åæ¶ä¹æ¯æå ¶ä»æ件æµè§å¨ï¼å¦Dropboxçã
7. Sand IDE Pro
Sandæ¯ä¸ä¸ªAndroidå¹³å°çJavaéæå¼åç¯å¢ï¼IDEï¼ï¼æ¯æJava1.3å°Java1.6ï¼æ³¨æçæ¯Androidä¸æ¯æJava1.7ï¼ã
Sand IDEæ¯ä¸ä¸ªJavaç¼è¾å¨ï¼å¹¶æ¯æJavaå ³é®åé«äº®æ¾ç¤ºãæ¾ç¤ºè¡å·ãæ¤é/éåï¼ä¹æ¯ä¸ä¸ªå ¨åè½çJavaç¼è¯å¨ï¼è½å¤è¿è¡Javaç¨åºå¹¶æ¯æç¨åºçè¾å ¥/è¾åºã
æè¿ä¸äºæ°çå¹³æ¿çµèå¼å§éç¨Intelè¯çï¼ä¸è¿ä¸ç¨æ å¿ï¼Sand IDEæ¯æææç±»åçCPUæ¶æï¼xãARMãMIPSï¼ã
8. AIDEââAndroid IDE
AIDEæ¯ä¸ä¸ªå¯ä»¥ç´æ¥å¨èªå·±Android设å¤ä¸å¼ååºç¨çIDEï¼å ³äºå®çæ交äºå¼ç¼ç¨è¯¾ç¨ãåºç¨å¼åçåå¸æç¨ä»¥åJavaç¼ç¨æå·§ãä½ å¯ä»¥ç´è§ç设计åºç¨ãç¨ç¼è¾å¨ç¼å代ç ãå®æ¶æ£æ¥é误ã代ç éæãæºè½ä»£ç 导èªâ¦â¦ã
9. Anacode
Anacodeæ¯å¦ä¸ä¸ªIDEåæºä»£ç ç¼è¾å¨ï¼æ¯æJavaãHTMLãCSSãPHPãJavaScriptåC/C++ï¼å¹¶å è®¸ä½ å¨Android设å¤ä¸æ建åè¿è¡ã ä½ ä¹å¯ä»¥å¨å ç½®æç³»ç»æµè§å¨ä¸ç¼ååæµè¯HTMLãJavaScriptåCSSï¼å¹¶ä¸ä¼ å°FTPã
. Quoda代ç ç¼è¾å¨
Quodaä¹ç±»ä¼¼äºNotepad++æ¯æSFTP/FTP(S)æå¡åäºåå¨ï¼å¦Dropboxåè°·æï¼ï¼è¯æ³é«äº®æ¯éè¿åç§åæ ·ç主é¢ååä½æ¥æ¾ç¤ºçï¼å¹¶éç¨äºåç§ç¼ç¨è¯è¨ï¼å æ¬HTMLãXMLãCSSãJavaScriptãPHPãCãC++ãC#ãJavaãActionScriptãLispãMarkdownãHaskellççï¼ã为åå°ç¨åºåç代ç å·¥ä½ï¼æé«å ¶å¼åçæçï¼Quodaæä¾äºä»£ç 模æ¿åç段çæ¯æï¼å¹¶ä¸å¢å äºé®çä¸é¢å¤çæé®ï¼ä½¿ä½ è½å¤æé«æåé度ãå¦å¤ï¼å ¶å®å¼å¾ä¸æçç¹æ§è¿å æ¬æ¥æ¾åæ¿æ¢ã注éååæ¶æ³¨éãHTMLæ件é¢è§ãç½ç«æºç ä¸è½½ãHTMLæ¸ æ´å¨çã
懂编程的来
各种语言的介绍(第二版)
在介绍编程语言之前,先说说开放源代码的必要性。现在,在软件生产领域存在巨大的智利浪费,大家把大量的精力用在编写别人已经实现的 程序代码上。看看,文本编辑器有多少,看看ftp程序有多少,看看字处理程序有多少,这些程序虽然有差别,但主要的功能都是一样的。要实 现个性化的功能,在已有的软件基础上修改会节省多少时间呀!而每个程序各编一套,又浪费多少时间?如果,没有这些重复的工作量,世界 上的程序员至少可以节省%的工作量。同时,开放源代码也方便了大家的交流,阅读源代码应该是最直接最有效的学习途径。尤其是比较专业 的领域。
要开放源代码,下面几点比较重要: ×、语言要流行。 ×、语言的函数和类库统一。 ×、语言的语法和编译器要统一。 ×、编译器是否开 放源代码。 ×、API是否开放源代码。 ×、语言的可重用性、功能、友好性。
语言统一的必要性:如果大家都用一种编程语言,都用同样的函数,同样的类库,那么,大家的共同语言就会很多。大家只要学会一种语言, 一套函数,一套类库,就可以相互读懂源代码,这样,学习量是最少的。学习新的API浪费程序员大量的时间和精力,尤其是当这个API有大量 和其他API重复的功能的时候。
要增加代码的可重用性,要从下面几点着手: ×、代码的可读性。如格式、是否接近英语语法和单词。 ×、代码的表达能力,也就是简单性 ,能用最少的语句和单词实现同样的功能。 ×、代码的结构性,如函数、模块、类。
语言功能的强大从下面几点来说: ×、是否拥有大量的库支持。这是最重要的,要求编写任何功能的程序都有强大的库支持。 ×、语法功能 是否强大,比如是否有出错处理。是否有指针。
语言的三棵球源码竞猜源码友好性: ×、语言包的大小,语言包越小,学习越简单。 ×、语言是否有友好的编辑调试环境。 ×、语言的可视化和集成编程环境。
c语言:
从性能上说,除了汇编语言,c语言是最接近机器的语言。各种操作系统的编程接口的默认语言都是c语言。因此,用c语言编程,可以最大限 度发挥操作系统的能力。同时,由于绝大部分的商品软件都是c实现的,都有c编程接口,可以说,没有c不能实现的功能。
在linux环境中,c具有很好的开放源代码的条件,它有统一的编译器gcc,有强大但比较难掌握的编程环境emacs,有统一的API:posix和 linux接口。并且编译器和API是开放源代码的。
在linux上编写图形界面程序,有两个选择KDE和gnome,KDE更成熟,gnome支持多语言和面向对象的程序间的协同。
在windows环境中,现在统一到了vc上,但有一个缺点,windows的升级换代太快,从dos环境到windows
,从windows到windows,到windows,到.net。API常常变换,这样,在windows上的程序代码的寿命会比较短。并且vc的编译器和API 太复杂,难于掌握。
同时,由于c具有现代语言的大量特征,现在常常代替pasical作为教学的编程语言。
实际上,如果不深入学习,c也是一种很简单的语言。不学basic,直接学c完全没有问题。
和其他语言相比,c有多种编译器,多种操作系统API,多种语法和函数。学习的难度大,统一性差。
和java相比,c的语法不够丰富、现代。
java:
相对c,java作为现代语言,具有非常丰富的语法特征,如模块和类,不像c随操作系统和编译器的不同有极大差异,java是一个公司的产品 ,具有唯一的API,因此,java程序员没有语言隔阂。
相对跨平台的语言来说,java具有最好的图形界面编程API。
java所有的API都是类库,相对c的函数来说,是非常大的进步。java具有现代语言几乎所有的特征。
perl:
perl的最大特点是有强大的字符串模式匹配,是最好的文本文件的读取和生成语言。
perl具有很大的自由性,象英语一样有很大的随意性,
perl有一个强大的数据库接口和其他各种接口。
perl有最大量的程序库。
perl不适合编写大程序。
perl有一个著名的缺点是难懂,也有一个著名的优点是简练。
php:
我感到php是个怪胎,本来perl加嵌入html的功能就完全能实现php的功能,还要另创一种语言,加重了大家的学习负担。
php可以嵌入html,更容易编写服务器端程序。
php天然和web服务器以及mysql数据库相结合。
php可以动态生成图像。
python:
首先,python是网页导航源码双端APP源码和basic一样面向初学者的语言,和英语一样容易懂。
python具有和java一样的最丰富的语法。
python有和perl类似的简单性,但没有模式匹配。
python适合编写大程序。
python有和lisp相似的地方,它有将字符串作为程序执行的eval函数,可以对一个对象的所有数据进行保存,可以把函数作为参数传给另一 个函数。
python具有非常好的扩充性,python程序可以和c程序,以及java程序很好地结合。
tcl:
tcl具有最简单的语法,最好的和其他程序交互的能力,有编写图形界面程序的tk。
javascript:
编写动态网页的最佳工具。
lisp:
lisp的语法非常简单,只有简单的函数和参数的语句结构。
lisp数据和程序的界限模糊。
lisp可以深度嵌套。
prolog:
prolog是一种专门的语言。专门用来处理知识。
我感觉prolog是一种数据库的处理工具。
也是根据一些知识衍生出更多知识的推理工具。
basic:
现在最著名的basic是vb,
basic是简单的初级语言。
vb是快速的界面生成语言,是快速的数据库程序开发语言。
vba是vb的应用版,嵌入在offic中。编写offic上的程序很好用。
vbscript是vb的脚本语言,可以产生服务器端和客户端的动态网页。
basic的丑陋在于参数还是默认传地址。太危险。
delphi:
和vb一样是快速开发环境,但性能更好,功能更强大。
.net:
支持多种语言的统一的API类库,
可以编写webform程序,即所有的逻辑都在服务器端,传到客户端的是标准的html3.0,可以被各种浏览器支持。各程序组件间通过soap交换 消息。
--新增内容:
除了汇编语言外,c是最接近系统底层的语言,因此它是大部分程序的编程语言。c的缺点是没有统一的函数库,标准不统一,因此,同样是c程 序员,相互看不懂代码是很平常的事。
ada的出现就是为了解决统一标准的问题。有一个国际组织专门进行严格ada语言的认证来保证ada的统一。因此,ada编译器有很多种,但ada语 言程序用任何ada编译器编译都能通过。同时,ada的执行程序的效率和c比较接近。有人说比c要快,我想不可能,除非c用的库有问题。ada比c 排错能力更强,但c也有类似的功能。ada还有一个缺点,就是语言罗索,象cobol一样非常难看。
java是对c的大大的改进。有统一的标准,丰富的库,完全的面向对象。也继承了c的一些特点,无所不包的全功能,深入系统底层的编程的灵 活性。但因为java学习了c的深入系统底层的特点,它的语言就严格、呆板、罗索。另外,java要跨平台,它的速度就非常令人不满意,只能局 限在高级应用方面。在速度上,可以选择微软的.net和苹果的coco(可能拼写有错误)。他们也同样是底层的面向对象语言。
作为高级的应用程序,如果没有保密要求,脚本语言是最合适的。脚本语言因为不用编译,因此开发速度会比编译语言快很多。
basic和perl都是古老的脚本语言。basic被微软发扬光大了,但它的分时主图源码副图源码缺点是没有完整的面向对象特性,因此编写大型程序很困难。另外,微软 的产品肯定是“肿件”。perl被特别设计来进行文本的处理,文本处理能力非常强,但不适合编写大程序,语言风格也比较令人费解。
python定位于入门的编程语言,是basic的代替品,它具有和basic同样的简单性,并且编程语句更优雅。python有比较完整的面向对象特性, 可以用来编写大程序,因此有些大型的实用程序是python完成的,从加快开发速度的角度,可以代替c和java。python的另一个巨大的应用领域 是用来操作定制其他程序,这个能力basic也有,从这个角度说,python就是unix世界的basic。但python更进一步,和c的沟通能力非常好,任 何为c编写的接口能够很容易转化为python的接口。和java的接口有专门的python的java版,就是jython,jython可以和java本身一样使用各种 java资源。
ruby首先是smalltalk的替代品。有彻底的面向对象特性。另外,也努力作为perl、php、basic、python的替代品。
rebol是lisp的替代品,同时作为脚本语言的一员,有自己的独特之处,他的网络编程和图形用户界面编程是最强大的。
语言解析语言yacc、 html、xml、xlt、xul等也可以算作语言。
[edit]
各种语言的选择
如果编写对性能要求苛刻,或和操作系统结合紧密的程序,必然选择c。
如果编写到处可用的程序,选java。
如果编写大程序,可能的化尽量用python,不行了再用java和c。因为python带来了生产力。
编写文本的处理程序用perl。
编写知识的处理程序用prolog。
编写最灵活,最模糊的程序用lisp。
编写office程序用vba。
编写服务器端程序,php、perl、python、asp都是选择。
编写数据库程序用vb或delphi。
[edit]
各种语言的选择
如果要追求性能和程序的能力,要完全发挥操作系统的能力,使用c语言是合适的。在windows环境下用vc,在linux环境下用gcc。
如果不是追求和操作系统完美结合,而只是性能,又要追求跨平台性,那么仍然选择c,但可以选择跨平台的库,如qt、gtk、fox、wxwindows 。如果要编写游戏也有跨平台选择:SDL。
如果不满意c领域标准的不统一,不满意c的容易出错,不满意c的面向对象特征不彻底。如果不在乎跨平台,windows平台可以选择c#,mac平台 可以选择coco。如果需要跨平台,可以选择java。
如果需要跨平台,又要广泛的支持的话,选择java。
如果不在乎商业机密,应用目标也不是太苛刻的话,编写大型跨平台程序还有一个选择就是python或ruby。脚本语言,但是具有全面的库的支 持,有和c语言的方便的交互能力。他们和java相比,编程效率更高。同时因为没有编译,程序更方便修改。因为他们的库都是c实现的,也比 java有更高性能。同时,他们都是开源的,都是对商业应用友好的,也是简单的、方便定制的。也是不满意java的不可控制的越来越庞大的库 的又一个选择。
在linux下,最方便的工具语言是perl,它有强大的社区和代码库的支持。
如果只作为简单应用的工具语言,python和ruby是更好的选择,他们的跨平台移植性好,应用也比较广泛。其中python更适合入门和交流,长 期使用也不错。ruby是对python不满意的另一个选择,它提供了很多额外的功能。
如果要选择一个程序的嵌入语言,原来有lisp、basic和java,现在还可以选择python和ruby。
如果在要求动态解释执行语言,而又不想学其他语言的话,c程序员的选择是pike,java程序员的选择是beanshell。
在java平台,又想用脚本语言的话,可以用jython。
最正统的基于文档的语言或叫动态页面语言是javascript。
最专门的服务器端语言是php,当然也有很多其他选择。
xml语言以xul为最著名,dtml也算一个,你自己也可以用xml作为自己特殊用途的语言。比如jedit就用xml作为一种模式定制语言。xml语言是 一种比较先进的趋势,比现有的语言在特殊领域更高效。
要找容易实现的语言,lisp和tcl是选择。
lisp的数据和程序融为一体的能力和自由是其他语言都没有的。现在出现了一个lisp的现代化的变种:rebol。
如果有基于事实的编程的需要的话,prolog和clips是必然。
[edit]
我为什么选择了python
首先声明,我编程只编应用程序,就是代替自己工作的小程序。如果编写系统程序总会用到c或java的。
我喜欢脚本语言,脚本语言不用编译就可以运行,非常便于修改,而编程序是一种经常性的活动,程序编完后总在不断的修改中,没必要搞的 很隆重,还要编译。另外,脚本程序每个使用的人都可以随手拿来修改,不会出现还要去找源代码的情况。因此,c和java就被排除了。
我喜欢简单的语言,不喜欢为了编写简单的程序而去学习大量复杂的规定,需要大量的学习才会的语言不是好语言,是把人当机器看。c和java 都有严格但罗索的语法,有永远学不完的函数、类、库。让人看到就头大。而perl有各种怪里怪气的速记符号,程序常常让人头晕。简单的含 义除了容易学,还要功能丰富,常用到的东西要早就准备好,不用每个人都去写同样的数据结构程序等。python有丰富的数据类型,有完备的 面向对象的结构,有规则表达式等各种方便编程的模块。这个逻辑就是程序做的多,人做的就少,如果程序做的少,就要人做的多。这就是界 面友好的问题。容易上手,功能丰富是程序设计的很重要的目标,windows就是靠这个流行的。而python也很好的体现了这点。而perl象unix的 emac之类其它工具一样,功能强大,但太难学,太难懂。是比较违背人性的。
关于性能。现在cpu已经很强大了。除了很大的程序和系统程序,没必要关心性能。
关于功能。如果不是编写系统程序和贴近系统的程序,没必要使用操作系统特别提供的功能。c是可以干任何事情,但它编程效率低,复杂。
至于我为什么不用vb,因为vb太庞大了。我没必要实现一个小功能启动这么庞大的程序。太夸张。另外,vb没有类继承,虽然是应用编程,但 如果要编稍微大的程序,总会用到类继承的。
python得强大得扩展能力使对python得学习不会浪费。python经过简单得处理能使用各种得c和c++库,也可以被c和c++调用。python可以直接 使用java得类,也可以直接被java调用。这样,对python、java、c得学习和使用经验都不会被浪费,还能相互补充。python可以提高java和c 得编程效率,java和c可以补充python功能上得不足。python还可以和tcl直接交互,这种功能是内置得。期待python能简单的调用perl和php得 功能。能使用lisp和prolog更好。
[edit]
ruby 吸取了所有语言精华的语言 第二版
ruby 语言还是杂耍 ruby?:O ruby 日本人的玩意
ruby有
* perl的正则表达式
* python的语言的简单性可读性、最容易的扩展能力,强大的可移植性。
* php的嵌入功能和多种客户端
* smalltalk的纯面向对象语法和单继承
* lisp的无穷嵌套的语法,也就是函数式的语法。
* 用“块”来实现更快捷的数据结构的处理。不知道是不是scheme的宏功能。用块能更清楚的实现python的表处理功能。
* java和ada的线程编程
* java的安全编程
不得不承认ruby确实是个精彩的语言,它完全学会了lisp的所有编程都是函数的思想,smalltalk的所有东西都是对象的思想,perl的一个目的 多种手段的方法,python的简单化的“最少惊喜”的原则,java的多线程和安全控制的功能,tcl的容易扩展的功能,php的嵌入功能和强大客 户端的功能,最方便的shell命令的调用。
[edit]
ruby和python的比较
[edit]
python和ruby的相同点
* 都强调语法简单,都具有更一般的表达方式。python是缩进,ruby是类basic的表达。都大量减少了符号。
* 都是动态数据类型。都是有丰富的数据结构。
* 都具有c语言扩展能力,都具有可移植性,比perl的可移植性更好。也都可以作为嵌入语言。
* 都是面向对象的语言,都可以作为大项目的开发工具。
* 都有丰富的库支持。
* 也有最宽松的版权许可,除了一些工具属于GNU世界。
* 都有lisp特色的eval函数,也都能把函数作为参数。
* 也有图形界面的ruby的专门编辑器。
* 都获得了广泛的c库的支持。如qt、gtk、tk、SDL、FOX等,ruby计划实现SWIG接口。
* 都有完善的文档。
[edit]
和python相比ruby的优点
* 具有正则表达式和嵌入html的功能。python也有正则表达式,但没有ruby的应用方便和广泛。python的嵌入html项目才刚起步。ruby还有 apache的mod模块。ruby本身也实现和很多unix工具,如racc,doctools。比python更亲近linux。
* 比python功能更完整的面向对象的语法。
* ruby的整个库都是具有类继承的结构。
* 他的基本的数据类型和运算符都是可以重载的。
* ruby主要的功能都是通过对象的方法调用来实现的,而不是函数。python也在向这方面发展,但没有ruby做的彻底。
* ruby的类是更规范的单继承,还有接口等概念的实现。
* python可以实现在列表内的条件语句、循环语句,而ruby用“块”的方式来实现这个功能,比python的更灵活,更具有通用性。
* ruby具有类似lisp的彻底的函数方式的条件语句、循环语句等。语句的表达能力更强。
* 附带一些unix工具,如racc等。
[edit]
和python相比ruby的不足
* 最大的不足正是因为ruby的强大所引起的。它没有python的简单性好。比较复杂的面向对象语法、“块”语法的引入、正则表达式的引入、 一些简写标记都增加了语言的复杂性。
* python的缩进表达方式比ruby的basic的表达方式更让人悦目,ruby程序的满眼的end让人不舒服。当然,ruby认为end的方式比python更先 进。
* ruby还没有python的“自省”的能力,没有从程序文件中生成文档的能力。
* ruby没有国际化的支持。国际化支持在ruby的计划中。这是因为ruby的历史比python要短造成的。
* ruby没有类似jython的东西。
[edit]
python和ruby的语言的选择
从简单的就是好的来说,选python是没错的。python适合寻找简单语言的人,这很可能造成python更流行,因此也有更多的支持。但如果要追 求更强大的语法功能,则ruby是好的选择。因为ruby和python的哲学有很多相似的地方,先从python入手,尽量用python,如果python的能力 不足了,可以在找ruby。
ruby和python的比较,就像五笔和拼音输入法的比较。拼音作为入门的输入法和长久使用的输入法都没有问题。五笔适合更高要求的情况。如 果追求性能的不妨学学ruby。对编程语言感兴趣,想了解各种编程概念的学ruby也会很兴奋。
[edit]
php有什么好处
我一直认为php是一个垃圾,因为它只是实现了脚本语言得嵌入,却单独实现一种语言、实现大量得函数库,浪费了大量得开发人员得宝贵时间 来重复其他脚本已经实现了得功能,也浪费了php开发人员得大量学习时间,还要单独学一种只能存在于web服务器得语言,浪费了perl、 python得已有得使用经验。相似得还有pike,一种c得脚本语言,没什么新东西,还不如仍然用c编译器。
但我最近看书才了解php得独特得开发目标。
php为什么不直接用perl作脚本语言。是因为perl是一种unix语言,带有unix传统得字符神秘高深,让人难于学习。而编动态网页得人不见得会 用perl这种unix工具,他们可能只有html知识。php就简化了perl得语言,变成了一种简单友好得语言,免去了人们学习perl得困难。
php为什么不选python作脚本。因为python是一种面向对象得语言,大量得功能都要涉及面向对象概念,而web应用只是简单得实现客户机逻辑 和显示功能。没必要涉及面向对象得复杂概念。函数是最简单,最容易理解得,因此,php倾向于所有得功能都用函数来解决,而不是用对象来 解决。这有点象c和c++之争。应该承认,函数在实现简单功能得时候是最有利得工具,它得语句量最少。
php定位于以html为用户界面,充当各种服务器得客户端,实现得是传统得客户端编程得任务。它有pop、smtp、ftp、多种数据库等各种服务器 得客户端得函数,也有、pdf生成,xml处理等这种必要得功能。这些都是其他脚本比不上php得地方。
我几乎没用过php,说得不对,请指教。
[edit]
ada语言草述
ada语言我看了他的介绍。
ada语言和c一样是一种编译语言,他们最后编译出的执行文件的机器码都很小。因此现在众多的语言只有c很ada能比较。
和c相比,ada的特点是可靠、可移植。
他的可靠是通过比其他语言都强大的类型,每种类型还都可以象数据库字段一样进行强类型、范围的检查。以此来保证在编译中就发现错误。
它有强大的标准化组织,严格认证ada编译器的标准。有多线程能力。
适于编写实时程序。
但和c相比太复杂、罗嗦,因此注定不能流行。
[edit]
多脚本语言的大统一及疑问
现在各种脚本语言太多了,有必要进行整合,parrot是一个好的想法。.net也是好的想法。它为各种脚本提供了一个统一的虚机,为各种脚本 语言提供了基于“类”的相互调用,为各种脚本提供了统一的类库。
现在各种脚本语言只是提供了对c语言的交互性,这种交互也是费劲的和效果不好的。比如python、perl、ruby等都提供了对c的交互功能。脚 本语言之间的交流障碍重重。而类似.net的东西,提供了非常容易的各种脚本的相互利用的途径,避免了很多的代码的重复编写。这种标准平 台的力量是很大的,这种标准平台为什么没有在开源领域首先出现呢?众多的脚本正是开源的特点和优势,为什么这种问题要微软来解决呢? 前面有人提出了类似的问题,在linux中为什么至今没有好用的类似ODBC的东西呢?
可能这种整合只有商业公司有能力实现吧。
我的理解是,如果有创新思想的人都拿他的想法去卖钱了,因此,在开源中只剩下了模仿的人。kde是模仿windows,koffice是模仿office, linux是模仿unix,gcc、bash等也全都是模仿,以及gstep等,还有freedos、atheos等也是模仿,wxwindows、SDL也是模仿。我想知道开源社 区有没有自己的创新?我所知道的创新是zope,但zope最初也是商业产品,后来才开源的。perl是创新,python是创新,但还有什么呢?是不 是开源领域只有hack,没有creator?
[edit]
.net介绍
.net所实现的java的功能
可控代码 跨平台的虚机和伪码免费赠送命令行编译器 纯面向对象语言 对xml和xml web services的支持 和jsp对应的asp.net 网页上的程序 一套统一的中间件环境。
asp.net跟jsp不是同一个层次上的web技术, asp.net使用完善的事件响应机制,WinForms类似的 WebForm技术,只有JSF跟Asp.net有可比性。
.net未实现的java功能
免费的集成开发环境 多厂家支持,跨平台的成熟度
免费的IDE, #develop , ASP.net的有MS的WebMatrix 而免费开源的CLR实现,有MS自己的XP,FreeBSD,MacOS下的实现(原理演示不能进行商 业应用), Novell下的Mono项目,已经发布了Beta1版本,在-6- 将会发布Release1; 还有GNU的一个.net实现!!
[edit]
.net实现的java不具备的功能
多语言支持 强大的集成开发环境。在windows上媲美本机程序的速度。 对COM的支持,对vs的继承 对widows form 、web form、服务器端程序 的图形直观编程。
[edit]
相对vs6的改进
统一了集成开发环境,使c++程序也具有了vb的友好性。
[edit]
xml各种技术介绍
xml:
xml是统一格式的结构化数据的文本文件。
基于xml的程序,数据结构是开放的,方便不同程序处理同一种文件,这样,程序之间可以达到高水平的协作。
xml现在成为了各行各业统一数据格式的基础。
xml发展出了完善的语法,它用DTD或scheme来界定xml的标记语言。用uri来唯一确定一个xml格式。用css或XLT来转换xml格式,xlink和 xpointer等来建立xml的链接,用xpath来定位xml中的数据。
xhtml:
是严格符合xml格式的html。
RDF:
基于xml的元数据描述语言。方便交换结构化数据。方便交换知识。
RDF是用主语、谓语、宾语来描述知识的。
SVG:
xml格式的矢量图形格式。
SMILE:
xml格式的各种多媒体在时间线上的协同。
xmath:
xml格式的公式描述语言。
xml-rpc和soap:
以scape的mazilla使用的程序界面语言,基于xml格式,比html强大的多的描述图形界面的xml语言。它用css来换肤,用DTD来实现多语言界 面,用javascript来实现程序逻辑,以此编写跨平台的可方便定制界面的程序,现在这个程序API功能已经很强大了,整个mazilla程序就是基 于xul的。
xaml:
MS在LongHorn平台的最新编程语言,将统一Windows与Web编程,直接使用
LongHorn下的浏览器进行执行, 跟XUL有类比性
[edit]
最先进的xml格式图形界面程序开发工具-xul
大家知道netscape程序,一个仅次于ie得浏览器,也有很多人知道mozilla,netscape得开放源代码版本。但很多人只是使用mozilla,不知道 mozilla另一个重要得功能--程序开发。在netscape开放源代码后三年mozilla得1。0版还没有问世,很多人讥笑他的超慢得开发速度,实际 上,mozilla酝酿出了一个超酷得新产品,可以看作是软件开发工具发展得另一个里程碑。
现在基于浏览器得三层开发结构非常流行,微软得.net得思路就是基于这个结构得。另外,不考虑服务器结构,就是基于网页得javascript小 程序也对人很有吸引力,这些产品得思路都是以html为用户界面,但开发人员常常苦恼于html太简陋。而mazilla得xul解决了这个问题。
xul是对html得扩展
Jmeter进阶·时间戳使用技巧汇总
JMeter进阶·时间戳使用技巧汇总
在JMeter测试中,时间戳函数是必不可少的工具。本文将简要概述时间戳功能和日期格式转换的技巧,以及内置时间戳函数的使用。时间戳与日期格式转换
1. 从日期到时间戳: 利用BeanShell Sampler,可以编写自定义脚本来将日期格式转换为位毫秒级时间戳,如需精确到秒数为,可使用格式 `${ __time(yyyy-MM-dd HH:mm, time)}`。 2. 从时间戳到日期: 遇到复杂场景时,可能需要自己编写java代码实现,将时间戳转换为日期格式,然后导出jar包到JMeter的扩展目录,通过Beanshell调用。时间戳函数应用实例
在教育公司的接口测试中,娇娇遇到开课时间要求,通过调整参数和使用时间戳函数,成功生成精确到秒级且秒数为的时间戳。内置时间戳函数
__time():生成时间戳和格式化,如 `${ __time(yyyy-MM-dd HH:mm:ss,)}` 为-- ::。
__timeShift():时间移位,如 `${ __timeShift(yy-MM-dd,--, P2D)}` 返回--。
__randomDate():随机日期,如 `${ __randomDate(yyyy-MM-dd,--,--)}` 生成--到--之间的日期。
使用BeanShell Sampler在测试中获取不同时间戳,例如获取一小时后的时间:`${ __longSum(${ __time()},${ __Random(,,)},)}`。 总之,这些时间戳技巧有助于满足各种测试场景,使接口测试更高效。如需更多帮助,可通过源码和实例深入理解。2025-01-18 19:56
2025-01-18 19:15
2025-01-18 18:55
2025-01-18 18:54
2025-01-18 18:00