Android开发学习-中级控件

Drawable

Android把所有能够显示的图形都抽象为Drawable类(可绘制的)。

这里的图形不止是图片,还包括色块、画板、背景等。
包含图片在内的图形文件放在res目录的各个drawable目录下,其中drawable目录一般保存描述性的XML文件,而图片文件一般放在具体分辨率的drawable目录下。例如:

同尺寸的手机有可能分辨率不同,手机分辨率就高不就低,因为分辨率低了屏幕会有模糊的感觉)。
drawable-ldpi里面存放低分辨率的图片 (如240x320),现在基本没有这样的智能手机了
drawable-mdpi里面存放中等分辨率的图片 (如320x480) ,这样的智能手机已经很少了
drawable-hdp里面存放高分辨率的图片(如480X800),一般对应4英寸~4.5英寸的手机(但不绝对,
drawable-xhdpi里面存放加高分辨率的图片 (如720x1280) ,一般对应5英寸~5.5英寸的手机。drawable-xxhdpi里面存放超高分辨率的图片 (如1080x1920),一般对应6英寸~6.5英寸的手机
drawable-xxxhdpi里面存放超超高分辨率的图片(如1440x2560) ,一般对应7英寸以上的平板电脑
基本上,分辨率每加大一级,宽度和高度就要增加二分之一或三分之一像素。

如果各目录存在同名图片,Android就会根据手机的分辨率分别适配对应文件夹里的图片。

在开发App时,为了兼容不同的手机屏幕,在各目录存放不同分辨率的图片,才能达到最合适的显示效果。例如,在drawable-hdpi放了一张背景图片bg,png (分辨率为480x800),其他目录没放,使用分辨率为480X800的手机查看该App界面没有问题,但是使用分辨率为720x1280的手机查看该App会发现背景图片有点模糊,原因是Android为了让bg,png适配高分辨率的屏幕,强行把bg.png拉伸到了720x1280,拉伸的后果是图片变模糊了。
在XML布局文件中引用图形文件可使用“@drawable/不含扩展名的文件名称”这种形式,如各视图的background属性、ImageView和lmageButton的src属性、TextView和Button四个方向的drawable***系列属性都可以引用图形文件。

形状shape图形

shape图形又称形状图形,它用来描述常见的几何形状,包括矩形、圆角矩形、圆形、椭圆等。用好形状图形可以让App页面不再呆板还可以节省美工不少工作量。
形状图形的定义文件放在drawable目录下,它是以shape标签为根节点的XML描述文件。根节点下定义了6个节点,分别是: size(尺寸)、stroke(描边)、corners (圆角)、solid (填充)、padding (间隔)、gradient(渐变),各节点的属性值主要是长宽、半径、角度以及颜色等。下面是形状图形各个节点及其属性的简要说明。
1. shape (形状)
shape是形状图形文件的根节点,它描述了当前是哪种几何图形。下面是shape节点的常用属性说明。

形状类型说明
rectangle矩形。默认值
oval椭圆。此时corners节点会失效
line直线。此时必须设置stroke节点,不然会报错
ring圆环

代码:

shape_rect_gold.xml
shape_rect_voal.xml 

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"><!--    指定形状内部填充颜色--><solid android:color="#ffdd66"></solid>
<!--    指定形状轮廓与颜色-->
<stroke android:width="1dp" android:color="#aaaaaa"/>
<!--    指定四个圆角的半径--><corners android:radius="10dp"/>
</shape>
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"android:shape="oval"><!--    指定形状内部填充颜色--><solid android:color="#ff66aa"></solid>
<!--    指定形状轮廓与颜色-->
<stroke android:width="1dp" android:color="#aaaaaa"/>
<!--    指定四个圆角的半径--></shape>
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"tools:context="com.pshdhx.middleComponent.ShapeActivity"><Viewandroid:id="@+id/view_content"android:layout_width="match_parent"android:layout_height="300dp"/><LinearLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"android:orientation="horizontal"><Buttonandroid:id="@+id/btn_rect"android:layout_width="0dp"android:layout_height="100dp"android:layout_weight="1"android:text="矩形"/><Buttonandroid:id="@+id/btn_oval"android:layout_width="0dp"android:layout_height="100dp"android:layout_weight="1"android:text="椭圆"/></LinearLayout></LinearLayout>
public class ShapeActivity extends AppCompatActivity implements View.OnClickListener {View view;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_shape);view = findViewById(R.id.view_content);view.setBackgroundResource(R.drawable.shape_rect_gold);findViewById(R.id.btn_rect).setOnClickListener(this);findViewById(R.id.btn_oval).setOnClickListener(this);}@Overridepublic void onClick(View v) {switch (v.getId()){case R.id.btn_rect:view.setBackgroundResource(R.drawable.shape_rect_gold);break;case R.id.btn_oval:view.setBackgroundResource(R.drawable.shape_rect_voal);break;}}
}

