class和getClass()的区别

class和getClass()的区别前几天做项目,觉得自己都开发一年多了,还没有自己封装的类,感觉真是白做了,再加上,看到自己的代码,我都不忍心看,有的时候,还需要自己去读自己写的代码,乱乱糟糟的,实在不忍心看,没办法,重现在开始吧,把自己需要的,都封装起来,用到什么的时候,在哪来用,方便,快捷首先是自己封装的基类baseActivity,不废话,直接上代码(其他的就不贴出来了,只有这个地方有错误)packagecom.d

大家好,又见面了,我是你们的朋友全栈君。

前几天做项目,觉得自己都开发一年多了,还没有自己封装的类,感觉真是白做了,再加上,看到自己的代码,我都不忍心看,有的时候,还需要自己去读自己写的代码,乱乱糟糟的,实在不忍心看,没办法,重现在开始吧,把自己需要的,都封装起来,用到什么的时候,在哪来用,方便,快捷

首先是自己封装的基类baseActivity,不废话,直接上代码(其他的就不贴出来了,只有这个地方有错误)

package com.demo.XXX.XX.base;

import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.os.IBinder;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
import android.view.inputmethod.InputMethodManager;
import android.widget.EditText;

import com.demo.XXX.XXX.tools.LogUtil;
import com.demo.XXX.XXX.tools.ShareUtils;

/**
 * Created by XXX on 2016/9/26.
 */
public abstract class BaseActivity extends Activity {

    private String TAG;
    protected Context context;
    protected ShareUtils shareUtils;
    protected LayoutInflater inflater;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        context = this;
        inflater = LayoutInflater.from(context);
        TAG = getClass().getName();
        LogUtil.i("BaseActivity", TAG);
        shareUtils = new ShareUtils(context);

    }

    /**
     * 初始化控件或者数据
     */
    protected abstract void initView();

    /**
     * 初始化点击事件
     */
    protected abstract void setListener();

    /**
     * 单一的activity的跳转
     *
     * @param mClass 跳转的类
     */
    public void start_activity(Class<?> mClass) {
        startActivity(new Intent(context, mClass.getClass()));
    }

    /**
     * 带传递参数的跳转
     *
     * @param mClass 跳转类
     * @param key    跳转key值
     * @param value  跳转value值
     */
    public void start_activity(Class<?> mClass, String key, String value) {
        startActivity(new Intent(context, mClass).putExtra(key, value));
    }

    /**
     * 带传递参数的跳转
     *
     * @param mClass 跳转类
     * @param key    跳转key值
     * @param value  跳转value值
     */
    public void start_activity(Class<?> mClass, String key, int value) {
        startActivity(new Intent(context, mClass).putExtra(key, value));
    }

    /**
     * 带传递参数的跳转
     *
     * @param mClass 跳转类
     * @param key    跳转key值
     * @param value  跳转value值
     */
    public void start_activity(Class<?> mClass, String key, Bundle value) {
        startActivity(new Intent(context, mClass).putExtra(key, value));
    }

    /***
     * 点击空白处 隐藏软键盘
     * @param ev
     * @return
     */
    @Override
    public boolean dispatchTouchEvent(MotionEvent ev) {
        if (ev.getAction() == MotionEvent.ACTION_DOWN) {
            View v = getCurrentFocus();
            if (isShouldHideKeyboard(v, ev)) {
                hideKeyboard(v.getWindowToken());
            }
        }
        return super.dispatchTouchEvent(ev);
    }

    /**
     * 根据EditText所在坐标和用户点击的坐标相对比,来判断是否隐藏键盘,因为当用户点击EditText时则不能隐藏
     *
     * @param v
     * @param event
     * @return
     */
    private boolean isShouldHideKeyboard(View v, MotionEvent event) {
        if (v != null && (v instanceof EditText)) {
            int[] l = {0, 0};
            v.getLocationInWindow(l);
            int left = l[0],
                    top = l[1],
                    bottom = top + v.getHeight(),
                    right = left + v.getWidth();
            if (event.getX() > left && event.getX() < right
                    && event.getY() > top && event.getY() < bottom) {
                // 点击EditText的事件,忽略它。
                return false;
            } else {
                return true;
            }
        }
        // 如果焦点不是EditText则忽略,这个发生在视图刚绘制完,第一个焦点不在EditText上,和用户用轨迹球选择其他的焦点
        return false;
    }

    /**
     * 获取InputMethodManager,隐藏软键盘
     *
     * @param token
     */
    private void hideKeyboard(IBinder token) {
        if (token != null) {
            InputMethodManager im = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
            im.hideSoftInputFromWindow(token, InputMethodManager.HIDE_NOT_ALWAYS);
        }
    }
}

原本以为自己封装的不错,挺满意的,哈哈,我也有自己封装的代码了,以后在完善下,直接用这个框架做项目,那还不嗖嗖的,想想都觉得开森

开始在使用activity跳转的时候,用的自己封装好的start_activity方法,结果一盆凉水浇在了我的头上,直接报错

 android.content.ActivityNotFoundException: Unable to find explicit activity class {com.demo.neu/java.lang.Class};
 have you declared this activity in your AndroidManifest.xml?

找不到这个类?我明明已经在androidManifest里边注册了啊,为啥还提示找不到这个类,试试Google提供的startac方法,看看

