怎么实现interface回调。 20C

3.5.3 实时预览 NET_DVR_RealPlay_V40
函 数: public int NET_DVR_RealPlay_V40(int lUserID, NET_DVR_PREVIEWINFO previewInfo, RealPlayCallBack
CallBack)
参 数: [in] lUserID NET_DVR_Login_V30 的返回值
[in] previewInfo 预览参数,包括码流类型、取流协议、通道号等
[in] CallBack 码流数据回调函数
public interface RealPlayCallBack {
public void fRealDataCallBack(int iRealHandle, int iDataType, byte[] pDataBuffer, int iDataSize);
}
[out] iRealHandle 当前的预览句柄
[out] iDataType 数据类型
[out] pDataBuffer 存放数据的缓冲区指针
[out] iDataSize 缓冲区大小

返回值: -1 表示失败,其他值作为 NET_DVR_StopRealPlay 等函数的句柄参数。接口返回失败请调用
NET_DVR_GetLastError 获取错误码,通过错误码判断出错原因。
说 明:
通过该接口设置实时流回调函数获取实时流音视频数据,然后可以通过播放库进行解码显示。

---------------------------------------以上是sdk说明
遇到的问题是:我现在lUserID和previewInfo参数都没问题了,就是这个回调的接口作为参数输入不知道怎么实现。
我现在实现的方法是:

    public class PlayCallBack : RealPlayCallBack
    {
        public IntPtr Handle
        {
            get
            {
                throw new NotImplementedException();
            }
        }

        public void Dispose()
        {
            throw new NotImplementedException();
        }

        public void FRealDataCallBack(int p0, int p1, byte[] p2, int p3)
        {
            //回调取到数据 调用SDK执行Input操作

            //执行的代码
        }
    }

然后实例化PlayCallBack playback=new PlayCallBack();
用playback作为参数输入的,但是调试的时候断点一直就没执行过FRealDataCallBack这个方法。导致一直无法显示画面。

3个回答

我用的是C#语言。。