效果:

九宫格图片-.9图片

将某张图片设置成视图背景时,如果图片尺寸太小,则系统会自动拉伸图片将之填满背景。

可是一旦图片拉的过大,其画面容易变得模糊。

九宫格图片*.9.png可以控制边角处,不会进行拉伸。

上边缘线和左边缘线控制水平和竖直的拉伸效果,将其设置,可以不拉伸边角处。

下边缘线和右边缘线控制文字在显示区域内的效果。

图形状态列表

状态类型的属性名称说明适用的控件
state_pressed是否按下按钮Button
state_checked是否勾选复选框CheckBox、单选按钮RadioButton
state_focused是否获取焦点文本编辑框EditText
state_selected是否选中各控件通用

btn_selector.xml 

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android"><item android:state_pressed="true" android:drawable="@drawable/shape_rect_gold"/><item  android:drawable="@drawable/shape_rect_voal"/>
</selector>
android:background="@drawable/btn_selector"

复选框-checkbox

CompoundButton再xml中,主要使用以下两个属性

        checked:指定勾选状态true/false

        button:指定左侧勾选图标的图形资源,如果不指定,则系统默认。

CompoundButton在Java中主要使用下列4种方法

        setChecked

        setButtonDrawable:设置左侧勾选图标的图形资源

        setOnCheckedChangeListener:监听器

        isChecked

开关按钮-switch

textOn:设置右侧开启时的文本

textOff:设置左侧关闭时的文本

track:设置开关轨道的背景

thumb:设置开关表示的图标

单选按钮组

RadioGroup

RadioButton

文本输入框-EditText

监听文本编辑器

addTextChangedListener

beforeTextChanged:在文本改变之前触发

onTextChanged:在文本改变过程中触发

afterTextChanged:在文本改变之后触发

edit_phone.addTextChangedListener(new HideTextWatcher(edit_phone,11));private class HideTextWatcher implements TextWatcher{private EditText mView;private int maxLength;public HideTextWatcher(EditText v,int maxLength){this.mView = v;this.maxLength = maxLength;}
}

对话框

提醒对话框-AlertDialog

就是卸载时,带着确认或者是取消的对话框

<Buttonandroid:id="@+id/btn_alert_dialog"android:layout_width="match_parent"android:layout_height="wrap_content"android:onClick="alertDialog"android:text="点击弹出对话框"/><TextViewandroid:id="@+id/tv_result"android:layout_width="match_parent"android:layout_height="wrap_content"/>
public void alertDialog(View view) {AlertDialog.Builder builder = new AlertDialog.Builder(this);TextView tv_result = findViewById(R.id.tv_result);builder.setTitle("尊敬的用户");builder.setMessage("你真的要卸载吗?");builder.setPositiveButton("残忍卸载",(dialog,witch)->{tv_result.setText("我已残忍卸载");});builder.setNegativeButton("我再想一下",(dialog,witch)->{tv_result.setText("我再想一下吧!");});AlertDialog alertDialog = builder.create();alertDialog.show();}

setIcon:设置对话框的标题图标

setNeutralButton:设置中性按钮的信息,包括按钮文本和点击的监听器。

日期对话框-DatePickerDialog

