前端请求接口post_接口自动化测试-WEB资讯专栏-DMOZ中文网站分类目录

为什么UI自动化维护成本更高?因为前端页面变化太快,而且UI自动化比较耗时(比如等待页面元素的加载、添加等待时间、定位元素、操作元素、模拟页面动作这些都需要时间)为什么接口自动化维护成本较低?因为接口较稳定,接口的响应时间基本上都是秒级、毫

(1)接口自动化测试的意义、前后端分离思想

接口自动化测试的优缺点:

优点:

  1. 测试复用性。

  2. 维护成本相对UI自动化低一些。

    为什么UI自动化维护成本更高?
    因为前端页面变化太快,而且UI自动化比较耗时(比如等待页面元素的加载、添加等待时间、定位元素、操作元素、模拟页面动作这些都需要时间)为什么接口自动化维护成本较低?
    因为接口较稳定,接口的响应时间基本上都是秒级、毫秒级别的,速度快,并且接口自动化本身也可以做一些有关联的操作、全流程的操作(比如:注册 --> 登录 --> 修改个人信息)。
    
  3. 回归方便。

  4. 可以运行更多更繁琐的测试。自动化的一个明显的好处是可以在较少的时间内运行更多的测试。

    优点1、优点3、优点4是接口自动化和UI自动化公有的优点。
    

缺点:

  1. 不能完全取代手工测试。(自动化永远不能替代手工测试,只是提高测试效率)
  2. 手工测试比自动化测试发现的缺陷更多,自动化测试不容易发现新的BUG。

GET请求和POST请求的区别:

  1. GET请求一般是从后台服务器上获取数据用于前端页面的展示(例如:看到列表页面等),POST请求是向服务器传送数据(登录、注册、上传文件、发布文章)。什么时候用GET,什么时候用POST取决于开发。无论用POST请求还是GET请求,都能完成对数据的增删改查,分不同的请求方式更多的是一种约定。
  2. GET请求的请求参数是拼接在url后面的,只能以文本的形式传递参数,请求参数会显示在地址栏,数据长度受限于url的长度,传递的数据量小(4KB左右,不同浏览器会有差异),POST请求的请求参数是放在request body里面,传递数据量大(默认8M),对数据长度也没有要求。GET请求可以在浏览器中直接访问,而POST请求只能借助工具完成(比如:postman、jmeter)。
  3. GET请求速度快,安全性不高;POST请求一般用于像登录这种安全性要求高的场合,请求不会被缓存,也不会保留在浏览器的历史记录中。
以前:get 查询;post 新增;put 编辑;delete 删除
现在:get 查询;post 新增 + 编辑 + 删除
或者:纯post走天下

前后端分离

开发模式

以前老的方式:

  • 产品经理 / 领导 / 客户提出需求(提出文字需求)

  • UI做出设计图

  • 前端工程师做html页面(用户能看到的页面)

  • 后端工程师将html页面套成jsp页面(前后端强依赖,后端必须要等到前端的html页面做好才能套jsp。如果html发生变更,就很麻烦,开发效率低)

    比如云商系统:

  • 集成出现问题

  • 前端返工

  • 后端返工

  • 二次集成

  • 集成成功

  • 交付

新的方式:

  • 产品经理 / 领导 / 客户提出需求(提出文字需求)
  • UI做出设计图
  • 前后端约定接口 & 数据 & 参数
  • 前后端并行开发(无强依赖,可前后端并行开发,如果需求变更,只要接口 & 参数不变,就不用两边都修改代码,开发效率高)
  • 前后端集成
  • 前端页面调整
  • 集成成功
  • 交付

??通过F12打开浏览器开发者工具进行抓包,返回数据是json格式的就是前后端分离,返回时html页面就是没有前后端分离。

微服务的概念:

将大模块切分成小模块。减少代码的耦合度,从而降低模块与模块之间的影响。原先是一个jar包里面包含所有模块,改一个模块就有可能影响其他模块,现在是将一个一个的模块都打成一个一个的jar包,模块与模块之间的交互通过接口,哪个模块出了问题,只需要修改那个模块的jar包,避免因为修改一个模块的代码导致其他模块出错。