竟然可以跳转,那为啥,我封装的不能跳转呢,也没有啥问题啊,把androidManifest里边的那个类删除,再次用Google的startactivity方法做跳转看看,结果报错

android.content.ActivityNotFoundException: Unable to find explicit activity class {com.demo.XXX/com.demo.XXX.XXX.
activity.LoginActivity}; have you declared this activity in your AndroidManifest.xml?

咦,错误竟然不一样,好吧,那就不是类没有注册的问题了,再看看自己封装的方法吧,仔细看的时候才发现,原来问题出在这里

    /**
     * 单一的activity的跳转
     *
     * @param mClass 跳转的类
     */
    public void start_activity(Class<?> mClass) {
        startActivity(new Intent(context, mClass.getClass()));
    }

而下边的封装

/**
     * 带传递参数的跳转
     *
     * @param mClass 跳转类
     * @param key    跳转key值
     * @param value  跳转value值
     */
    public void start_activity(Class<?> mClass, String key, String value) {
        startActivity(new Intent(context, mClass).putExtra(key, value));
    }

在单一跳转的哪里竟然使用了class.getClass(),去掉getClass(),运行成功,可以跳转,那么问题来了,class和getClass()有啥区别呢,

细心的你可能发现了,问题就在这里

com.demo.neu/java.lang.Class

com.demo.XXX/com.demo.XXX.XXX.activity.LoginActivity

这就是问题所在了,前边的报错是java里边的long类型,因为在long类型里边没有loginActivity这个类,所以出现错误,而后便是指定的一个具体的类,就是说没有在androidMainfest里边没有注册了

一个是类型里边的类,一个是具体的activity的类,当然错误不一样了,当然出现问题了

我替你们踩坑了,以后封装的小伙伴注意了,别再犯我这么低级的错误了,唉

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/148097.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 关于各种型号单片机delay函数不起作用问题的解决方法

    关于各种型号单片机delay函数不起作用问题的解决方法这里以单片机HT45F75为例://定义一个延时xms毫秒的延时函数voiddelay(unsignedintxms) //xms代表需要延时的毫秒数{   unsignedintx,y;   for(x=xms;x&gt;0;x–)           for(y=960/4;y&gt;0;y–)           {                     …

    2022年6月1日
    48
  • STM32中IIC协议[通俗易懂]

    IIC协议:接收器和发送器:物理层:SCL–时钟总线SDA–数据总线开始条件:SCL高电平,SDA由高变低停止条件:SCL高电平,SDA由低变高主机:用来产生SCL(发送数据和接收数据)从机:(发送数据和接收数据)总线空闲态:SDA为高电平(没有设备发送开始条件)写:1.主机发送开始条件2.发送从机地址(7位)+写

    2022年4月14日
    52
  • netty 书籍_pdf怎么把书签变成目录

    netty 书籍_pdf怎么把书签变成目录Netty权威指南第2版带书签目录完整版下载地址:https://pan.baidu.com/s/12h96bKAdKEGXHdqOskK3nw扫码下面二维码关注公众号回复100019获取分享码本书目录结构如下:第1章Java的I/O演进之路1.1I/O基础入门1.2Java的I/O演进1.3总结第2章NIO入门2.1传统的BIO编程2.2伪异步I/O编程2.3NIO编程2.4AIO编程2.54…

    2022年10月2日
    3
  • PCIe扫盲——Flow Control基础(一)

    PCIe扫盲——Flow Control基础(一)FlowControl即流量控制,这一概念起源于网络通信中。PCIe总线采用FlowControl的目的是,保证发送端的PCIe设备永远不会发送接收端的PCIe设备不能接收的TLP(事务层包)。也就是说,发送端在发送前可以通过FlowControl机制知道接收端能否接收即将发送的TLP。在PCI总线中,并没有FlowControl这样的机制,因此发送端并不知道当前时刻,接收端能否接收对应的TLP。因此,发送端只能先尝试发送,期间可能会被插入多个等待周期(接收设备尚未就绪等原因),甚至是重发(Re

    2022年5月15日
    32
  • idea mac 快捷键重置(mac重启快捷键是什么)

    智能提示⌘-&gt;command⇧-&gt;shift⌥-&gt;option⬆-&gt;上箭头⬇-&gt;下箭头⌃-&gt;Control编辑快捷键 说明 ⌘+F 在当前窗口查找 ⌘+⇧+F 在全工程查找 ⌘+⇧+⌥+N 查找类中的方法或变量 F3/⇧+F3 移动到搜索结…

    2022年4月12日
    66
  • 2021年Spring面试题70道「建议收藏」

    2021年Spring面试题70道「建议收藏」文章目录2021年Spring面试题70道前言Spring面试题内容1.谈谈你对Spring的理解?2.Spring的特点是什么?3.Spring的优缺点是什么?4.Spring由哪些模块组成?5.详细讲解一下核心容器(springcontext应用上下文)模块6.解释AOP模块7.解释JDBC抽象和DAO模块8.解释对象/关系映射集成(ORM)模块9.解释WEB模块10.Spring配置文件11.什么是SpringIoC容器。12.控制反转(IoC)有什么作用13.控制反转

    2022年10月9日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号