自己找到方法 已解决。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
java - jna 中的回调问题
在jna中使用回调函数遇到的,使用回调函数用作事件监听.问题如下 比如有两个硬件,配套了dll,单独加载时回调正常,事件能正常监听, 如 A.dll上送input事件,A.class能监听到, B.dll上送inserted事件,B.class能监听到. 但如果在同一个项目中(同一个jvm),同时加载A.dll和B.dll时 只能监听到先加载的dll事件,后加载的则无法监听.(不触发回调) 不知道是不是jna的bug? 请问有高人能解答么?毕竟我也不太可能每一个硬件启动一个jvm,这样问题是解决了,但性能损耗和其他衍生问题会变的更麻烦. package com.sunyard.vtm.drivers.driver; import com.sun.jna.Callback; import com.sun.jna.Library; import com.sun.jna.Native; import com.sunyard.vtm.drivers.dictionary.FingerStatus; import com.sunyard.vtm.drivers.listener.IFingerListener; /** * 指纹扫描仪驱动(封装dll驱动) * * @author Efy */ public class FINDriver { /** * 继承jna的Library接口 逻辑: * <p>1.继承jna的Library后,注册dll库中的方法(输入参数,返回参数都必须与dll库一致) * <p>2.如需使用回调则需要dll提供注册回调方法 * * @author Efy */ public interface FinLibrary extends Library { /** * 启动设备 * @author Efy */ public abstract boolean open(); /** * 关闭设备 * @author Efy */ public abstract void close(); /** * 设备重置 * @author Efy */ public abstract boolean reset(); /** * 获取设备状态 * @author Efy */ public abstract FingerStatus getStatus(); /** * 获取指纹模板 * @author Efy */ public abstract boolean getFingerTemplete(String filePath); /** * 获取指纹特征 * @author Efy */ public abstract boolean getFingerFeature(String filePath); /** * 比对指纹 * @author Efy */ public abstract boolean compareFinger(String filePath); /** * 释放内存 * @author Efy */ public abstract void freeMemory(); /** * 回调监听 * @author Efy */ public abstract void addListener(FinEventListener listener); } /** * 注册回调接口监听 * @author Efy */ public interface FinEventListener extends Callback { /** * 回调接口 * @author Efy */ public abstract void callback(int arg0,int arg1,String data); } /** * 内部类实现FinEventListener接口,处理回调事件 * 使用时,先在此驱动中声明一个监听接口,由上层set此接口的实现 * * @author Efy */ public class CallBackInstance implements FinEventListener{ /** * 回调接口 * @author Efy */ @Override public void callback(int arg0,int arg1,String data){ switch (arg0) { case 1032: if(arg1 > 0){ iFingerListener.fingerComplete(data); }else{ iFingerListener.fingerFail(); } break; case 1044: iFingerListener.fingerMoveIn(); break; case 1045: iFingerListener.fingerMoveOut(); break; } } } private FINDriver() { // 构造时装载dll try{ lib = (FinLibrary) Native.loadLibrary("FingerLoader.dll", FinLibrary.class); System.out.println("装载FingerLoader.dll...成功."); }catch(UnsatisfiedLinkError e){ System.out.println("未找到FingerLoader.dll."); return; } // 实例化回调接口 if (callback == null) { callback = new CallBackInstance(); } } private static FinLibrary lib; private static FINDriver instance; private static CallBackInstance callback; private static IFingerListener iFingerListener; /** * 单例模式 * * @return */ public static FINDriver getInstance() { if (instance == null){ instance = new FINDriver(); } return instance; } public FinLibrary getLib() { return lib; } public CallBackInstance getCallback() { return callback; } public void setiFingerListener(IFingerListener iFingerListener) { lib.addListener(callback); FINDriver.iFingerListener = iFingerListener; } }
Activity在回调函数执行前被finish会引起崩溃吗?
假设有如下情景,activity实现了接口interface A,override了操作函数function( )(是对activity里面的一些变量进行处理),activity里面开了两个线程(Thread1,Thread2)进行网络访问,Thread2中网络访问有响应后执行了回调函数function,而Thread1网络访问有响应了之后执行的是把activity finish掉(回调也好,广播也好,反正就是把activity finish掉),那么恰好又是Thread1比Thread2快执行完毕,那么Thread2到了回调函数那里会不会有空指针之类的错误呢?
JAVA困惑很久的问题——属于上转型还是接口回调,还是两者皆有?
**在JAVA中若有一个接口:** interface Father { public void fatherFunc(); } **先继承该接口:** interface MyFather extends Father { public void setName(); } **再实现继承的MyFather接口:** public class Son implements MyFather{ public void fatherFunc(){ //对fatherFunc的实现方法 } public void setName(){ //对setName的实现方法 } } **最后调用接口:** MyFather myFather = new Son();//第一行 Father father = myFather;//第二行 **则对第一行而言,属于接口回调** **但对第二行而言,属于接口回调还是上转型,还是两者皆有?** **另:** 第一行myFather可以调用setName()方法,但在第二行father可不可以调用setName()方法?
JAVA:这个就是回调函数吗?我没看出来A调用B,B又回来调用A这种关系啊
public interface EventInfo { 接口 void showEventInfo(); } public class SearchInfo implements EventInfo { 实现类 public SearchInfo() { } public void showEventInfo() { System.out.println("发生了查询事件"); } } public class PrintInfo implements EventInfo { 实现类 public PrintInfo() { } public void showEventInfo() { System.out.println("发生了打印事件"); } } public class EventNotifier { private EventInfo ei; public EventNotifier() { } public void setEventInfo(EventInfo ei) { this.ei = ei; } public void doWork() { ei.showEventInfo(); } } public class Test { public static void main(String[] args) { PrintInfo pi = new PrintInfo(); SearchInfo si = new SearchInfo(); EventNotifier en = new EventNotifier(); en.setEventInfo(pi); en.doWork(); en.setEventInfo(si); en.doWork(); } } 最后输出: 发生了打印事件 发生了查询事件 这是我在网上看到的例子 但是没看出怎么就回调了呢 ?
interface接口使用,mvp模式下接口整理
有没有大神可以通俗的总结一下接口的使用,女汉子使用时候有点混淆了。接口可以作为连接桥梁,目前使用较多是适配器与activity之间的回调。mvp模式下也有很多运用,接口是规范的集合,实现接口的类覆写接口方法,但是实现起来有点混淆。
java关于接口参数的赋值问题
一直没有想明白这个怎么实现的。本来已经实现了接口的回调,但是在接口回调里面还有一个参数 ,那这个接口参数怎么和类的变量结合在一起呢? 比如: interface A { public void aa(B b); } class C { A a = null; B b = null; public void C(){ b = new B(); } public void setListener( A a){ this.a = a; } public void printThis(){ a.aa(b); } } class B { public void B(){ System.out.println("B"); } public void printThis(){ System.out.println("I'm B"); } } public class Test(){ public static void main(String[] args){ C c = new C(); c.setListener(new A(){ public void aa(B b){ b.printThis();//问题来了,这个地方的b是刚刚申明的,而且还没有实例化,如何才能将值付给它呢? } }); c.printThsi(); } } 我在使用高德地图的时候,就有这样的例子 AMapLocationListener mAMapLocationListener = new AMapLocationListener(){ @Override public void onLocationChanged(AMapLocation amapLocation) { String str = ""; TextView p1 = (TextView)findViewById(R.id.textView1); if (amapLocation != null) { Log.v("test info","amapLocation 不是空"); if (amapLocation.getErrorCode() == 0) { Log.v("test info","amapLocation 成功"); //定位成功回调信息,设置相关消息 amapLocation.getLocationType();//获取当前定位结果来源,如网络定位结果,详见定位类型表 amapLocation.getLatitude();//获取纬度 amapLocation.getLongitude();//获取经度 amapLocation.getAccuracy();//获取精度信息 } } 这里的amapLocation是在什么时候获得的值呢?
Android中Fragment和Activity间数据交换的问题
我想在Activity中读取Fragment中EditText中的字符串,找了一些资料都是使用接口回调的方法,下面程序附录中的第二种方法,我理解了一下发现第一种方法也可以实现,那么问什么非要使用接口回调的方法开实现数据共享而没有使用提供一个get方法来获取数据?是不是接口回调还有其他好处? Fragemnt的源码: import android.app.Fragment; import android.os.Bundle; import android.view.LayoutInflater; import android.view.View; import android.view.View.OnClickListener; import android.view.ViewGroup; import android.widget.EditText; import android.widget.Toast; public class Fragment1 extends Fragment { private EditText editText; @Override public void onCreate(Bundle savedInstanceState) { // TODO Auto-generated method stub super.onCreate(savedInstanceState); } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { // TODO Auto-generated method stub View view = inflater.inflate(R.layout.fragment1_layout, null); editText = (EditText) view.findViewById(R.id.editText1); return view; } //第一种方法 public String getData(){ return editText.getText().toString(); } // 第二种方法接口回调 public void getEditText(CallBack callBack) { callBack.getData(editText.getText().toString()); } public interface CallBack { public void getData(String str); } @Override public void onPause() { // TODO Auto-generated method stub super.onPause(); } } Activity代码 : import android.app.Activity; import android.app.FragmentManager; import android.app.FragmentTransaction; import android.os.Bundle; import android.view.Menu; import android.view.View; import android.view.View.OnClickListener; import android.widget.Toast; import com.example.class_fragment_activity_communicating_data.Fragment1.CallBack; public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); FragmentManager manager = getFragmentManager(); FragmentTransaction transaction = manager.beginTransaction(); final Fragment1 fragment1 = new Fragment1(); transaction.add(R.id.right, fragment1, "fragment1"); transaction.commit(); findViewById(R.id.A_button1).setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub fragment1.getEditText(new CallBack() {//通过接口回调获取Fragment中的值 @Override public void getData(String str) { // TODO Auto-generated method stub Toast.makeText(MainActivity.this, str, 1).show(); } }); // Toast.makeText(MainActivity.this, fragment1.getData(), 1).show(); //Fragment的实例调用Fragment的函数也能实现数据通信,为嘛要使用接口? 使用接口的好处? } }); } }
AndroidTV onfocus和onclick是会冲突吗?我用RecycleView写了焦点事件和点击事件但只能触发点击事件这什么问题呢?
如题,我为RecycleView的item重写了点击事件,在适配器里写了焦点事件,只实现其中一个都没问题,但同时使用就只有点击事件触发了,是因为onfocus和onclick冲突吗?我要怎么写可以同时触发焦点事件和点击事件呢?求大神赐教! 代码如下: ``` //焦点事件 holder.itemimages.setOnFocusChangeListener(new View.OnFocusChangeListener() { @Override public void onFocusChange(View v, boolean hasFocus) { if (hasFocus){ if(Build.VERSION.SDK_INT>=21) { ViewCompat.animate(v).scaleX(1.25f).scaleY(1.25f).translationZ(1).start(); } }else { ViewCompat.animate(v).scaleX(0.8f).scaleY(0.8f).translationZ(0).start(); } } }); ``` ``` recycleViewAdapter.setItemClickListener(new RecycleViewAdapter.OnRecycleViewClickListener() { @Override public void onItemClickListener(View view) { int position = recyclerView.getChildAdapterPosition(view); messagetext.setText("位置 + "+position); switch (position){ case 0: Toast.makeText(context, "第一个!",Toast.LENGTH_SHORT).show(); break; case 1: Toast.makeText(context, "第二个!",Toast.LENGTH_SHORT).show(); break; case 2: Toast.makeText(context, "第三个!",Toast.LENGTH_SHORT).show(); break; case 3: Toast.makeText(context, "第四个!",Toast.LENGTH_SHORT).show(); break; case 4: Intent intent = new Intent(MainActivity.this,MenuActivity.class); startActivity(intent); break; default: break; } } }); //RecycleView点击接口 public interface OnRecycleViewClickListener { void onItemClickListener(View view); } private OnRecycleViewClickListener listener; public void setItemClickListener(OnRecycleViewClickListener itemClickListener) { listener = itemClickListener; } @NonNull @Override public MyViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) { inflater = LayoutInflater.from(context).inflate(R.layout.item_main,parent,false); MyViewHolder myViewHolder = new MyViewHolder(inflater); //接口回调 if(listener != null){ inflater.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { listener.onItemClickListener(v); } }); } return myViewHolder; } ```
关于,Xe7调用jar转成的pas问题,代码如下,如何调用
扫描模块管理类BarcodeManager API说明 2.1.1 获取扫描模块管理对象 原 型 BarcodeManager getInstance() 功 能 获取BarcodeManager控制类,通过该类实现对扫描模块操作 参 数 参 数 说 明 返 回 BarcodeManager BarcodeManager 对象 注 释 通过该类实现对扫描模块操作 2.1.2 打开扫描设备 原 型 void Barcode_Open(Context context ,Callback callback) 功 能 打开扫描设备 参 数 参 数 说 明 context 调用者上下文 callback 数据回调接口对象,详见扫描模块接口说明 返 回 注 释 调用此方法将打开扫描设备(此方法将自动对扫描头上电) 2.1.3 关闭扫描设备 原 型 void Barcode_Close() 功 能 关闭条码设备 参 数 参 数 说 明 返 回 注 释 此方法将对自动对扫描头下电 2.1.4 开始扫描 原 型 void Barcode_Start() 功 能 出光开始扫描 参 数 参 数 说 明 返 回 注 释 2.1.5 停止扫描 原 型 void Barcode_Stop() 功 能 闭光停止扫描 参 数 参 数 说 明 返 回 注 释 ,pas JBarcodeManager_Callback = interface; JBarcodeManager = interface; [JavaSignature('android/jiebao/barcode/BarcodeManager')] JBarcodeManager = interface(JObject) ['{74A6AF5B-2107-4368-AC75-E0C950135691}'] { Property Methods } { methods } function checkScannerModelSetting: JString; cdecl; //()Ljava/lang/String; procedure Barcode_Open(context: JContext; dataReceive: JBarcodeManager_Callback); cdecl; //(Landroid/content/Context;Landroid/jiebao/barcode/BarcodeManager$Callback;)V procedure Barcode_Close; cdecl; //()V procedure Barcode_Start; cdecl; //()V procedure Barcode_Stop; cdecl; //()V function getScanIsReturnFactory: Boolean; cdecl; //()Z procedure setScanIsReturnFactory(b: Boolean); cdecl; //(Z)V procedure writeCommand(b: TJavaArray<Byte>); cdecl; //([B)V { Property } end; TJBarcodeManager = class(TJavaGenericImport<JBarcodeManagerClass, JBarcodeManager>) end; [JavaSignature('android/jiebao/barcode/BarcodeManager$Callback')] JBarcodeManager_Callback = interface(IJavaInstance) ['{DBB051A8-6805-4416-9C23-00324C436E62}'] { Property Methods } { methods } procedure Barcode_Read(P1: TJavaArray<Byte>; P2: JString; P3: Integer); cdecl; //([BLjava/lang/String;I)V { Property } end; TJIBarcodeManager_Callback = class(TJavaGenericImport<JIBarcodeManager_CallbackClass, JBarcodeManager_Callback>) end;
进入页面虚拟机崩溃,找不到错误,求大神帮改下源码,谢谢啦
import android.app.Activity; import android.os.AsyncTask; import android.os.Bundle; import android.support.v7.widget.DefaultItemAnimator; import android.support.v7.widget.RecyclerView; import android.support.v7.widget.StaggeredGridLayoutManager; import android.view.View; import android.widget.Toast; import org.json.JSONArray; import org.json.JSONException; import org.json.JSONObject; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.io.UnsupportedEncodingException; import java.net.URL; import java.util.ArrayList; import java.util.List; public class StartCanteenActivity extends Activity { private static final String urlPath = "http://www.imooc.com/api/teacher?type=4&num=30"; //private static final String urlPath = "http://14.117.17.161/json.php"; private RecyclerView mRvDemoMain; private MyRecyclerAdapter mAdapter; private List<NewsBeam> mList; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.canteen); mRvDemoMain = (RecyclerView) findViewById(R.id.canteen_recyclerview); new NewAsyncTask().execute(urlPath); initView(); } /** * 初始化本页面的控件 */ private void initView() { mRvDemoMain.setAdapter(mAdapter); // 设置RecyclerView的布局管理器 mRvDemoMain.setLayoutManager(new StaggeredGridLayoutManager(3, StaggeredGridLayoutManager.VERTICAL)); mRvDemoMain.setItemAnimator(new DefaultItemAnimator()); // 调用Adapter中的设置监听器的方法 mAdapter.setOnItemClickListener(new MyRecyclerAdapter.OnItemClickListener() { @Override public void onItemClick(View view, int position) { Toast.makeText(StartCanteenActivity.this, "click : " + position, Toast.LENGTH_SHORT).show(); } }); } /** * 实现网络的异步访问 */ class NewAsyncTask extends AsyncTask<String, Void, List<NewsBeam>> { @Override protected void onPostExecute(List<NewsBeam> newsBeams) { super.onPostExecute(newsBeams); MyRecyclerAdapter adapter = new MyRecyclerAdapter(StartCanteenActivity.this, newsBeams, mRvDemoMain); mRvDemoMain.setAdapter(adapter); } @Override protected List<NewsBeam> doInBackground(String... params) { return getJsonData(params[0]); } /** * 从 URL 中获取数据 * * @param url * @return */ private List<NewsBeam> getJsonData(String url) { List<NewsBeam> newsBeamsList = new ArrayList<NewsBeam>(); try { String jsonString = readStream(new URL(urlPath).openStream()); JSONObject jsonObject; NewsBeam newsBeam; jsonObject = new JSONObject(jsonString); JSONArray jsonArray = jsonObject.getJSONArray("data"); for(int i = 0; i < jsonArray.length(); i++) { jsonObject = jsonArray.getJSONObject(i); newsBeam = new NewsBeam(); newsBeam.newsIconUrl = jsonObject.getString("picSmall"); newsBeam.newsTitle = jsonObject.getString("name"); newsBeamsList.add(newsBeam); } } catch(IOException e) { e.printStackTrace(); } catch(JSONException e) { e.printStackTrace(); } return newsBeamsList; } /** * 从 inpustStream 获取的信息 * * @param is * @return */ private String readStream(InputStream is) { InputStreamReader isr; String result = ""; try { isr = new InputStreamReader(is, "utf-8"); BufferedReader br = new BufferedReader(isr); String line = ""; while((line = br.readLine()) != null) { result += line; } } catch(UnsupportedEncodingException e) { e.printStackTrace(); } catch(IOException e) { e.printStackTrace(); } return result; } } } import android.content.Context; import android.support.v7.widget.RecyclerView; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.ImageView; import android.widget.TextView; import java.util.ArrayList; import java.util.List; public class MyRecyclerAdapter extends RecyclerView.Adapter<MyRecyclerAdapter.MyRecyclerHolder> { protected LayoutInflater mLayoutInflater; private Context mContext; protected List<NewsBeam> mList; private List<Integer> mHeights; // 随机高度的集合 private ImgLoader mImgLoader; private int mStart; private int mEnd; public static String[] URLS; private boolean mFirstIn; private MyRecyclerAdapter(List<NewsBeam> mList) { this.mList = mList; } /** * 自定义一个OnItemClickListener的回调接口 */ public interface OnItemClickListener{ void onItemClick(View view, int position); } /** * 创建接口的成员变量 */ private OnItemClickListener mOnItemClickListener; /** * 设置监听器的方法 * @param listener listener */ public void setOnItemClickListener(OnItemClickListener listener){ this.mOnItemClickListener = listener; } /** * 构造方法 * @param context context * @param data data */ public MyRecyclerAdapter(Context context, List<NewsBeam> data,RecyclerView recyclerView) { this.mContext = context; this.mList = data; mLayoutInflater = LayoutInflater.from(mContext); mImgLoader = new ImgLoader(recyclerView); mLayoutInflater = LayoutInflater.from(mContext); mHeights = new ArrayList<Integer>(); // 向随机高度集合中添加随机数(100 ~ 400) for (int i = 0; i < mList.size(); i++) { mHeights.add((int) (100 + Math.random() * 300)); } URLS = new String[data.size()]; for(int i = 0; i < data.size(); i++) { URLS[i] = data.get(i).newsIconUrl; } mFirstIn = true; } /** * RecyclerView中条目的数量 * * @return count */ @Override public int getItemCount() { return mList.size(); } /** * 创建ViewHolder * * @param parent parent * @param viewType viewType * @return holder */ @Override public MyRecyclerHolder onCreateViewHolder(ViewGroup parent, int viewType) { // zz 测试 System.out.println("====onCreateViewHolder : " + viewType + " == " + parent); View view = mLayoutInflater.inflate(R.layout.recycler_item, parent, false); MyRecyclerHolder mHolder = new MyRecyclerHolder(view); return mHolder; } /** * 绑定ViewHolder * * @param holder holder * @param position position */ @Override public void onBindViewHolder(final MyRecyclerHolder holder, final int position) { // 为ViewHolder的父控件(也即一条Item)设置高度 ViewGroup.LayoutParams lp = holder.itemView.getLayoutParams(); lp.height = mHeights.get(position); holder.itemView.setLayoutParams(lp); holder.mIvItem.setImageBitmap(null); holder.mIvItem.setImageResource(R.mipmap.ic_launcher); String url = mList.get(position).newsIconUrl; holder.mIvItem.setTag(url); mImgLoader.showImgByAysncTask(holder.mIvItem, url); holder.mTvItem.setText(mList.get(position).newsTitle); // 调用条目的点击事件设置方法 setUpItemEvent(holder); // zz 测试 System.out.println("====onBindViewHolder : " + position + " == " + holder); } /** * 设置条目的点击事件(点按) * @param holder holder */ protected void setUpItemEvent(final MyRecyclerHolder holder) { if (mOnItemClickListener != null) { holder.itemView.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { int layoutPosition = holder.getLayoutPosition(); mOnItemClickListener.onItemClick(holder.itemView, layoutPosition); } }); } } /** * RecyclerView的ViewHolder类 */ public class MyRecyclerHolder extends RecyclerView.ViewHolder { ImageView mIvItem; TextView mTvItem; public MyRecyclerHolder(View itemView) { super(itemView); mIvItem = (ImageView) itemView.findViewById(R.id.id_image); mTvItem = (TextView) itemView.findViewById(R.id.id_name); } } }
哪位好心的大侠帮我看一下代码,不知道为什么一运行虚拟机就崩溃,谢谢啦
import android.content.Context; import android.os.AsyncTask; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.support.v7.widget.DefaultItemAnimator; import android.support.v7.widget.RecyclerView; import android.support.v7.widget.StaggeredGridLayoutManager; import android.view.View; import android.widget.Toast; import org.json.JSONArray; import org.json.JSONException; import org.json.JSONObject; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.io.UnsupportedEncodingException; import java.net.URL; import java.util.ArrayList; import java.util.List; public class StartCanteenActivity extends AppCompatActivity { private RecyclerView mRvDemoMain; private Context mContext; private List<NewsBeam> mList; private MyRecyclerAdapter mAdapter; private static final String urlPath = "http://www.imooc.com/api/teacher?type=4&num=30"; //private static final String urlPath = "http://14.117.17.161/json.php"; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.canteen); // 1. 初始化RecyclerView中要显示的数据 initData(); // 2. 初始化本页面的控件 initView(); } /** * 初始化RecyclerView中要显示的数据 */ private void initData() { } /** * 初始化本页面的控件 */ private void initView() { mRvDemoMain = (RecyclerView) findViewById(R.id.canteen_recyclerview); // 设置RecyclerView的Adapter mAdapter = new MyRecyclerAdapter(mContext,mList,mRvDemoMain); mRvDemoMain.setAdapter(mAdapter); // zz 测试 System.out.println("==== mRvDemoMain.setAdapter(mAdapter)执行完了"); mRvDemoMain.setLayoutManager(new StaggeredGridLayoutManager(3, StaggeredGridLayoutManager.VERTICAL)); mRvDemoMain.setItemAnimator(new DefaultItemAnimator()); // 调用Adapter中的设置监听器的方法 mAdapter.setOnItemClickListener(new MyRecyclerAdapter.OnItemClickListener() { @Override public void onItemClick(View view, int position) { Toast.makeText(StartCanteenActivity.this, "click : " + position, Toast.LENGTH_SHORT).show(); } }); } /** * 实现网络的异步访问 */ class NewAsyncTask extends AsyncTask<String, Void, List<NewsBeam>> { @Override protected void onPostExecute(List<NewsBeam> newsBeams) { super.onPostExecute(newsBeams); MyRecyclerAdapter adapter = new MyRecyclerAdapter(StartCanteenActivity.this, newsBeams, mRvDemoMain); mRvDemoMain.setAdapter(adapter); } @Override protected List<NewsBeam> doInBackground(String... params) { return getJsonData(params[0]); } /** * 从 URL 中获取数据 * * @param url * @return */ private List<NewsBeam> getJsonData(String url) { List<NewsBeam> newsBeamsList = new ArrayList<NewsBeam>(); try { String jsonString = readStream(new URL(urlPath).openStream()); JSONObject jsonObject; NewsBeam newsBeam; jsonObject = new JSONObject(jsonString); JSONArray jsonArray = jsonObject.getJSONArray("data"); for(int i = 0; i < jsonArray.length(); i++) { jsonObject = jsonArray.getJSONObject(i); newsBeam = new NewsBeam(); newsBeam.newsIconUrl = jsonObject.getString("picSmall"); newsBeam.newsTitle = jsonObject.getString("name"); newsBeamsList.add(newsBeam); } } catch(IOException e) { e.printStackTrace(); } catch(JSONException e) { e.printStackTrace(); } return newsBeamsList; } /** * 从 inpustStream 获取的信息 * * @param is * @return */ private String readStream(InputStream is) { InputStreamReader isr; String result = ""; try { isr = new InputStreamReader(is, "utf-8"); BufferedReader br = new BufferedReader(isr); String line = ""; while((line = br.readLine()) != null) { result += line; } } catch(UnsupportedEncodingException e) { e.printStackTrace(); } catch(IOException e) { e.printStackTrace(); } return result; } } } import android.content.Context; import android.support.v7.widget.RecyclerView; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.ImageView; import android.widget.TextView; import java.util.ArrayList; import java.util.List; public class MyRecyclerAdapter extends RecyclerView.Adapter<MyRecyclerAdapter.MyRecyclerHolder> { protected LayoutInflater mLayoutInflater; private Context mContext; protected List<NewsBeam> mList; private List<Integer> mHeights; // 随机高度的集合 private ImgLoader mImgLoader; private int mStart; private int mEnd; public static String[] URLS; private boolean mFirstIn; private MyRecyclerAdapter(List<NewsBeam> mList) { this.mList = mList; } /** * 自定义一个OnItemClickListener的回调接口 */ public interface OnItemClickListener{ void onItemClick(View view, int position); } /** * 创建接口的成员变量 */ private OnItemClickListener mOnItemClickListener; /** * 设置监听器的方法 * @param listener listener */ public void setOnItemClickListener(OnItemClickListener listener){ this.mOnItemClickListener = listener; } /** * 构造方法 * @param context context * @param data data */ public MyRecyclerAdapter(Context context, List<NewsBeam> data,RecyclerView recyclerView) { this.mContext = context; this.mList = data; mLayoutInflater = LayoutInflater.from(mContext); mImgLoader = new ImgLoader(recyclerView); mLayoutInflater = LayoutInflater.from(mContext); mHeights = new ArrayList<Integer>(); // 向随机高度集合中添加随机数(100 ~ 400) for (int i = 0; i < mList.size(); i++) { mHeights.add((int) (100 + Math.random() * 300)); } URLS = new String[data.size()]; for(int i = 0; i < data.size(); i++) { URLS[i] = data.get(i).newsIconUrl; } mFirstIn = true; } /** * RecyclerView中条目的数量 * * @return count */ @Override public int getItemCount() { return mList.size(); } /** * 创建ViewHolder * * @param parent parent * @param viewType viewType * @return holder */ @Override public MyRecyclerHolder onCreateViewHolder(ViewGroup parent, int viewType) { // zz 测试 System.out.println("====onCreateViewHolder : " + viewType + " == " + parent); View view = mLayoutInflater.inflate(R.layout.recycler_item, parent, false); MyRecyclerHolder mHolder = new MyRecyclerHolder(view); return mHolder; } /** * 绑定ViewHolder * * @param holder holder * @param position position */ @Override public void onBindViewHolder(final MyRecyclerHolder holder, final int position) { // 为ViewHolder的父控件(也即一条Item)设置高度 ViewGroup.LayoutParams lp = holder.itemView.getLayoutParams(); lp.height = mHeights.get(position); holder.itemView.setLayoutParams(lp); holder.mIvItem.setImageResource(R.mipmap.ic_launcher); String url = mList.get(position).newsIconUrl; holder.mIvItem.setTag(url); mImgLoader.showImgByAysncTask(holder.mIvItem, url); holder.mTvItem.setText(mList.get(position).newsTitle); // 调用条目的点击事件设置方法 setUpItemEvent(holder); // zz 测试 System.out.println("====onBindViewHolder : " + position + " == " + holder); } /** * 设置条目的点击事件(点按) * @param holder holder */ protected void setUpItemEvent(final MyRecyclerHolder holder) { if (mOnItemClickListener != null) { holder.itemView.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { int layoutPosition = holder.getLayoutPosition(); mOnItemClickListener.onItemClick(holder.itemView, layoutPosition); } }); } } /** * RecyclerView的ViewHolder类 */ public class MyRecyclerHolder extends RecyclerView.ViewHolder { ImageView mIvItem; TextView mTvItem; public MyRecyclerHolder(View itemView) { super(itemView); mIvItem = (ImageView) itemView.findViewById(R.id.id_image); mTvItem = (TextView) itemView.findViewById(R.id.id_name); } } }
关于rmi的疑惑,请熟悉的朋友指点一下
第一我想问的是 调远程的方法时,是把远程的实现类下载到客户端再执行吗,我怎么感觉是这样的,在服务器端写的system.out.println 会在客户端输出,在服务器端没出现,在客户端调用的方法时,如果此方法在服务端调用了其它方法时(在客户端没有执行的环境,只能在服务器那执行,如连数据库操作)会在客户端报错,客户端没有这个环境你当然不能执行啊, 我想像的rmi,只要你把服务器方法返回的结果给客户端就行了,至于中间的调用过程怎么拿到客户端去执行啊,求大家说明一下这是什么状况,想不通了 下面是部分代码 服务接口 public interface Service extends Remote{ public List<Entity> list(String id,String name); } 服务实现 public class LiebaoServiceImpl implements Service,Remote,Serializable{ /** * uid */ private static final long serialVersionUID = 1L; @Override public List<Entity> list(String id,String name) { // TODO Auto-generated method stub System.out.println("coming..........."); System.out.println("coming..........."); List<Entity> list = new ArrayList<Entity>(); Test t = new Test(); list = t.test();//执行业务操作并返回(这里会在客户端出错,到客户端执行了) return list; } } //绑定jndi服务 public class InitJndiService { public void init(){ Properties pros = new Properties(); pros.put(Context.INITIAL_CONTEXT_FACTORY, "com.sun.jndi.rmi.registry.RegistryContextFactory"); pros.put(Context.PROVIDER_URL, "rmi://localhost:1099"); try { LocateRegistry.createRegistry(1099); InitialContext ini = new InitialContext(pros); Service service = new ServiceImpl(); ini.bind("Service", service); ini.close(); } catch (NamingException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (RemoteException e) { // TODO Auto-generated catch block e.printStackTrace(); } }; } 客户端调用: public static void main(String[] arg){ System.setProperty(Context.INITIAL_CONTEXT_FACTORY, "com.sun.jndi.rmi.registry.RegistryContextFactory"); System.setProperty(Context.PROVIDER_URL, "rmi://localhost:1099"); System.setSecurityManager(new SecurityManager(){ @Override public void checkPermission(Permission perm) { // TODO Auto-generated method stub } }); try { InitialContext ctx = new InitialContext(); Service service = (Service)ctx.lookup("Service"); System.out.println(service.List("3444","ddd")); } catch (NamingException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (MalformedURLException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (RemoteException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (NotBoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } } 【客户端输出会报错误(空指针): coming........... coming........... XXXXXXXXX其它的信息(服务器端业务类信息) Caused by: java.lang.NullPointerException at com.jdbc.ConnectionFactory.getConn 服务器那不打印任何信息 如不调业务方法test(),list方法只返回个字符串或自己new个Entity和ArrayList返回则没有问题, 不知道这种情况是咋回事,如何解决, 我想的是客户端只接收结果的,怎么产生的结果由服务器负责,为什么现在不是这样呢,初次搞rmi,请大家说说
使用夜间切换,切换回来后为什么是灰色的?不是白色的,是哪里的配置文件有问题吗?
colors: <resources> <color name="colorPrimary">#3F51B5</color> <color name="colorPrimaryDark">#303F9F</color> <color name="colorAccent">#FF4081</color> <!--定义需要切换的两种颜色,使用只要调用对应的name就可以了--> <color name="textColor">#3b3b3b</color> <color name="textColor_night">#FFFFFF</color> <color name="backgroundColor">#FFFFFF</color> <color name="backgroundColor_night">#3b3b3b</color> </resources> 布局 <?xml version="1.0" encoding="utf-8"?> <RelativeLayout 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:id="@+id/relativelayout" android:background="#55666666" tools:context="text.bawei.com.heibai.MainActivity"> <Button android:id="@+id/button" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="黑白切换" app:layout_constraintBottom_toBottomOf="parent" app:layout_constraintLeft_toLeftOf="parent" app:layout_constraintRight_toRightOf="parent" app:layout_constraintTop_toTopOf="parent" /> </RelativeLayout> package text.bawei.com.heibai; import android.content.Context; import android.content.res.Resources; import java.util.HashMap; import java.util.LinkedList; import java.util.List; /** * 类描述: * 姓名 :刘希鑫 */ public class Heibaiqiehuan { private static ThemeMode mThemeMode = ThemeMode.DAY; private static List<OnThemeChangeListener> mThemeChangeListenerList = new LinkedList<>(); private static HashMap<String, HashMap<String, Integer>> sCachedNightResrouces = new HashMap<>(); private static final String RESOURCE_SUFFIX = "_night"; public enum ThemeMode{ DAY,NIGHT; } public static void setThemeMode(ThemeMode themeMode) { if (mThemeMode != themeMode) { mThemeMode = themeMode; if (mThemeChangeListenerList.size() > 0) { for (OnThemeChangeListener listener : mThemeChangeListenerList) { listener.onThemeChanged(); } } } } public static int getCurrentThemeRes(Context context, int dayResId) { if (getThemeMode() == ThemeMode.DAY) { return dayResId; } // 资源名 String entryName = context.getResources().getResourceEntryName(dayResId); // 资源类型 String typeName = context.getResources().getResourceTypeName(dayResId); HashMap<String, Integer> cachedRes = sCachedNightResrouces.get(typeName); // 先从缓存中去取,如果有直接返回该id if (cachedRes == null) { cachedRes = new HashMap<>(); } Integer resId = cachedRes.get(entryName + RESOURCE_SUFFIX); if (resId != null && resId != 0) { return resId; } else { //如果缓存中没有再根据资源id去动态获取 try { // 通过资源名,资源类型,包名得到资源int值 int nightResId = context.getResources().getIdentifier(entryName + RESOURCE_SUFFIX, typeName, context.getPackageName()); // 放入缓存中 cachedRes.put(entryName + RESOURCE_SUFFIX, nightResId); sCachedNightResrouces.put(typeName, cachedRes); return nightResId; } catch (Resources.NotFoundException e) { e.printStackTrace(); } } return 0; } /** * 注册ThemeChangeListener */ public static void registerThemeChangeListener(OnThemeChangeListener listener) { if (!mThemeChangeListenerList.contains(listener)) { mThemeChangeListenerList.add(listener); } } /** * 反注册ThemeChangeListener */ public static void unregisterThemeChangeListener(OnThemeChangeListener listener) { if (mThemeChangeListenerList.contains(listener)) { mThemeChangeListenerList.remove(listener); } } /** * 得到主题模式 */ public static ThemeMode getThemeMode() { return mThemeMode; } /** * 主题模式切换监听器 */ public interface OnThemeChangeListener { /** * 主题切换时回调 */ void onThemeChanged(); } } main类 package text.bawei.com.heibai; import android.graphics.Color; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.view.View; import android.widget.Button; import android.widget.RelativeLayout; //实现的接口是自己刚刚写的那个类 public class MainActivity extends AppCompatActivity implements Heibaiqiehuan.OnThemeChangeListener{ Button button; private boolean isDay=true;//默认是日间模式 RelativeLayout relativeLayout; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); //还是用自己定义的那个类来调用方法 Heibaiqiehuan.registerThemeChangeListener(this); button = (Button) findViewById(R.id.button); relativeLayout = (RelativeLayout) findViewById(R.id.relativelayout); button.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { //再点击事件里面切换黑白 if(isDay==true){ Heibaiqiehuan.setThemeMode(Heibaiqiehuan.ThemeMode.NIGHT ); button.setText("日间模式"); relativeLayout.setBackgroundColor(Color.BLACK); isDay=false; }else { Heibaiqiehuan.setThemeMode(Heibaiqiehuan.ThemeMode.DAY ); relativeLayout.setBackgroundColor(Color.GRAY); button.setText("夜间模式"); isDay=true; } } }); } @Override public void onThemeChanged() { //日间模式下的颜色 button.setTextColor(getResources().getColor(Heibaiqiehuan.getCurrentThemeRes(MainActivity.this, R.color.textColor))); relativeLayout.setBackgroundColor(getResources().getColor(Heibaiqiehuan.getCurrentThemeRes(MainActivity.this, R.color.backgroundColor))); } @Override protected void onDestroy() { super.onDestroy(); Heibaiqiehuan.unregisterThemeChangeListener(this); } }
动态规划入门到熟悉,看不懂来打我啊
持续更新。。。。。。 2.1斐波那契系列问题 2.2矩阵系列问题 2.3跳跃系列问题 3.1 01背包 3.2 完全背包 3.3多重背包 3.4 一些变形选讲 2.1斐波那契系列问题 在数学上,斐波纳契数列以如下被以递归的方法定义:F(0)=0,F(1)=1, F(n)=F(n-1)+F(n-2)(n&gt;=2,n∈N*)根据定义,前十项为1, 1, 2, 3...
程序员,职场上请远离这种人!
对有些职场人来讲,甩锅就是一种生存手段。01.从大学打篮球说起上大学的时候喜欢打篮球,然后我又特别喜欢抢篮板,经常是跳起来的时候没事,落下来的时候偶尔会踩到别人的脚上,于...
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
对计算机专业来说学历真的重要吗?
我本科学校是渣渣二本,研究生学校是985,现在毕业五年,校招笔试、面试,社招面试参加了两年了,就我个人的经历来说下这个问题。 这篇文章很长,但绝对是精华,相信我,读完以后,你会知道学历不好的解决方案,记得帮我点赞哦。 先说结论,无论赞不赞同,它本质就是这样:对于技术类工作而言,学历五年以内非常重要,但有办法弥补。五年以后,不重要。 目录: 张雪峰讲述的事实 我看到的事实 为什么会这样 ...
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
Python——画一棵漂亮的樱花树(不同种樱花+玫瑰+圣诞树喔)
最近翻到一篇知乎,上面有不少用Python(大多是turtle库)绘制的树图,感觉很漂亮,我整理了一下,挑了一些我觉得不错的代码分享给大家(这些我都测试过,确实可以生成) one 樱花树 动态生成樱花 效果图(这个是动态的): 实现代码 import turtle as T import random import time # 画樱花的躯干(60,t) def Tree(branch, ...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
一个读研让我损失了一百万的真实故事
关注我!只要10分钟,包你学会数据分析 毕业后,应该就业还是考研? 我刚出国留学那会儿,就惊讶的发现,外国local95%都不会选择读研 他们说,硕士学费很贵,时间宝贵,老板不认,所以很费 当几乎所有人都是本科学历时,硕士学历反而像个异类 在老板眼里,三年硕士远远不如3年的工作经验实用 他们甚至专门为拒绝高学历者发明了一个词,叫overoccupie...
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给
shell脚本:备份数据库、代码上线
备份MySQL数据库 场景: 一台MySQL服务器,跑着5个数据库,在没有做主从的情况下,需要对这5个库进行备份 需求: 1)每天备份一次,需要备份所有的库 2)把备份数据存放到/data/backup/下 3)备份文件名称格式示例:dbname-2019-11-23.sql 4)需要对1天以前的所有sql文件压缩,格式为gzip 5)本地数据保留1周 6)需要把备份的数据同步到远程备份中心,假如...
聊聊C语言和指针的本质
坐着绿皮车上海到杭州,24块钱,很宽敞,在火车上非正式地聊几句。 很多编程语言都以 “没有指针” 作为自己的优势来宣传,然而,对于C语言,指针却是与生俱来的。 那么,什么是指针,为什么大家都想避开指针。 很简单, 指针就是地址,当一个地址作为一个变量存在时,它就被叫做指针,该变量的类型,自然就是指针类型。 指针的作用就是,给出一个指针,取出该指针指向地址处的值。为了理解本质,我们从计算机模型说起...
为什么你学不过动态规划?告别动态规划,谈谈我的经验
动态规划难吗?说实话,我觉得很难,特别是对于初学者来说,我当时入门动态规划的时候,是看 0-1 背包问题,当时真的是一脸懵逼。后来,我遇到动态规划的题,看的懂答案,但就是自己不会做,不知道怎么下手。就像做递归的题,看的懂答案,但下不了手,关于递归的,我之前也写过一篇套路的文章,如果对递归不大懂的,强烈建议看一看:为什么你学不会递归,告别递归,谈谈我的经验 对于动态规划,春招秋招时好多题都会用到动态...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
如何安装 IntelliJ IDEA 最新版本——详细教程
IntelliJ IDEA 简称 IDEA,被业界公认为最好的 Java 集成开发工具,尤其在智能代码助手、代码自动提示、代码重构、代码版本管理(Git、SVN、Maven)、单元测试、代码分析等方面有着亮眼的发挥。IDEA 产于捷克,开发人员以严谨著称的东欧程序员为主。IDEA 分为社区版和付费版两个版本。 我呢,一直是 Eclipse 的忠实粉丝,差不多十年的老用户了。很早就接触到了 IDEA...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
大学四年自学走来,这些珍藏的「实用工具/学习网站」我全贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
为什么要推荐大家学习字节码?
配套视频: 为什么推荐大家学习Java字节码 https://www.bilibili.com/video/av77600176/ 一、背景 本文主要探讨:为什么要学习 JVM 字节码? 可能很多人会觉得没必要,因为平时开发用不到,而且不学这个也没耽误学习。 但是这里分享一点感悟,即人总是根据自己已经掌握的知识和技能来解决问题的。 这里有个悖论,有时候你觉得有些技术没用恰恰是...
【超详细分析】关于三次握手与四次挥手面试官想考我们什么?
在面试中,三次握手和四次挥手可以说是问的最频繁的一个知识点了,我相信大家也都看过很多关于三次握手与四次挥手的文章,今天的这篇文章,重点是围绕着面试,我们应该掌握哪些比较重要的点,哪些是比较被面试官给问到的,我觉得如果你能把我下面列举的一些点都记住、理解,我想就差不多了。 三次握手 当面试官问你为什么需要有三次握手、三次握手的作用、讲讲三次三次握手的时候,我想很多人会这样回答: 首先很多人会先讲下握...
压测学习总结(1)——高并发性能指标:QPS、TPS、RT、吞吐量详解
一、QPS,每秒查询 QPS:Queries Per Second意思是“每秒查询率”,是一台服务器每秒能够相应的查询次数,是对一个特定的查询服务器在规定时间内所处理流量多少的衡量标准。互联网中,作为域名系统服务器的机器的性能经常用每秒查询率来衡量。 二、TPS,每秒事务 TPS:是TransactionsPerSecond的缩写,也就是事务数/秒。它是软件测试结果的测量单位。一个事务是指一...
新程序员七宗罪
当我发表这篇文章《为什么每个工程师都应该开始考虑开发中的分析和编程技能呢?》时,我从未想到它会对读者产生如此积极的影响。那些想要开始探索编程和数据科学领域的人向我寻求建议;还有一些人问我下一篇文章的发布日期;还有许多人询问如何顺利过渡到这个职业。我非常鼓励大家继续分享我在这个旅程的经验,学习,成功和失败,以帮助尽可能多的人过渡到一个充满无数好处和机会的职业生涯。亲爱的读者,谢谢你。 -罗伯特。 ...
2019年Spring Boot面试都问了什么?快看看这22道面试题!
Spring Boot 面试题 1、什么是 Spring Boot? 2、Spring Boot 有哪些优点? 3、什么是 JavaConfig? 4、如何重新加载 Spring Boot 上的更改,而无需重新启动服务器? 5、Spring Boot 中的监视器是什么? 6、如何在 Spring Boot 中禁用 Actuator 端点安全性? 7、如何在自定义端口上运行 Sprin...
【图解】记一次手撕算法面试:字节跳动的面试官把我四连击了
字节跳动这家公司,应该是所有秋招的公司中,对算法最重视的一个了,每次面试基本都会让你手撕算法,今天这篇文章就记录下当时被问到的几个算法题,并且每个算法题我都详细着给出了最优解,下面再现当时的面试场景。看完一定让你有所收获 一、小牛试刀:有效括号 大部分情况下,面试官都会问一个不怎么难的问题,不过你千万别太开心,因为这道题往往可以拓展出更多有难度的问题,或者一道题看起来很简单,但是给出最优解,确实很...
面试官:关于Java性能优化,你有什么技巧
通过使用一些辅助性工具来找到程序中的瓶颈,然后就可以对瓶颈部分的代码进行优化。 一般有两种方案:即优化代码或更改设计方法。我们一般会选择后者,因为不去调用以下代码要比调用一些优化的代码更能提高程序的性能。而一个设计良好的程序能够精简代码,从而提高性能。 下面将提供一些在JAVA程序的设计和编码中,为了能够提高JAVA程序的性能,而经常采用的一些方法和技巧。 1.对象的生成和大小的调整。 J...
【图解算法面试】记一次面试:说说游戏中的敏感词过滤是如何实现的?
版权声明:本文为苦逼的码农原创。未经同意禁止任何形式转载,特别是那些复制粘贴到别的平台的,否则,必定追究。欢迎大家多多转发,谢谢。 小秋今天去面试了,面试官问了一个与敏感词过滤算法相关的问题,然而小秋对敏感词过滤算法一点也没听说过。于是,有了下下事情的发生… 面试官开怼 面试官:玩过王者荣耀吧?了解过敏感词过滤吗?,例如在游戏里,如果我们发送“你在干嘛?麻痹演员啊你?”,由于“麻痹”是一个敏感词,...
GitHub 标星 1.6w+,我发现了一个宝藏项目,作为编程新手有福了!
大家好,我是 Rocky0429,一个最近老在 GitHub 上闲逛的蒟蒻… 特别惭愧的是,虽然我很早就知道 GitHub,但是学会逛 GitHub 的时间特别晚。当时一方面是因为菜,看着这种全是英文的东西难受,不知道该怎么去玩,另一方面是一直在搞 ACM,没有做一些工程类的项目,所以想当然的以为和 GitHub 也没什么关系(当然这种想法是错误的)。 后来自己花了一个星期看完了 Pyt...
杭漂程序员2019的心路历程,还不起助学贷款,交不起房租,披荆斩棘终雨过天晴
一个杭漂2019的心酸历程,一路披荆斩棘终于还是雨过天晴。
我采访了同事,让他掏出了每天都会浏览的干货网站
前言只有光头才能变强。文本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y在周六的晚上,我日常去到公司写文章。想写...
Java知识体系最强总结(2020版)
更新于2019-12-15 10:38:00 本人从事Java开发已多年,平时有记录问题解决方案和总结知识点的习惯,整理了一些有关Java的知识体系,这不是最终版,会不定期的更新。也算是记录自己在从事编程工作的成长足迹,通过博客可以促进博主与阅读者的共同进步,结交更多志同道合的朋友。特此分享给大家,本人见识有限,写的博客难免有错误或者疏忽的地方,还望各位大佬指点,在此表示感激不尽。 文章目录...
计算机专业的书普遍都这么贵,你们都是怎么获取资源的?
介绍几个可以下载编程电子书籍的网站。 1.Github Github上编程书资源很多,你可以根据类型和语言去搜索。推荐几个热门的: free-programming-books-zh_CN:58K 星的GitHub,编程语言、WEB、函数、大数据、操作系统、在线课程、数据库相关书籍应有尽有,共有几百本。 Go语言高级编程:涵盖CGO,Go汇编语言,RPC实现,Protobuf插件实现,Web框架实...
2020年一线城市程序员工资大调查
人才需求 一线城市共发布岗位38115个,招聘120827人。 其中 beijing 22805 guangzhou 25081 shanghai 39614 shenzhen 33327 工资分布 2020年中国一线城市程序员的平均工资为16285元,工资中位数为14583元,其中95%的人的工资位于5000到20000元之间。 和往年数据比较: yea...
毕业5年,我问遍了身边的大佬,总结了他们的学习方法
我问了身边10个大佬,总结了他们的学习方法,原来成功都是有迹可循的。
这些软件太强了,Windows必装!尤其程序员!
Windows可谓是大多数人的生产力工具,集娱乐办公于一体,虽然在程序员这个群体中都说苹果是信仰,但是大部分不都是从Windows过来的,而且现在依然有很多的程序员用Windows。 所以,今天我就把我私藏的Windows必装的软件分享给大家,如果有一个你没有用过甚至没有听过,那你就赚了????,这可都是提升你幸福感的高效率生产力工具哦! 走起!???? NO、1 ScreenToGif 屏幕,摄像头和白板...
大学四年因为知道了这32个网站,我成了别人眼中的大神!
依稀记得,毕业那天,我们导员发给我毕业证的时候对我说“你可是咱们系的风云人物啊”,哎呀,别提当时多开心啦????,嗯,我们导员是所有导员中最帅的一个,真的???? 不过,导员说的是实话,很多人都叫我大神的,为啥,因为我知道这32个网站啊,你说强不强????,这次是绝对的干货,看好啦,走起来! PS:每个网站都是学计算机混互联网必须知道的,真的牛杯,我就不过多介绍了,大家自行探索,觉得没用的,尽管留言吐槽吧???? 社...
相关热词 c# 时间比天数 c# oracle查询 c# 主动推送 事件 c# java 属性 c# 控制台 窗体 c# 静态类存值 c#矢量作图 c#窗体调用外部程式 c# enum是否合法 c# 如何卸载引用
立即提问