(2)Python requests框架讲解

接口自动化requests环境搭建

接口自动化核心库:requests

安装requests库的方法:

方法一:

命令行安装,打开cmd或者终端,输入以下命令:

pip install requests -i 

tki3lqremlm.png

方法二:
在pycharm中安装,settings --> Project --> Project Interpreter --> 点击“+”号 --> 输入request安装

hgkeka2xicc.png

测试环境是否ok

# -*- coding:utf-8 -*-
# 作者:IT小学生蔡坨坨
# 时间:2021/1/7 21:48import requestsurl_toutiao = ""
# 方式一:
# result_toutiao = (url_toutiao)# 方式二:
result_toutiao = (url=url_toutiao)# 方式三:
# result_toutiao = (
#     "")# print(())
# print(type(()))  # <class "dict">
result = ()
print(result)
expect_result = "华晨金杯汽车花朵朵"
actual_result = result["data"][0]["comment"]["user_name"]
print(actual_result)
if expect_result == actual_result:print("pass!")
else:print("failed!")

响应超时timeout

import requests# V部落:http://182.92.178.83:8081/index.html
# 文章列表
url_v_article = ""
v_headers = {"Cookie": "studentUserName=ctt01; Hm_lvt_cd8218cd51f800ed2b73e5751cb3f4f9=1609742724,1609762306,1609841170,1609860946; adminUserName=admin; JSESSIONID=9D1FF19F333C5E25DBA60769E9F5248E"}
article_params = {"state": 1,  # -1:全部文章 1:已发表 0:回收站 2:草稿箱"page": 1,  # 显示第1页"count": 6,  # 每页显示6条"keywords": ""  # 包含的关键字}
keywords = ["大橘猫", "跑男", "牙"]
for keyword in keywords:article_params["keywords"] = keyword# headers和params是不定长的,根据定义的字典传参# timeout超时,单位为秒# 通过设置超时时间,告诉requests在经过多久后停止等待响应result = (url_v_article, headers=v_headers, params=article_params, timeout=30)print(())

JSON、URL、text、encoding、status_code、encoding、cookies

print(()) # 响应结果以json的形式打印输出
print() # 打印url地址
print() # 以文本格式打印服务器响应的内容
print() # 响应状态码
print() # 编码格式
print() # cookie

JSON(JavaScript Object Notation, JS 对象简谱) 是一种轻量级的数据交换格式。它基于 ECMAScript (欧洲计算机协会制定的js规范)的一个子集,采用完全独立于编程语言的文本格式来存储和表示数据。简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。 易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。

JSON格式在Python里面相当于字典类型。

JSON格式化:http://www.bejson.com/jsonviewernew/

url在线编码转换:

(3)get、post、put、delete请求方式的自动化实现

GET请求方式

# -*- coding:utf-8 -*-
# 作者:IT小学生蔡坨坨
# 时间:2021/1/7 21:48import requestsurl_toutiao = ""
# 方式一:
# result_toutiao = (url_toutiao)# 方式二:
result_toutiao = (url=url_toutiao)# 方式三:
# result_toutiao = (
#     "")# print(())
# print(type(()))  # <class "dict">
result = ()
print(result)
expect_result = "华晨金杯汽车花朵朵"
actual_result = result["data"][0]["comment"]["user_name"]
print(actual_result)
if expect_result == actual_result:print("pass!")
else:print("failed!")运行结果:
{"message": "success", "err_no": 0, "data": [{"comment": {"id": 6914864825282215951, "id_str": "6914864825282215951", "text": "藁城出国打工的人很多,重点检查藁城区!", "content_rich_span": "{"links":[]}", "user_id": 940799526971408, "user_name": "华晨金杯汽车花朵朵",}, "post_count": 0, "stick_toast": 1, "stable": True}
华晨金杯汽车花朵朵
pass!

POST请求方式

# -*- coding:utf-8 -*-
# 作者:IT小学生蔡坨坨
# 时间:2021/1/9 22:51import requestsurl_v_login = ""
# 定义参数,字典格式
payload = {"username": "sang", "password": "123"}
# Content-Type: application/json --> json
# Content-Type: application/x-www-form-urlencoded --> data
result = (url_v_login, data=payload)
# 将返回结果转为json格式
result_json = ()
print(result_json)  # {"status": "success", "msg": "登录成功"}
# 获取RequestsCookieJar
result_cookie = 
print(result_cookie, type(result_cookie))  # RequestsCookieJar
# 将RequestsCookieJar转化为字典格式
result_cookie_dic = (result_cookie)
print(result_cookie_dic)  # {"JSESSIONID": "D042C5FE4CFF337806D545B0001E7197"}
# 获取SESSION
final_cookie = "JSESSIONID=" + result_cookie_dic["JSESSIONID"]  # SJSESSIONID=D042C5FE4CFF337806D545B0001E7197
print(final_cookie)

PUT请求方式

# V部落_编辑栏目# 定义请求头,自动获取cookie的方法详情请看下文
headers = {"Cookie": "VBlog().get_cookie()"}
new_now_time = ("%Y%m%d%H%M%S", (()))
new_category_name = "更新栏目" + new_now_time
payload = {"id": 2010, "cateName": new_category_name}
.put("", headers=headers, data=payload)

DELETE请求方式

# 删除栏目
result = .delete("" + “2010”, headers=headers)
print(())  # {"status": "success", "msg": "删除成功!"}
("删除成功!", ()["msg"])

(4)接口自动化测试过程中cookie的处理

手动传入cookie的值(每次通过浏览器F12抓包,然后复制request header里面的cookie)

# -*- coding:utf-8 -*-
# 作者:IT小学生蔡坨坨
# 时间:2021/1/7 22:25import requests# V部落查询栏目
url_v_category = "all"
# 定制请求头
# 如果你想为请求添加HTTP头部,只要简单地传递一个字典给headers参数就可以了
v_headers = {"cookie": "studentUserName=ctt01; Hm_lvt_cd8218cd51f800ed2b73e5751cb3f4f9=1609742724,1609762306,1609841170,1609860946; adminUserName=admin; JSESSIONID=9D1FF19F333C5E25DBA60769E9F5248E"}
result = (url_v_category, headers=v_headers)
# 打印json格式的响应结果
print(())

kayuerfqt2p.png

cookie自动获取

# -*- coding:utf-8 -*-
# 作者:IT小学生蔡坨坨
# 时间:2021/1/9 22:51import requestsurl_v_login = ""
# 定义参数,字典格式
payload = {"username": "sang", "password": "123"}
# Content-Type: application/json --> json
# Content-Type: application/x-www-form-urlencoded --> data
result = (url_v_login, data=payload)
# 将返回结果转为json格式
result_json = ()
print(result_json)  # {"status": "success", "msg": "登录成功"}
# 获取RequestsCookieJar
result_cookie = 
print(result_cookie, type(result_cookie))  # RequestsCookieJar
# 将RequestsCookieJar转化为字典格式
result_cookie_dic = (result_cookie)
print(result_cookie_dic)  # {"JSESSIONID": "D042C5FE4CFF337806D545B0001E7197"}
# 获取SESSION
final_cookie = "JSESSIONID=" + result_cookie_dic["JSESSIONID"]  # SJSESSIONID=D042C5FE4CFF337806D545B0001E7197
print(final_cookie)

批量获取cookie脚本

# -*- coding:utf-8 -*-
# 作者:IT小学生蔡坨坨
# 时间:2021/1/9 23:26import requestsdef get_cookie(username, password):"""通过考试系统学生登录获取单个cookie"""url_login = ""payload = {"userName": username, "password": password, "remember": False}result = (url_login, json=payload)# result_json = ()# print(result_json)# 获取RequestsCookieJarresult_cookie = # print(result_cookie, type(result_cookie))  # RequestsCookieJar# 将RequestsCookieJar转化为字典格式result_cookie_dic = (result_cookie)# print(result_cookie_dic)  # {"SESSION": "YzFkM2IzN2QtZWY1OC00Nzc4LTgyOWYtNjg5OGRiZDZlM2E4"}# 获取SESSIONfinal_cookie = "SESSION=" + result_cookie_dic["SESSION"]  # SESSION=Mzc2...return final_cookie
# -*- coding:utf-8 -*-
# 作者:IT小学生蔡坨坨
# 时间:2021/1/9 23:23from test01.demo04_student_login import get_cookie
import osdef get_batch_cookies():"""批量获取cookie"""# 获取cookie之前,先将文件内容清空# with open(r"D:\Desktop\Testman_Study\API_auto\file\", "w") as cookies_info:#     ("")# 或者将文件删除(r"D:\Desktop\Testman_Study\API_auto\file\")# 读取csv文件with open(r"D:\Desktop\Testman_Study\API_auto\file\", "r") as user_info:for user in user_info:user_list = ().split(",")# 调用获取单个cookies的方法,传入注册好的用户名和密码cookies = get_cookie(user_list[0], user_list[1])# 将cookie追加写入文件with open(r"D:\Desktop\Testman_Study\API_auto\file\", "a") as cookies_info:(cookies + "\n")# 调用方法
get_batch_cookies()
(前提是这些账号和密码都是已经注册过的,可以直接登录)poopoo001,123456,1
poopoo002,123457,2
poopoo003,123458,3
poopoo004,123459,4
......
SESSION=ZmE3YmU4ZDctNDExZS00MDdhLWE0YjEtMjAyZjQxOTMxYmUx
SESSION=YjdkNTZhNTUtNGFmMi00MjVkLWEyNjctOTNiMmRmOTY1YTdm
SESSION=ZTJmMTYzMWEtZjUzOS00NTlhLWI0OWQtMzBmN2RkYmU4YmRi
SESSION=YTM0ZGRhOTctZjk5Ni00OWZhLTg1YTItZjUyMTMwZGE2MjVi
......

(5)不同类型请求参数的处理

# -*- coding:utf-8 -*-
# 作者:IT小学生蔡坨坨
# 时间:2021/1/7 22:25import requests# 文章列表
url_v_article = ""
v_headers = {"Cookie": "studentUserName=ctt01; Hm_lvt_cd8218cd51f800ed2b73e5751cb3f4f9=1609742724,1609762306,1609841170,1609860946; adminUserName=admin; JSESSIONID=9D1FF19F333C5E25DBA60769E9F5248E"}# 自定义url参数,定义一个字典,将参数拆分,再将字典传递给params变量即可
article_params = {"state": 1,  # -1:全部文章 1:已发表 0:回收站 2:草稿箱"page": 1,  # 显示第1页"count": 6,  # 每页显示6条"keywords": ""  # 包含的关键字}
keywords = ["大橘猫", "跑男", "牙"]
for keyword in keywords:article_params["keywords"] = keyword# headers和params是不定长的,根据定义的字典传参result = (url_v_article, headers=v_headers, params=article_params)print(())

t1snmxjemv4.png

(6)结合Python+Requests+Unittest框架做接口自动化测试

unittest框架结构:

2zv5esm0hby.png

代码地址:https://github.com/itcaituotuo/unittest_api

if _name_ == "__main__":

if __name__ == "__main__"的意思是:

  • 当.py文件被直接运行时,if __name__ == "__main__"下的代码块将被运行;
  • 当.py文件以模块形式被导入时,if __name__ == "__main__"下的代码块不被运行。

(7)接口自动化测试过程中高级断言

闭环断言(新增 --> 查询 --> 修改 --> 查询 --> 删除 -->查询)

    def test_article(self):# ①V部落_新增文章now_time = ("%Y%m%d%H%M%S", (()))title = "蔡坨坨" + now_timepayload = {"id": -1, "title": title, "mdContent": "文章内容", "state": 1, "htmlContent": "<p>文章内容</p>","dynamicTags": "", "cid": 62}headers = {"Cookie": VBlog().get_cookie()}result = self.("", headers=headers, data=payload)# ②查询文章url_v_article = ""article_params = {"state": 1,  # -1:全部文章 1:已发表 0:回收站 2:草稿箱"page": 1,  # 显示第1页"count": 6,  # 每页显示6条"keywords": title  # 包含的关键字title}result = (url_v_article, headers=headers, params=article_params, timeout=30)print(())  # 响应结果以json的形式打印输出ls = ()["articles"]act = 123# 查到新增的文章,说明新增成功for l in range(0, len(ls)):if ls[l]["title"] == title:act = "ok"article_id = ls[l]["id"]("ok", act)# ③编辑文章now_time = ("%Y%m%d%H%M%S", (()))title = "修改文章" + now_timepayload = {"id": article_id, "title": title, "mdContent": "修改内容", "state": 1, "htmlContent": "<p>修改内容</p>","dynamicTags": "", "cid": 62}headers = {"Cookie": VBlog().get_cookie()}self.("", headers=headers, data=payload)# 编辑完,查询文章url_v_article = ""article_params = {"state": 1,  # -1:全部文章 1:已发表 0:回收站 2:草稿箱"page": 1,  # 显示第1页"count": 6,  # 每页显示6条"keywords": title  # 包含的关键字title}result = (url_v_article, headers=headers, params=article_params, timeout=30)print(())  # 响应结果以json的形式打印输出ls = ()["articles"]act = 123# 查到修改过的文章,说明编辑成功for l in range(0, len(ls)):if ls[l]["title"] == title:act = "ok"article_id = ls[l]["id"]("ok", act)# ④查看文章详情article_id = str(article_id)result = self.("" + article_id, headers=headers)print(())if ()["title"] == title:act = "ok"(act, "ok")# ⑤删除文章payload = {"aids": article_id, "state": 1}result = .put("dustbin", headers=headers, data=payload)print(())act = ()["msg"](act, "删除成功!")

(8)通过生成可视化HTML测试报告

i34iqoi1hym.png

百度网盘链接:

链接:
提取码:p20c

# -*- coding:utf-8 -*-
# 作者:IT小学生蔡坨坨
# 时间:2021/1/10 13:45from reports import HTMLTestRunner
from case.exam_case.teacher_case import TeacherCase
import unittest
import os
import time# 创建测试套件
suite = ()# 添加测试用例,根据添加顺序执行
# 添加单个测试用例
# (TeacherCase("test_001_admin_login"))# 添加多个测试用例
s([TeacherCase("test_001_admin_login"),TeacherCase("test_002_insert_paper"),TeacherCase("test_003_select_paper"),])# 定义测试报告的存放的路径
path = r"D:\Desktop\Testman_Study\unittest_exam_system\reports"
# 判断路径是否存在
if not os.path.exists(path):# 如果不存在,则创建一个(path)
else:pass
# 定义一个时间戳用于测试报告命名
now_time = ("%Y-%m-%d-%H-%M-%S", (()))
reports_path = path + "\\" + now_time + "(exam_report).html"
reports_title = u"考试系统&V部落——测试报告"
desc = u"考试系统&V部落——接口自动化测试报告"
# 二进制写
fp = open(reports_path, "wb")
runner = (stream=fp, title=reports_title, description=desc)
# 运行
(suite)

postman、JMeter、requests总结:

  • postman:接口功能测试

  • JMeter:接口性能测试

  • requests:接口自动化

  • ??三个的共同特点:都能完成接口功能测试。

以上信息来源于网络,如有侵权,请联系站长删除。

TAG:接口测试

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/527053.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Windows虚拟服务器vm,史上最详细的虚拟机VMware12安装Windows7教程 | 心塞塞

首先你电脑必须安装了 VMware &#xff0c;推荐版本 VMware12 或者 VMware 11 版本&#xff0c;然后你还需要一个系统镜像&#xff0c;可以通过下面链接下载 Win7 的镜像&#xff0c;复制链接&#xff0c;打开迅雷新建任务即可下载&#xff1a;Windows7 64位1ed2k://|file|cn_w…

方法 手写promise_JS探索-手写Promise

无意间在知乎上刷到Monad这个概念&#xff0c;去了解了一下&#xff0c;前端的Promise就是一种Monad模式&#xff0c;所以试着学习一下手写一个Promise.本文内容主要参考于只会用&#xff1f;一起来手写一个合乎规范的Promise​www.jianshu.comPromise是什么所谓Promise&#x…

12如何隐藏dock栏_一键隐藏 iPhone 刘海和底部 Dock 栏,简洁又好看

技能&#xff1a; 隐藏刘海和底部dock 栏难度系数&#xff1a;2颗星适用系统&#xff1a;iOS 13(部分非iOS13也适用)最近&#xff0c;小雷打开手机&#xff0c;看到最多的关键词&#xff0c;就是&#xff1a;iOS13又双叒叕更新了。。。而且也看到不止一位网友晒这个有趣的新功能…

宝塔php安装那个合_使用宝塔面板安装nextcloud | 启用本地存储 | 安装smbclient

宝塔面板安装nextcloud | 启用本地存储使用宝塔面板搭建nextcloud服务后&#xff0c;在设置外部存储时总是无法启用本地存储。问题1&#xff1a;提示&#xff1a;“smbclient” 未安装。无法挂载 "SMB / CIFS", "SMB / CIFS 使用 OC 登录信息"。请联系管理…

mysql groupby 拼接_mysql groupby 字段合并问题(group_concat)

在我们的日常mysql查询中&#xff0c;我们可能会遇到这样的情况&#xff1a;对表中的所有记录进行分类&#xff0c;并且我需要得到每个分类中某个字段的全部成员。上面的话&#xff0c;大家看起来可能不太好懂&#xff0c;下面举一个例子来给大家说明。现在我们有一张表&#x…

mysql聚集索引 myisam_一句话说清聚集索引和非聚集索引以及MySQL的InnoDB和MyISAM

版权声明&#xff1a;本文为博主原创文章&#xff0c;未经博主允许不得转载。https://blog.csdn.net/21aspnet/article/details/89303988聚集索引和非聚集索引以及MySQL的InnoDB和MyISAM经常遇到有人向我咨询这个问题&#xff0c;其实呢&#xff0c;网上帖子很多&#xff0c;也…

ue4插件导入导出_Blender到UE4的无缝衔接

Hello . 大家好本文给大家介绍一下Send To Unreal插件我是Vee1简介Send To Unreal是Epic官方开发的用于Blender和UE4快速同步的插件&#xff0c;支持静态物体、骨骼物体、动画等等。省去了Blender导出-选择目录文件-UE4导入这个中间步骤&#xff0c;效率提升不是一般得多。插件…

mysql点击计数器_MySql计数器,如网站点击数,如何实现高性能高并发的计数器功能...

MySql计数器&#xff0c;如网站点击数&#xff0c;如何实现高性能高并发的计数器功能Clicks: 5338 Date: 2014-03-29 23:30:42 Power By 李轩LaneTagMysql计数器高性能现在有很多的项目&#xff0c;对计数器的实现甚是随意&#xff0c;比如在实现网站文章点击数的时候&#xff…

python 微服务架构_微服务架构(Python)

在后端开发方面&#xff0c;Java的使用呢要远比Python广泛&#xff0c;所以Java的微服务框架非常流行&#xff0c;但Python的微服务框架却很少有人问津。在大多数需要微服务的场合下直接用Java的各种工具就可以解决问题&#xff0c;但如果业务代码使用Python写的&#xff0c;那…

vue修改入口文件名字_webpack打包vue项目,可修改配置文件

问题&#xff1a;vue项目打包完成后&#xff0c;如需改变配置文件中的信息&#xff0c;比如域名修改(如下图config.js)&#xff0c;是不可能在配置文件中直接更改的&#xff0c;因为配置文件是前端写死的&#xff0c;这时只能手动更改项目中的配置&#xff0c;然后重新打包npm …

java判断正整数正则_Java正则验证正整数的方法分析【测试可用】

本文实例讲述了Java正则验证正整数的方法。分享给大家供大家参考&#xff0c;具体如下&#xff1a;package des;import java.util.regex.Matcher;import java.util.regex.Pattern;public class Num {/*** param args*/public static void main(String[] args) {// TODO Auto-ge…

java 官网下载jdk源码_openJDK之如何下载各个版本的openJDK源码

如果我们需要阅读openJDK的源码&#xff0c;那么需要下载&#xff0c;那么该去哪下载呢?现在JDK已经发展到版本10了&#xff0c;11已经处于计划中&#xff0c;如果需要特定版本的openJDK&#xff0c;它们的下载链接在哪呢?1.openJDK的项目图1 可以看到有openJDK6、openJDK7、…

java 最大分词算法_Java实现的最大匹配分词算法详解

本文实例讲述了java实现的最大匹配分词算法。分享给大家供大家参考&#xff0c;具体如下&#xff1a;全文检索有两个重要的过程&#xff1a;1分词2倒排索引我们先看分词算法目前对中文分词有两个方向&#xff0c;其中一个是利用概率的思想对文章分词。 也就是如果两个字&#x…

java jnotify_Jnotify文件监控的用法以及Jar文件导入的方法

简介Jnotiy, 支持动态监控(支持级联监控)文件夹和文件的jar包。在linux中&#xff0c;调用linux底层的jnotify服务。在windows中&#xff0c;需要添加附件的dll文件。因为通用的Maven仓库中没有此Jar文件&#xff0c;pom.xml文件需要如下配置&#xff1a;net.contentobjects.jn…

java 异常练习题_Java 异常(习题)

异常Key Point* 异常的概念和分类* 异常的产生和传递* 异常的处理* 自定义异常练习1. 填空Java 中所有的错误都继承自throwable类&#xff1b;在该类的子类中&#xff0c;Error类表示严重的底层错误&#xff0c;对于这类错误一般处理的方式是不要求我们对其处理Exception类表示…

mysql 半同步 主主_MySQL主从,半同步,主主复制

MySQL Replication我们知道&#xff0c;MySQL数据库的二进制日志记录着每一个明确或者潜在可能导致数据库发生改变的sql语句&#xff0c;因此我们可以基于二进制日志来实现mysql的主从一致。而我们在此提到的mysql的复制的简单过程就是&#xff1a;首先mysql的主服务器(Master)…

java 数据队列_Java 数据结构 - 队列

Java 数据结构 - 队列我们今天要讲的数据结构是队列&#xff0c;比如 Java 线程池任务就是队列实现的。1. 什么是队列和栈一样&#xff0c;队列也是一种操作受限的线性结构。使用队列时&#xff0c;在一端插入元素&#xff0c;而在另一端删除元素。1.1 队列的主要特性队列中的数…

java+set+split_阿里资深工程师教你如何优化 Java 代码!

原标题&#xff1a;阿里资深工程师教你如何优化 Java 代码&#xff01;作者 | 王超责编 | 伍杏玲明代王阳明先生在《传习录》谈为学之道时说&#xff1a;私欲日生&#xff0c;如地上尘&#xff0c;一日不扫&#xff0c;便又有一层。着实用功&#xff0c;便见道无终穷&#xff0…

myVariable是java标识符吗_java 标识符与变量

一、Java 标识符三要素1.标识符由字母、下划线(_)、美元符号($)或者字母组成。2.标识符应以字母、下划线(_)、美元符开头。3.标识符字符大小写敏感&#xff0c;长度无限制。标识符最重要的就是 见名知意并且不能与java关键字重名!二、Java 变量1.java变量是程序中最基本的单元。…

友盟统计java代码_SFAnalytics 分析友盟统计源码,反编译 SDK,还有部分没有 出来 android 259万源代码下载- www.pudn.com...

文件名称: SFAnalytics下载 收藏√ [5 4 3 2 1 ]开发工具: Java文件大小: 8023 KB上传时间: 2016-06-05下载次数: 0提 供 者: 花心大萝卜详细说明&#xff1a;分析友盟统计源码&#xff0c;反编译友盟统计SDK&#xff0c;还有部分没有反编译出来-Analysis their Allies s…