- 关于YII2使用mssql/SqlServer的问题
aisicongg
yiiSqlServer
场景:配置了多个db连接,包含mysql和mssql等多个。本人在配置使用mssql的的过程中发现表名和字段名自动转义成`分隔符。例如SELECT`id`,`username`FROM`user`该语句在mssql是无法执行的,因为mssql不支持`分隔符,这个时候你需要在yii2调用的时候指定对应的配置db,比如我的申请了SqlServer是db2,那么我的写法如下:$query->create
- mysql:破解数据库的密码!!!
qq_41051690
mysql燕十八运维
如何破解数据库的密码?步骤如下:(1)通过任务管理器或着服务器管理,关掉mysqld进程;(2)通过命令行+特殊参数开启mysqld;(3)此时,mysqld服务进程已经打开,并且不需要权限检查;(4)mysql-uroot无密码登陆服务器;(5)修改权限表A:usemysql;B:updateusersetPassword=password(‘111111’)whereUser=’root’;C
- ubuntu环境搭建四:安装和使用git
小坚学Linux
ubuntu环境搭建gitubuntugithub
1.安装gitsudoapt-getinstallgit2.配置git的名字和邮箱gitconfig--globaluser.name"jian"gitconfig--globaluser.email"
[email protected]"gitconfig--globalcore.editorvim提交内核patch的配置gitconfig--globaluser.name"RuijianLi"gi
- opencv入门(6) TrackBar调整图片和键盘响应
千殃sama
opencv学习笔记
文章目录1创建trackbar2使用userdata传入函数3键盘响应1创建trackbar1.trackbar名称2.创建在哪个窗口上3.拖动trackbar改变的值4.trackBar的最大值5.trackbar改变时的回调函数6.带入回调函数的数据,可以不用带,是一个void指针createTrackbar(“Valuebar”,“亮度调整”,&lightness,max_value,on_
- Java面试题100道及答案
编程大全
面试题java开发语言
一、Java基础Java17中的sealed类和record类的作用和区别?答案:sealed类:限制继承关系,通过permits指定允许的子类。示例代码:publicsealedclassShapepermitsCircle,Square{...};record类:不可变数据类,自动生成equals()、hashCode()和toString()。示例代码:publicrecordUser(St
- 08_Excel 导入 - 用户信息批量导入
耀耀_很无聊
【后端开发】Java碎碎念exceljava开发语言
08_Excel导入-用户信息批量导入1.VO类java复制编辑@Data@AllArgsConstructor@NoArgsConstructorpublicclassUserInfoBatch4ExcelReq{@ExcelProperty(value="用户姓名")@Schema(description="用户姓名")privateStringuserName;@ExcelProperty(
- MongoDB 常见查询语法与命令详解
夜影风
大数据(BigData)mongodb数据库
MongoDB作为文档型数据库,其查询语言基于BSON(二进制JSON)格式,与传统关系型数据库的SQL语法有较大差异。一、基本查询命令1.find():查询文档语法:db.collection.find(查询条件,投影)示例://查询users集合中所有文档db.users.find()//查询年龄大于25岁的用户,只返回姓名和年龄db.users.find({age:{$gt:25}},{na
- 【Go-策略模式】告别if/else hell,拥抱 Go 语言策略模式
c无序
Gogolang策略模式开发语言
引言:为什么你的代码像一棵巨大的圣诞树?想象一下,你正在为你的电商平台开发一个订单价格计算模块。最初,需求很简单:商品原价就是最终价格。但很快,业务部门提出了新的需求:新用户享受9折优惠。VIP用户享受8折优惠。大促活动期间,全场7折。你很自然地写出了这样的代码:funcCalculatePrice(userTypestring,isPromotionbool,pricefloat64)float
- java依赖注入方法
hqxstudying
log4jjavaspringioc依赖
依赖注入主要有以下几种方式,每种方式各有特点,适用于不同场景:构造函数注入方式:通过类的构造函数将依赖对象传入。示例:publicclassUserService{privatefinalUserRepositoryuserRepository;publicUserService(UserRepositoryuserRepository){this.userRepository=userRepos
- Maven的概念与核心配置
代码如疯.
mavenjava
安装步骤:1、安装jdk2、从官网中下载对应的版本3、解压安装,然后配置环境变量,将bin目录添加到path路径下4、在命令行中输入mvn-v,看到版本信息表示安装成功3、maven的基本常识3.1maven如何获取jar包maven通过坐标的方式来获取jar包,坐标组成为:公司/组织(groupId)+项目名(artifactId)+版本(version)--GAV组成,可以从互联网,本地等多种
- MySQL调优实战
fei飛fei飞
mysql数据库
各位小伙伴是否在工作中遇到过类似的问题?一个简单的用户查询居然用时15s,接到优化sql语句的任务又无从下手。今天,我们简单的讲讲MySql如何调优。sqlSELECT*FROMusersWHEREage>18ORDERBYcreate_timeDESC;如上图,一个简单的查询sql为啥用时如此之久呢,我们先看这个sql可能存在的问题。1.索引缺失或不合理问题:该查询涉及两个字段条件(age>18
- RabbitMQ实现路由模式发送接收消息
1.基础类publicclassRabbitMQHelper{publicstaticIConnectionGetConnect(){//连接工厂varfac=newConnectionFactory(){HostName=“127.0.0.1”,//IPPort=5672,//端口UserName=“xxx”,Password=“xxx”,VirtualHost=“/”};returnfac.C
- 高性能 List 转 Map 解决方案(10,000 元素)
快乐肚皮
list数据结构java
文章目录前言一、问题背景:为什么List转Map如此重要?二、基础方法对比:StreamvsFor循环三、性能优化关键点四、面试回答技巧前言遇到一个有意思的面试题,如标题所说,当10,000条数据的List需要转Map,如何完成高性能的转换,本文将深入探讨这个问题。一、问题背景:为什么List转Map如此重要?在Java开发中,List转Map是最常见的集合操作之一://常见场景ListuserL
- 缓存设计体系化知识(结合大厂面试+实战案例+简历包装)
@一叶之秋
Java架构师学习路线缓存面试spring简历包装实战案例缓存设计体系化
缓存设计体系化知识(结合大厂面试+实战案例+简历包装)一、缓存基础设计:键、值、更新策略1.核心知识(1)缓存键设计原则:分层命名(业务:模块:ID)、唯一、可读、避免过长(≤1024字节)案例:电商商品缓存键product:{id}:detail(分层清晰,支持按商品ID快速查询)进阶:动态键(如user:{id}:orders:{date}支持时间范围查询)(2)缓存值设计序列化:优先选Pro
- js filter()
码上心间
java前端javascript
listType(queryParams.value).then(response=>{filterTable.value=response.rows.slice(1);//只显示前3条数据;filterTable.value=filterTable.value.filter(item=>{returnwnSensorsList.value.some(sensorsgroup=>{returnse
- 用流式API优雅地在Java中组装数据
作为开发者,我们经常会遇到这样的场景:从数据库、微服务API或不同的文件里获取到了几份数据,它们之间通过某些ID相互关联。我们的任务是将它们“拼接”成一个完整的、信息丰富的视图。通常,我们的第一反应可能是这样://丑陋的嵌套循环Listresult=newArrayListfinalData=DataAssembler.source(users).data(orders).match((user,
- :checked=“true“
咔咔咔索菲斯
vue.js前端javascript
在Vue中,:checked="true"是通过v-bind(缩写:)绑定表单元素的checked属性,使其默认处于选中状态。具体说明如下:1.作用:动态设置复选框/单选框的选中状态-当isSelected为true时,复选框默认选中;为false时取消选中。-单选框通过表达式userGender==='male'的布尔值判断是否选中。2.与不使用v-bind的区别-:checked="true"
- CORS 问题解决--threejs 相关01
CORS问题解决–threejs相关01解决方法"C:\ProgramFiles\Google\Chrome\Application\chrome.exe"–disable-web-security--user-data-dir=C:\ProgramFiles\Google\Chrome\Application注:C:\ProgramFiles\Google\Chrome\Application为
- mysql 开启远程登录 ubuntu_ubuntu mysql新增用户并开启远程连接
weixin_39709367
mysql开启远程登录ubuntu
1、首先用root用户登录mysqlmysql-uroot-p输入密码后登录成功2、新建用户usemysql;selecthost,userfromuser;(查看现有用户)CREATEUSER'king'@'localhost'IDENTIFIEDBY'';(新建用户);selecthost,userfromuser;(再次查看用户)第一次第二次3、赋权限GRANTALLPRIVILEGESON
- ubuntu编译 aosp for x86, windows avd启动 aosp-qemu镜像
鲁班king666
ubuntuwindowslinux
编译aosp给出编译脚本10:38:36test@server:~/workspace/shell/build$catbuild_emulater.sh#!/bin/bashcd/home/suhui/workspace/aosp/x86_emulater/sourcebuild/envsetup.shlunchsdk_phone_x86_64-userdebugmake-j12810:38:39
- Ubuntu18.04/Mysql 5.7 建立主备模式Mysql集群
武昌库里写JAVA
面试题汇总与解析课程设计springbootvue.jslayui毕业设计
一、数据库的安装详见https://www.jianshu.com/p/5073177eedf2本文实验环境为阿里云的两台ubuntu18.04服务器:masterip:172.26.138.7slaveip:172.26.0.209二、修改Master的配置(#的行是我后增加的部分):编辑/etc/mysql/mysql.conf.d/mysqld.cnf[mysqld]user=mysqlpi
- 传输层协议:UDP
目录1、概念2、报文结构3、核心特性3.1无连接3.2不可靠交付3.3面向数据报3.4轻量级&高效3.5支持广播和组播4、典型应用场景5、优缺点分析6、与TCP的区别1、概念UDP(UserDatagramProtocol,用户数据报协议)主要目的:供一种简单、高效、无连接的数据传输服务。2、报文结构UDP头部:(8字节)源端口:(2字节)发送方应用程序的端口号。可选(可置为0),用于接收方回复时
- ASP学生信息管理系统完整实施指南
带虾条酱
本文还有配套的精品资源,点击获取简介:ASP学生信息管理系统,基于ActiveServerPages技术,为学校优化学生信息管理,提高工作效率。系统功能涵盖班级管理、成绩跟踪、权限设置等。各组件如list_fenban.asp、xj_update.asp、xj_add.asp、admin_user.asp、funoperate.asp、list_check_upd.asp、list_check_a
- EasyExcel分次插入Excel
Jerry_carry
exceljava
@GetMapping("/muiltAppend")publicStringmuiltAppend(){Stringfilename="multi_append_data.xlsx";//创建ExcelWriter对象ExcelWriterexcelWriter=EasyExcel.write(filename,User.class).build();//创建WriteSheet对象WriteS
- 设计模式-访问者模式
GodKeyNet
设计模式访问者模式
一.所用到的类访问者模式是一个多对多的关系1.所要被访问的类一个公共抽象类:属性和accept方法,用来接收访问者实现抽象类的N个类2.访问者类一个抽象接口里面定义要访问N个类的方法实现抽象接口的N个类二、是实现代码所要被访问的类的抽象类publicabstractclassUser{publicStringname;publicStringidentity;//身份publicStringcla
- mysql索引失效的场景
布拉多多
mysqlandroid数据库
在MySQL中,索引是提高查询性能的关键工具,但在某些情况下,索引可能会失效,导致查询性能下降。以下是一些常见的索引失效的场景:使用OR操作符如果查询中使用了OR操作符连接多个条件,且其中一个条件没有使用索引,或者索引无法有效使用,那么整个查询可能会导致索引失效。例如:SELECT*FROMusersWHEREage=25ORname='John';如果age和name字段上都有索引,但MySQL
- MCP 协议使用核心讲解
Code_Geo
服务器前端MCP协议
MCP协议使用核心讲解✅MCP协议的核心在于以下几个方面一、MCP请求结构(MCPRequest){"messages":[{"role":"user","content":"帮我查询一下上海的天气"}],"tools":[{"name":"weather_query","description":"查询天气","parameters":{"type":"object","properties":
- 1、 快速上手 [代码级手把手解析diffusers库]
Yuezero_
AIGC人工智能深度学习
快速上手Pipeline内部执行步骤后续更新计划diffusers是HuggingFace推出的一个diffusion库,它提供了简单方便的diffusion推理训练pipe,同时拥有一个模型和数据社区,代码可以像torchhub一样直接从指定的仓库去调用别人上传的数据集和pretraincheckpoint。除此之外,安装方便,代码结构清晰,注释齐全,二次开发会十分有效率。diffusers使用
- 大事件项目记录6-用户接口开发-更新用户密码
a_Dragon1
SpringBoot学习记录数据库springbootjavaintellij-idea
(6)更新用户密码。UserController.java:UserService.java:UserServiceInterface.java:@OverridepublicvoidupdatePwd(StringnewPwd){Mapmap=ThreadLocalUtil.get();Integerid=(Integer)map.get("id");userMapper.updatePwd(M
- Django REST framework - 渲染器
djangopython
渲染器的确定方式视图的有效渲染器集合始终被定义为一个类列表。当进入视图时,RESTframework会在传入请求上执行内容协商,确定最合适的渲染器以满足请求。内容协商的基本过程涉及检查请求的Accept头,以确定其期望在响应中接收的媒体类型。另外,也可以使用URL上的格式后缀来显式请求特定的表示形式,例如,URLhttp://example.com/api/users_count.json可能是一
- 关于旗正规则引擎中的MD5加密问题
何必如此
jspMD5规则加密
一般情况下,为了防止个人隐私的泄露,我们都会对用户登录密码进行加密,使数据库相应字段保存的是加密后的字符串,而非原始密码。
在旗正规则引擎中,通过外部调用,可以实现MD5的加密,具体步骤如下:
1.在对象库中选择外部调用,选择“com.flagleader.util.MD5”,在子选项中选择“com.flagleader.util.MD5.getMD5ofStr({arg1})”;
2.在规
- 【Spark101】Scala Promise/Future在Spark中的应用
bit1129
Promise
Promise和Future是Scala用于异步调用并实现结果汇集的并发原语,Scala的Future同JUC里面的Future接口含义相同,Promise理解起来就有些绕。等有时间了再仔细的研究下Promise和Future的语义以及应用场景,具体参见Scala在线文档:http://docs.scala-lang.org/sips/completed/futures-promises.html
- spark sql 访问hive数据的配置详解
daizj
spark sqlhivethriftserver
spark sql 能够通过thriftserver 访问hive数据,默认spark编译的版本是不支持访问hive,因为hive依赖比较多,因此打的包中不包含hive和thriftserver,因此需要自己下载源码进行编译,将hive,thriftserver打包进去才能够访问,详细配置步骤如下:
1、下载源码
2、下载Maven,并配置
此配置简单,就略过
- HTTP 协议通信
周凡杨
javahttpclienthttp通信
一:简介
HTTPCLIENT,通过JAVA基于HTTP协议进行点与点间的通信!
二: 代码举例
测试类:
import java
- java unix时间戳转换
g21121
java
把java时间戳转换成unix时间戳:
Timestamp appointTime=Timestamp.valueOf(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()))
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd hh:m
- web报表工具FineReport常用函数的用法总结(报表函数)
老A不折腾
web报表finereport总结
说明:本次总结中,凡是以tableName或viewName作为参数因子的。函数在调用的时候均按照先从私有数据源中查找,然后再从公有数据源中查找的顺序。
CLASS
CLASS(object):返回object对象的所属的类。
CNMONEY
CNMONEY(number,unit)返回人民币大写。
number:需要转换的数值型的数。
unit:单位,
- java jni调用c++ 代码 报错
墙头上一根草
javaC++jni
#
# A fatal error has been detected by the Java Runtime Environment:
#
# EXCEPTION_ACCESS_VIOLATION (0xc0000005) at pc=0x00000000777c3290, pid=5632, tid=6656
#
# JRE version: Java(TM) SE Ru
- Spring中事件处理de小技巧
aijuans
springSpring 教程Spring 实例Spring 入门Spring3
Spring 中提供一些Aware相关de接口,BeanFactoryAware、 ApplicationContextAware、ResourceLoaderAware、ServletContextAware等等,其中最常用到de匙ApplicationContextAware.实现ApplicationContextAwaredeBean,在Bean被初始后,将会被注入 Applicati
- linux shell ls脚本样例
annan211
linuxlinux ls源码linux 源码
#! /bin/sh -
#查找输入文件的路径
#在查找路径下寻找一个或多个原始文件或文件模式
# 查找路径由特定的环境变量所定义
#标准输出所产生的结果 通常是查找路径下找到的每个文件的第一个实体的完整路径
# 或是filename :not found 的标准错误输出。
#如果文件没有找到 则退出码为0
#否则 即为找不到的文件个数
#语法 pathfind [--
- List,Set,Map遍历方式 (收集的资源,值得看一下)
百合不是茶
listsetMap遍历方式
List特点:元素有放入顺序,元素可重复
Map特点:元素按键值对存储,无放入顺序
Set特点:元素无放入顺序,元素不可重复(注意:元素虽然无放入顺序,但是元素在set中的位置是有该元素的HashCode决定的,其位置其实是固定的)
List接口有三个实现类:LinkedList,ArrayList,Vector
LinkedList:底层基于链表实现,链表内存是散乱的,每一个元素存储本身
- 解决SimpleDateFormat的线程不安全问题的方法
bijian1013
javathread线程安全
在Java项目中,我们通常会自己写一个DateUtil类,处理日期和字符串的转换,如下所示:
public class DateUtil01 {
private SimpleDateFormat dateformat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
public void format(Date d
- http请求测试实例(采用fastjson解析)
bijian1013
http测试
在实际开发中,我们经常会去做http请求的开发,下面则是如何请求的单元测试小实例,仅供参考。
import java.util.HashMap;
import java.util.Map;
import org.apache.commons.httpclient.HttpClient;
import
- 【RPC框架Hessian三】Hessian 异常处理
bit1129
hessian
RPC异常处理概述
RPC异常处理指是,当客户端调用远端的服务,如果服务执行过程中发生异常,这个异常能否序列到客户端?
如果服务在执行过程中可能发生异常,那么在服务接口的声明中,就该声明该接口可能抛出的异常。
在Hessian中,服务器端发生异常,可以将异常信息从服务器端序列化到客户端,因为Exception本身是实现了Serializable的
- 【日志分析】日志分析工具
bit1129
日志分析
1. 网站日志实时分析工具 GoAccess
http://www.vpsee.com/2014/02/a-real-time-web-log-analyzer-goaccess/
2. 通过日志监控并收集 Java 应用程序性能数据(Perf4J)
http://www.ibm.com/developerworks/cn/java/j-lo-logforperf/
3.log.io
和
- nginx优化加强战斗力及遇到的坑解决
ronin47
nginx 优化
先说遇到个坑,第一个是负载问题,这个问题与架构有关,由于我设计架构多了两层,结果导致会话负载只转向一个。解决这样的问题思路有两个:一是改变负载策略,二是更改架构设计。
由于采用动静分离部署,而nginx又设计了静态,结果客户端去读nginx静态,访问量上来,页面加载很慢。解决:二者留其一。最好是保留apache服务器。
来以下优化:
- java-50-输入两棵二叉树A和B,判断树B是不是A的子结构
bylijinnan
java
思路来自:
http://zhedahht.blog.163.com/blog/static/25411174201011445550396/
import ljn.help.*;
public class HasSubtree {
/**Q50.
* 输入两棵二叉树A和B,判断树B是不是A的子结构。
例如,下图中的两棵树A和B,由于A中有一部分子树的结构和B是一
- mongoDB 备份与恢复
开窍的石头
mongDB备份与恢复
Mongodb导出与导入
1: 导入/导出可以操作的是本地的mongodb服务器,也可以是远程的.
所以,都有如下通用选项:
-h host 主机
--port port 端口
-u username 用户名
-p passwd 密码
2: mongoexport 导出json格式的文件
- [网络与通讯]椭圆轨道计算的一些问题
comsci
网络
如果按照中国古代农历的历法,现在应该是某个季节的开始,但是由于农历历法是3000年前的天文观测数据,如果按照现在的天文学记录来进行修正的话,这个季节已经过去一段时间了。。。。。
也就是说,还要再等3000年。才有机会了,太阳系的行星的椭圆轨道受到外来天体的干扰,轨道次序发生了变
- 软件专利如何申请
cuiyadll
软件专利申请
软件技术可以申请软件著作权以保护软件源代码,也可以申请发明专利以保护软件流程中的步骤执行方式。专利保护的是软件解决问题的思想,而软件著作权保护的是软件代码(即软件思想的表达形式)。例如,离线传送文件,那发明专利保护是如何实现离线传送文件。基于相同的软件思想,但实现离线传送的程序代码有千千万万种,每种代码都可以享有各自的软件著作权。申请一个软件发明专利的代理费大概需要5000-8000申请发明专利可
- Android学习笔记
darrenzhu
android
1.启动一个AVD
2.命令行运行adb shell可连接到AVD,这也就是命令行客户端
3.如何启动一个程序
am start -n package name/.activityName
am start -n com.example.helloworld/.MainActivity
启动Android设置工具的命令如下所示:
# am start -
- apache虚拟机配置,本地多域名访问本地网站
dcj3sjt126com
apache
现在假定你有两个目录,一个存在于 /htdocs/a,另一个存在于 /htdocs/b 。
现在你想要在本地测试的时候访问 www.freeman.com 对应的目录是 /xampp/htdocs/freeman ,访问 www.duchengjiu.com 对应的目录是 /htdocs/duchengjiu。
1、首先修改C盘WINDOWS\system32\drivers\etc目录下的
- yii2 restful web服务[速率限制]
dcj3sjt126com
PHPyii2
速率限制
为防止滥用,你应该考虑增加速率限制到您的API。 例如,您可以限制每个用户的API的使用是在10分钟内最多100次的API调用。 如果一个用户同一个时间段内太多的请求被接收, 将返回响应状态代码 429 (这意味着过多的请求)。
要启用速率限制, [[yii\web\User::identityClass|user identity class]] 应该实现 [[yii\filter
- Hadoop2.5.2安装——单机模式
eksliang
hadoophadoop单机部署
转载请出自出处:http://eksliang.iteye.com/blog/2185414 一、概述
Hadoop有三种模式 单机模式、伪分布模式和完全分布模式,这里先简单介绍单机模式 ,默认情况下,Hadoop被配置成一个非分布式模式,独立运行JAVA进程,适合开始做调试工作。
二、下载地址
Hadoop 网址http:
- LoadMoreListView+SwipeRefreshLayout(分页下拉)基本结构
gundumw100
android
一切为了快速迭代
import java.util.ArrayList;
import org.json.JSONObject;
import android.animation.ObjectAnimator;
import android.os.Bundle;
import android.support.v4.widget.SwipeRefreshLayo
- 三道简单的前端HTML/CSS题目
ini
htmlWeb前端css题目
使用CSS为多个网页进行相同风格的布局和外观设置时,为了方便对这些网页进行修改,最好使用( )。http://hovertree.com/shortanswer/bjae/7bd72acca3206862.htm
在HTML中加入<table style=”color:red; font-size:10pt”>,此为( )。http://hovertree.com/s
- overrided方法编译错误
kane_xie
override
问题描述:
在实现类中的某一或某几个Override方法发生编译错误如下:
Name clash: The method put(String) of type XXXServiceImpl has the same erasure as put(String) of type XXXService but does not override it
当去掉@Over
- Java中使用代理IP获取网址内容(防IP被封,做数据爬虫)
mcj8089
免费代理IP代理IP数据爬虫JAVA设置代理IP爬虫封IP
推荐两个代理IP网站:
1. 全网代理IP:http://proxy.goubanjia.com/
2. 敲代码免费IP:http://ip.qiaodm.com/
Java语言有两种方式使用代理IP访问网址并获取内容,
方式一,设置System系统属性
// 设置代理IP
System.getProper
- Nodejs Express 报错之 listen EADDRINUSE
qiaolevip
每天进步一点点学习永无止境nodejs纵观千象
当你启动 nodejs服务报错:
>node app
Express server listening on port 80
events.js:85
throw er; // Unhandled 'error' event
^
Error: listen EADDRINUSE
at exports._errnoException (
- C++中三种new的用法
_荆棘鸟_
C++new
转载自:http://news.ccidnet.com/art/32855/20100713/2114025_1.html
作者: mt
其一是new operator,也叫new表达式;其二是operator new,也叫new操作符。这两个英文名称起的也太绝了,很容易搞混,那就记中文名称吧。new表达式比较常见,也最常用,例如:
string* ps = new string("
- Ruby深入研究笔记1
wudixiaotie
Ruby
module是可以定义private方法的
module MTest
def aaa
puts "aaa"
private_method
end
private
def private_method
puts "this is private_method"
end
end