<Buttonandroid:id="@+id/selectDateDialog"android:layout_width="match_parent"android:layout_height="wrap_content"android:onClick="selectDateDialog"android:text="请选择日期"/><DatePickerandroid:id="@+id/date_picker"android:layout_width="match_parent"android:layout_height="wrap_content"android:datePickerMode="spinner"android:calendarViewShown="false"/><Buttonandroid:layout_width="match_parent"android:layout_height="wrap_content"android:text="确定"android:onClick="selectDateClick"android:id="@+id/btn_ok"/><TextViewandroid:layout_width="match_parent"android:layout_height="wrap_content"android:id="@+id/tv_date"/>
public class DatePickerDialogActivity extends AppCompatActivity implements DatePickerDialog.OnDateSetListener {TextView tv_date;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_date_picker_dialog);tv_date = findViewById(R.id.tv_date);}public void selectDateClick(View view) {DatePicker date_picker = findViewById(R.id.date_picker);String desc = String.format("您选择的日期是%s",date_picker.getYear()+"-"+(date_picker.getMonth()+1)+"-"+date_picker.getDayOfMonth());tv_date.setText(desc);}public void selectDateDialog(View view) {DatePickerDialog dialog = new DatePickerDialog(this,this,2090,5,20);dialog.show();}@Overridepublic void onDateSet(DatePicker view, int year, int month, int dayOfMonth) {String desc = String.format("您选择的日期是%s",year+"-"+(month+1)+"-"+dayOfMonth);Toast.makeText(this,desc,Toast.LENGTH_LONG).show();tv_date.setText(desc);}
}

结果:

时间对话框-TimePickerDialog

<Buttonandroid:id="@+id/selectTimeDialog"android:layout_width="match_parent"android:layout_height="wrap_content"android:onClick="selectTimeDialog"android:text="请选择时间"/><TimePickerandroid:id="@+id/time_picker"android:layout_width="match_parent"android:layout_height="wrap_content"android:timePickerMode="spinner"/><Buttonandroid:layout_width="match_parent"android:layout_height="wrap_content"android:text="确定"android:onClick="selectTimeClick"android:id="@+id/btn_ok"/><TextViewandroid:layout_width="match_parent"android:layout_height="wrap_content"android:id="@+id/tv_time"/>
public class TimePickerActivity extends AppCompatActivity implements TimePickerDialog.OnTimeSetListener {TextView tv_time;TimePicker time_picker;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_time_picker);tv_time = findViewById(R.id.tv_time);time_picker = findViewById(R.id.time_picker);}public void selectTimeDialog(View view) {TimePickerDialog dialog = new TimePickerDialog(this,android.R.style.Theme_Holo_Light_Dialog_NoActionBar, this, Calendar.getInstance().get(Calendar.HOUR_OF_DAY),Calendar.getInstance().get(Calendar.MINUTE),true);dialog.show();}@RequiresApi(api = Build.VERSION_CODES.M)public void selectTimeClick(View view) {String desc = String.format("您选择的时间是%s",time_picker.getHour()+":"+time_picker.getMinute());tv_time.setText(desc);}@Overridepublic void onTimeSet(TimePicker view, int hourOfDay, int minute) {String desc = String.format("您选择的时间是%s",hourOfDay+":"+minute);tv_time.setText(desc);}
}

效果 

 

登录Demo 

布局文件:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"tools:context="com.pshdhx.middleComponent.LoginMainActivity"><RadioGroupandroid:id="@+id/rg_login"android:layout_width="match_parent"android:layout_height="@dimen/item_layout_height"android:orientation="horizontal"><RadioButtonandroid:id="@+id/rb_password"android:layout_width="0dp"android:layout_height="match_parent"android:layout_weight="1"android:checked="true"android:text="@string/login_by_password"android:textSize="@dimen/common_font_size" /><RadioButtonandroid:id="@+id/rb_verifycode"android:layout_width="0dp"android:layout_height="match_parent"android:layout_weight="1"android:text="@string/login_by_verifycode"android:textSize="@dimen/common_font_size" /></RadioGroup><LinearLayoutandroid:layout_width="match_parent"android:layout_height="@dimen/item_layout_height"android:orientation="horizontal"><TextViewandroid:layout_width="wrap_content"android:layout_height="match_parent"android:gravity="center"android:text="@string/phone_number"android:textColor="@color/black"android:textSize="@dimen/common_font_size" /><EditTextandroid:id="@+id/et_phone"android:layout_width="0dp"android:layout_height="match_parent"android:layout_weight="1"android:hint="@string/input_phone_number"android:inputType="number"android:maxLength="11"android:textSize="@dimen/common_font_size"/></LinearLayout><LinearLayoutandroid:layout_width="match_parent"android:layout_height="@dimen/item_layout_height"android:orientation="horizontal"><TextViewandroid:id="@+id/tv_password"android:layout_width="wrap_content"android:layout_height="match_parent"android:gravity="center"android:text="@string/login_password"android:textColor="@color/black"android:textSize="@dimen/common_font_size" /><EditTextandroid:id="@+id/et_password"android:layout_width="0dp"android:layout_height="match_parent"android:layout_weight="1"android:hint="@string/input_password"android:inputType="numberPassword"android:maxLength="6"android:textSize="@dimen/common_font_size"/><Buttonandroid:id="@+id/btn_forgetPassword"android:layout_width="wrap_content"android:layout_height="match_parent"android:textSize="@dimen/common_font_size"android:text="@string/forget_password"android:textColor="@color/black"android:background="@color/design_default_color_primary_dark"/></LinearLayout><CheckBoxandroid:id="@+id/ck_remember"android:layout_width="match_parent"android:layout_height="wrap_content"android:text="@string/remember_password"android:textColor="@color/black"android:textSize="@dimen/common_font_size"/><Buttonandroid:id="@+id/btn_login"android:layout_width="match_parent"android:layout_height="@dimen/item_layout_height"android:text="@string/login"android:textColor="@color/black"android:textSize="@dimen/common_font_size"/></LinearLayout>

 代码文件:

public class LoginMainActivity extends AppCompatActivity implements RadioGroup.OnCheckedChangeListener, View.OnClickListener {RadioGroup rg_login;TextView tv_password;EditText et_password;EditText et_phone;Button btn_forgetPassword;Button btn_login;CheckBox ck_remember;RadioButton rb_password;RadioButton rb_verifycode;private String mVerifyCode = "";@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_login_main);rg_login = findViewById(R.id.rg_login);btn_login = findViewById(R.id.btn_login);rb_password = findViewById(R.id.rb_password);rb_verifycode = findViewById(R.id.rb_verifycode);tv_password = findViewById(R.id.tv_password);et_password = findViewById(R.id.et_password);et_phone = findViewById(R.id.et_phone);et_phone.addTextChangedListener(new HideTextWatcher(et_phone, 11));et_password.addTextChangedListener(new HideTextWatcher(et_password, 6));btn_forgetPassword = findViewById(R.id.btn_forgetPassword);ck_remember = findViewById(R.id.ck_remember);rg_login.setOnCheckedChangeListener(this);btn_login.setOnClickListener(this);btn_forgetPassword.setOnClickListener(this);}@Overridepublic void onCheckedChanged(RadioGroup group, int checkedId) {switch (checkedId) {case R.id.rb_password:tv_password.setText(getString(R.string.login_password));et_password.setHint(getString(R.string.input_password));btn_forgetPassword.setText(getString(R.string.forget_password));ck_remember.setVisibility(View.VISIBLE);break;case R.id.rb_verifycode:tv_password.setText(getString(R.string.verifycode));et_password.setHint(getString(R.string.input_verifycode));btn_forgetPassword.setText(getString(R.string.get_verifycode));ck_remember.setVisibility(View.GONE);break;}}@Overridepublic void onClick(View v) {String phone = et_phone.getText().toString();String password = et_password.getText().toString();switch (v.getId()) {case R.id.btn_forgetPassword:if (phone.length() < 11) {Toast.makeText(this, "请输入正确的手机号码", Toast.LENGTH_SHORT).show();return;}if (rb_password.isChecked()) {Intent intent = new Intent(this, LoginForgetActivity.class);intent.putExtra("phone", phone);startActivityForResult(intent, 8888);} else if (rb_verifycode.isChecked()) {mVerifyCode = String.format("%6d", new Random().nextInt(999999));AlertDialog.Builder builder = new AlertDialog.Builder(this);builder.setTitle("请记住验证码");builder.setMessage("手机号" + phone + "本次验证码是" + mVerifyCode + ",请输入验证码");builder.setPositiveButton("好的", null);AlertDialog alertDialog = builder.create();alertDialog.show();}break;case R.id.btn_login:if(rb_password.isChecked()){if(!password.equals("111111")){Toast.makeText(this,"请输入正确的密码",Toast.LENGTH_SHORT).show();return ;}loginSuccess();}else if(rb_verifycode.isChecked()){if(!mVerifyCode.equals(et_password.getText().toString())){Toast.makeText(this,"请输入正确的验证码",Toast.LENGTH_SHORT).show();return ;}loginSuccess();}break;}}private void loginSuccess() {Toast.makeText(this,"登录成功",Toast.LENGTH_SHORT).show();}@Overrideprotected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {super.onActivityResult(requestCode, resultCode, data);}private class HideTextWatcher implements TextWatcher {private EditText mView;private int maxLength;public HideTextWatcher(EditText et_phone, int i) {this.mView = et_phone;this.maxLength = i;}@Overridepublic void beforeTextChanged(CharSequence s, int start, int count, int after) {}@Overridepublic void onTextChanged(CharSequence s, int start, int before, int count) {}@Overridepublic void afterTextChanged(Editable s) {if (s.toString().length() == maxLength) {ViewUtils.hideOneInputMethod(LoginMainActivity.this, mView);}}}
}

public class ViewUtils {public static void hideOneInputMethod(Context context, EditText mView) {InputMethodManager imm = (InputMethodManager) context.getSystemService(Context.INPUT_METHOD_SERVICE);imm.hideSoftInputFromWindow(mView.getWindowToken(), 0);}
}

 效果图:

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

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

相关文章

MySQL原理(三)锁定机制(1)综述

一、介绍&#xff1a; 1、锁的本质 业务场景中存在共享资源&#xff0c;多个进程或线程需要竞争获取并处理共享资源&#xff0c;为了保证公平、可靠、结果正确等业务逻辑&#xff0c;要把并发执行的问题变为串行&#xff0c;串行时引入第三方锁当成谁有权限来操作共享资源的判…

idea/webstorm 创建Vue实例 Unresolved type Vue 处理方法

1.电脑本地安装node.js 官网下载 2. 其他: 未排除变量,前期试错(以下步骤配置了,但不确定对解决问题是否有帮助)

C# .Net Framework webapi 全局日志

1.创建一个类名字叫做CustomActionFilter.cs /// <summary>/// /// </summary>public class CustomActionFilter : System.Web.Http.Filters.ActionFilterAttribute{/// <summary>/// /// </summary>/// <param name"actionExecutedContext&q…

C++ 入门(三)— 函数

文章目录 函数简介函数返回值Void 函数&#xff08;非值返回函数&#xff09;函数参数和参数局部范围函数的声明和定义具有多个代码文件的程序 函数简介 C 程序的方式工作。当程序遇到函数调用时&#xff0c;它将在一个函数内按顺序执行语句。函数调用是告诉 CPU 中断当前函数…

AI的安全应答之道

作者&#xff1a;统信UOS技术团队 2023,随着各种大语言模型的爆发&#xff0c;整个AI生态正处于从决策式AI进化到生成式AI的进程中。各类AI模型和AI应用层出不穷&#xff0c;也随之带来了与AI相关的各类潜在风险。AI开发和使用过程中的风险防范和治理&#xff0c;成为了不可忽…

【20240131】USB相机(查看设备列表、打开设备)

USB相机采集 1、v4l2查看设备列表2、查看具体设备信息3、在桌面打开USB相机 1、v4l2查看设备列表 打开终端&#xff0c;输入&#xff1a;v4l2-ctl --list-devices usb设备在Webcam: Webcam栏&#xff0c;分别是video9和video10&#xff0c;下一步&#xff1a;确定哪一个是接入…

vue2将一个页面作为组件来展示

这里使用vue2进行的实现 首先先建一个页面 <template><div>我是标题块111</div></template><script> export default {name: "index" } </script><style scoped></style>建好了页面&#xff0c;接下来在需要将这个页…

华为mate60 pro与小米14 pro 的巅峰对决

今天我们换下思路&#xff0c;不讲技术了&#xff01;我们一起讲讲手机&#xff01;小编暂时充当一下业余的数码咖。 今天我们就讲讲华为mate60 pro和小米14pro 这两款手机。这两款手机都是近期新出的发行版本&#xff0c;热度那是一直未减啊。 华为mate60 Pro 我们先说说这个…

分布式搜索引擎_学习笔记_1

分布式搜索引擎01 – elasticsearch基础 0.学习目标 1.初识elasticsearch 1.1.了解ES 1.1.1.elasticsearch的作用 elasticsearch是一款非常强大的开源搜索引擎&#xff0c;具备非常多强大功能&#xff0c;可以帮助我们从海量数据中快速找到需要的内容 例如&#xff1a; …

01、全文检索 ------ 反向索引库 与 Lucene 的介绍

目录 全文检索 ------ 反向索引库 与 LuceneSQL模糊查询的问题反向索引库反向索引库的查询 Lucene&#xff08;全文检索技术&#xff09;Lucene能做什么Lucene存在的问题Solr 和 Elasticsearch 与 Lucene 的关系 全文检索 ------ 反向索引库 与 Lucene MySQL一些索引词汇解释 …

Android进阶之路 - ViewPager2 比 ViewPager 强在哪?

我记得前年&#xff08;2022&#xff09;面试的时候有被问到 ViewPager 和 ViewPager2 有什么区别&#xff1f;当时因为之前工作一直在开发售货机相关的项目&#xff0c;使用的技术要求并不高&#xff0c;所以一直没去了解过 ViewPager2~ 去年的时候正好有相关的功能需求&#…

09. BI - 数据可视化,如何进行基本图形绘制

本文为 「茶桁的 AI 秘籍 - BI 篇 第 09 篇」 文章目录 EDA 作用可视化视图Python 进行可视化subplot Hi&#xff0c;你好。我是茶桁。 今天想给大家讲的是关于数据的可视化。在工作中很多时候我们不光要计算结果&#xff0c;还要把结果呈现出来&#xff0c;最好是一种图形化的…

机器学习_无监督学习之聚类

文章目录 介绍机器学习下的分类K均值算法K值的选取:手肘法用聚类辅助理解营销数据贴近项目实战 介绍机器学习下的分类 以下介绍无监督学习之聚类 聚类是最常见的无监督学习算法。人有归纳和总结的能力&#xff0c;机器也有。聚类就是让机器把数据集中的样本按照特征的性质分组&…

SpringBoot 使用WebSocket功能

实现步骤&#xff1a; 1.导入WebSocket坐标。 在pom.xml中增加依赖项&#xff1a; <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-websocket</artifactId> </dependency>2.编写WebSocket配…

TCP四次握手

TCP 协议在关闭连接时&#xff0c;需要进行四次挥手的过程&#xff0c;主要是为了确保客户端和服务器都能正确地关闭连接。 # 执行流程 四次挥手的具体流程如下&#xff1a; 客户端发送 FIN 包&#xff1a;客户端发送一个 FIN 包&#xff0c;其中 FIN 标识位为 1&#xff0c…

小程序软件测试应该怎么做?有什么作用?

近年来&#xff0c;随着移动互联网的快速发展&#xff0c;小程序软件的使用越来越广泛。无论是企业推广还是个人创作&#xff0c;小程序软件都具备了很大的潜力和市场空间。然而&#xff0c;在发布之前&#xff0c;进行充分的测试是至关重要的&#xff0c;以确保用户体验的顺畅…

【ARM Trace32(劳特巴赫) 使用介绍 3.1 -- 不 attach core 直接访问 memory】

文章目录 背景介绍背景介绍 在使用 trace32 时在有些场景需要不 attach core 然后去读写 memory,比如在某些情况下 core 已经挂死连接不上了,这个时候需要dump内存,这个时候需要怎做呢? print "test for memory access directly";SYStem.OPTION WAITRESET OF…

推荐系统|排序_多目标模型

文章目录 四大特征用户特征物品特征统计特征场景特征 训练过程中会遇到的问题 四大特征 ID相当于是人拥有的身份证&#xff0c;能够唯一确定出一个人 用户特征 主要指的是用户ID和用户画像 物品特征 主要是指物品ID和物品画像以及物品持有人。 统计特征 统计特征既包括对…

miniReact<一>

一、工程化配置 1.1 目录结构 1.1.1 Multi-repo VS Mono-repo Multi-repo 每个库有自己独立的仓库&#xff0c;逻辑清晰&#xff0c;协同管理复杂 Mono-repo 很方便管理不同独立的库的生命周期&#xff0c;会有更高的操作复杂度 项目有很多包&#xff0c;同时管理多个不同的…

数据可视化工具之选,三选一?

在数据可视化的世界中&#xff0c;选择一款合适的工具对于提升工作效率和洞察力至关重要。本文将对三款主流数据可视化工具进行详细比较&#xff0c;包括山海鲸可视化、Echarts和D3.js&#xff0c;以帮助您做出明智的选择。 山海鲸可视化 山海鲸可视化是一款免费且功能强大的…