android ListView Adapter不显示

//activity
package wk.bluetooth;

import android.app.Activity;
import android.bluetooth.BluetoothAdapter;
import android.bluetooth.BluetoothDevice;
import android.bluetooth.BluetoothSocket;
import android.content.Context;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.util.Log;
import android.view.View;
import android.view.Window;
import android.view.inputmethod.InputMethodManager;
import android.widget.*;
import android.widget.AdapterView.OnItemClickListener;
import android.view.View.OnClickListener;

import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;

import wk.bluetooth.StartServer.ChatListItem;

public class StartClient extends Activity implements OnItemClickListener ,OnClickListener{

private ListView mListView;
ChatAdapter mAdapter;
private ArrayList<ChatListItem> list;

private EditText sendMessage;
private Button sendButton;
private TextView title;
private ImageButton back;

private String joinChatRoomName;
private String address;
private String nowTime;

private BluetoothSocket socket;
private BluetoothDevice device = null;
private clientThread startClient = null;
private readThread mreadThread = null;
private BluetoothAdapter mBluetoothAdapter = BluetoothAdapter.getDefaultAdapter();



Context mContext;

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    requestWindowFeature(Window.FEATURE_CUSTOM_TITLE);
    setContentView(R.layout.chat);
    getWindow().setFeatureInt(Window.FEATURE_CUSTOM_TITLE,R.layout.titlebar);
    Bundle bundle = this.getIntent().getExtras();
    joinChatRoomName = bundle.getString("joinChatRoomName");
    address = bundle.getString("address");

    mContext = this;
    init();
}
private  void init(){
    device = mBluetoothAdapter.getRemoteDevice(address);

    list = new ArrayList<ChatListItem>();
    mAdapter = new ChatAdapter(mContext, list);
    mListView = (ListView) findViewById(R.id.chat_list);
    mListView.setAdapter(mAdapter);
    //mListView.setOnItemClickListener(this);
    mListView.setFastScrollEnabled(true);

    title = (TextView) findViewById(R.id.title);
    title.setText(joinChatRoomName);


    back = (ImageButton) findViewById(R.id.back);
    back.setOnClickListener(new OnClickListener() {
        @Override
        public void onClick(View view) {
            if(mreadThread!=null){
                mreadThread.interrupt();
            }
            if(startClient != null){
                startClient.interrupt();
            }
            list.clear();
            StartClient.this.finish();
        }
    });


    sendMessage = (EditText)findViewById(R.id.MessageText);
    sendButton = (Button)findViewById(R.id.btn_msg_send);
    sendButton.setOnClickListener(new OnClickListener() {
        @Override
        public void onClick(View view) {
            String msg= sendMessage.getText().toString();
            if(msg.length()>0){
                SendMessageHandle(msg);
                sendMessage.setText("");
                sendMessage.clearFocus();
                InputMethodManager imm = (InputMethodManager)getSystemService(Context.INPUT_METHOD_SERVICE);
                imm.hideSoftInputFromWindow(sendMessage.getWindowToken(), 0);

            }else{
                Toast.makeText(mContext, "消息发送失败", Toast.LENGTH_SHORT).show();
                sendMessage.setText("");
                sendMessage.clearFocus();
            }

        }
    });
    if(Bluetooth.joinChatRoom.get(address)) {
        Log.d("StartClient","join again");
        mreadThread = new readThread();
        mreadThread.start();

    }else{
        Log.d("StartClient","first time join");
        startClient = new clientThread();
        startClient.start();
    }


}

private class clientThread extends Thread {
    @Override
    public void run() {
        try {

            Message msg2 = new Message();
            msg2.obj = "正在加入"+device.getName()+"的聊天室";
            msg2.what = 2;
            LinkDetectedHandler.sendMessage(msg2);
            //创建一个Socket连接:只需要服务器在注册时的UUID号
            socket = Bluetooth.joinChatRoomSocket.get(address);
            //连接
            socket.connect();
            Bluetooth.joinChatRoomSocket.put(address,socket);
            Bluetooth.joinChatRoom.put(address,true);


           // new IsNotConnected().start();

            //启动接受数据
            mreadThread = new readThread();
            mreadThread.start();
        }
        catch (IOException e)
        {
            Bluetooth.joinChatRoom.put(address,false);
            Message msg = new Message();
            msg.obj = "加入聊天室失败,请断开重试";
            msg.what = 2;
            LinkDetectedHandler.sendMessage(msg);
        }

    }
}

//读取数据
private class readThread extends Thread {
@Override
public void run() {
Log.d("StartClient","read buffer");
byte[] buffer = new byte[1024];
int bytes;
InputStream mmInStream = null;

        try {
            mmInStream = Bluetooth.joinChatRoomSocket.get(address).getInputStream();
        } catch (IOException e1) {
            e1.printStackTrace();
        }
        while (true) {
            try {
                // Read from the InputStream
                if ((bytes = mmInStream.read(buffer)) > 0) {
                    byte[] buf_data = new byte[bytes];
                    for (int i = 0; i < bytes; i++) {
                        buf_data[i] = buffer[i];
                    }

                    String s = new String(buf_data);
                    Log.d("ReceiveMessage",s+"-------");
                    if(s.equals("MARLBORO")){
                        continue;
                    }

                    Message message = new Message();
                    message.obj = s;
                    message.what = 1;
                    LinkDetectedHandler.sendMessage(message);
                }
            } catch (IOException e) {
                try {
                    mmInStream.close();
                } catch (IOException e1) {
                    // TODO Auto-generated catch block
                    e1.printStackTrace();
                }
                break;
            }

        }
    }
}

private Handler LinkDetectedHandler = new Handler() {
    //what = 0发送的消息
    //what = 1接受的消息
    //what = 2公共消息
    @Override
    public void handleMessage(Message msg) {
        Log.d("ReceiveMessage", msg.obj + "   " + msg.what);
        SimpleDateFormat formatter = new SimpleDateFormat("yyy-MM-dd HH:mm:ss");
        nowTime = formatter.format(new Date(System.currentTimeMillis()));

        list.add(new ChatListItem((String) msg.obj, nowTime, msg.what));

        Log.d("ReceiveMessage","list size"+list.size());

        Log.d("ReceiveMessage","adddddddddddd");
        mAdapter.notifyDataSetChanged();
        mListView.setSelection(list.size() - 1);


    }

};

private void SendMessageHandle(String msg){
    Log.d("StartClient","send message"+msg);
    try {
        OutputStream outputStream = Bluetooth.joinChatRoomSocket.get(address).getOutputStream();
        outputStream.write(msg.getBytes());
    } catch (Exception e) {}
    Message m = new Message();
    m.obj = msg;
    m.what = 0;
    LinkDetectedHandler.sendMessage(m);
}

@Override
public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) {
    // TODO Auto-generated method stub
}
@Override
public void onClick(View arg0) {
    // TODO Auto-generated method stub
}

public class joinChatListItem {
    String message;
    Integer flag;

    public joinChatListItem(String msg, Integer f) {
        message = msg;
        flag = f;
    }
}

}

2个回答

//adapter
package wk.bluetooth;

import android.content.Context;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;
import wk.bluetooth.StartServer.ChatListItem;

import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;

/**

  • Created by wk on 2015/5/4.
    */
    public class ChatAdapter extends BaseAdapter {
    private ArrayList list;
    private LayoutInflater mInflater;

    public ChatAdapter(Context context, ArrayList l) {
    list = l;
    mInflater = LayoutInflater.from(context);
    }

    @Override
    public int getCount() {
    return list.size();
    }

    @Override
    public Object getItem(int position) {
    return list.get(position);
    }

    @Override
    public long getItemId(int position) {
    return position;
    }

    @Override
    public int getItemViewType(int position) {
    return position;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
    ViewHolder viewHolder = null;
    int[] textView ={R.id.send_text,R.id.receive_text,R.id.receive_text};
    int[] imageView = {R.id.send_head_image,R.id.receive_head_image, R.id.receive_head_image};
    int[] layout = {R.layout.send_message,R.layout.receive_message, R.layout.receive_message};
    Log.d("ChatAdapter","hhhhhhhhhhhhhhhhhhhh");
    ChatListItem item=list.get(position);
    Log.d("ChatAdapter","item.flag "+item.flag+"item.mes "+item.message);
    // if(convertView == null){
    Log.d("ChatAdapter","--"+item.message+" -- "+ item.flag);
    convertView = mInflater.inflate(layout[item.flag], null);
    viewHolder=new ViewHolder(
    // convertView.findViewById(R.id.list_child),
    (TextView) convertView.findViewById(textView[item.flag])
    , (TextView) convertView.findViewById(R.id.message_time)
    ,(ImageView) convertView.findViewById(imageView[item.flag])
    );
    convertView.setTag(viewHolder);
    //}

    //else{
      //  Log.d("ChatAdapter","nullllllllllll");
       // viewHolder = (ViewHolder)convertView.getTag();
    //}
    if(item.flag==2){
        Log.d("ChatAdapter",item.message+"--"+item.flag);
        viewHolder.time.setText(item.message);
        viewHolder.msg.setVisibility(View.GONE);
        viewHolder.img.setVisibility(View.GONE);
    }else {
        viewHolder.msg.setVisibility(View.VISIBLE);
        viewHolder.img.setVisibility(View.VISIBLE);
        viewHolder.time.setText(item.time);
        viewHolder.msg.setText(item.message);
    }
    return convertView;
    

    }

    class ViewHolder {
    protected TextView msg;
    protected TextView time;
    protected ImageView img;

    public ViewHolder(TextView message, TextView t, ImageView im){
        this.msg = message;
        this.time = t;
        this.img = im;
    
    }
    

    }
    }

我能收到socket发送的消息,但是我多次调用这个activity后 list没有add数据adapter也没有调用日志
运行结果

只要没有点返回之类的按钮,list应该是不断增大了。先跟踪看看list没有增加的原因吧

qq_16207577
wksnsw 解决了,,,多谢提示,,问题不在lis上在listview上面 把listview设置成静态的就可以了,谢谢
大约 5 年之前 回复
danielinbiti
danielinbiti 回复qq_16207577: 不是静态,你activity finish时候,list也释放了,再次进入这个acitivity就是重新初始化的list,原来的数据没了。
大约 5 年之前 回复
qq_16207577
wksnsw 回复danielinbiti: 设置为静态的后可以(为什么要设置为静态的?) 但是我重进多少次他就会累计多少次再刷新页面
大约 5 年之前 回复
danielinbiti
danielinbiti 回复qq_16207577: 想结束后再进来都能加载历史聊天记录,那就把聊天记录存到数据库或者文本文件里面。或者定义一个静态的list,不清除。
大约 5 年之前 回复
danielinbiti
danielinbiti 回复qq_16207577: 【我是把StartClient这个activity finish后再在别的地方又 进了一次 进来后就不能显示 第一次是正常的】这相当于重新初始化了list了。
大约 5 年之前 回复
danielinbiti
danielinbiti 回复qq_16207577: 那肯定不行了
大约 5 年之前 回复
danielinbiti
danielinbiti 回复qq_16207577: 你不用消息,直接add两个list.add(new ChatListItem((String) msg.obj, nowTime, msg.what));试试
大约 5 年之前 回复
qq_16207577
wksnsw 回复qq_16207577: 我是把StartClient这个activity finish后再在别的地方又 进了一次 进来后就不能显示 第一次是正常的
大约 5 年之前 回复
qq_16207577
wksnsw 回复danielinbiti: 我传了两条数据 但是list size还是1
大约 5 年之前 回复
danielinbiti
danielinbiti 回复qq_16207577: 看你日志不是打印了两次 Log.d("ReceiveMessage","adddddddddddd");嘛
大约 5 年之前 回复
qq_16207577
wksnsw list.add(new ChatListItem((String) msg.obj, nowTime, msg.what));这条语句没有执行 但是 try {}catch{}不显示任何错误信息
大约 5 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
android listview自定义adapter,getview方法不显示

adapter的getCount值不为0,但是不执行getview方法,在ErrorLog中打印出来的log在下面贴出来了,希望路过的大牛们帮忙看看 ![图片说明](https://img-ask.csdn.net/upload/201507/23/1437619354_763964.png)

Android ListView控件无法显示

显示不出来,显示的的是fragment布局的内容,程序没有报错,调试发现已经走过了runonuithread![图片说明](https://img-ask.csdn.net/upload/201711/03/1509711999_879713.png)![图片说明](https://img-ask.csdn.net/upload/201711/03/1509711946_74158.png)

关于 Android Listview不显示数据的问题

![图片说明](https://img-ask.csdn.net/upload/201509/01/1441102851_227331.png) ListView 正常,数据也正常,但是就是不显示数据。 List View 中包含Item布局(TextView),ViewPager中包含ListView,MainActivity中包含Viewpager。 ==== TextView 》ListView 》ViewPager 》MainActivity ==== ListView .setAdapter(Context,ArrayList);debug调试发现 Context 指向MainActivity,此时不报错但也不显示数据。 然后根据网上的教程,重写了布局。 ==== TextView 》ListView 》MainActivity ====此时正常显示,debug调试发现 Context 指向MainActivity。 不懂为什么,可能是因为ViewPager的原因,导致Context 出错,该怎么修改呢。谢谢大脚了,

Android Listview adapter数据更新

listview绑定适配器后,数据更新不是需要调用notifyDataSetChanged刷新数据吗,为什么我现在不用掉也能刷新,平台是4.2和4.4,低的平台没测。代码如下 adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1); listview = (ListView)findViewById(R.id.listview); listview.setAdapter(adapter); btn = (Button)findViewById(R.id.button); btn.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View arg0) { adapter.add("item"); } });

android listView嵌套ListView

android listView嵌套ListView,子listView第一个显示全了,其他的没显示。 ![图片说明](https://img-ask.csdn.net/upload/201708/22/1503391737_599360.jpg) 下面是我的代码。帮看看哪里有问题。。 这是第一个list。![图片说明](https://img-ask.csdn.net/upload/201708/22/1503391834_813393.png) 第二个list在adpater里面。 ![图片说明](https://img-ask.csdn.net/upload/201708/22/1503391957_187311.png) 我试了两种,一种是重写list view,一种是:Util.setListViewHeightBasedOnChildren(viewHolder.lv_cp_list2); 都没什么卵用。 有没有大神指教下,分不是问题

Android自定义控件在ListView中不显示

在Android中定义了一个MyTextView extends View,在Activity中使用的时候,高度设置为wrapcontent可以正常显示,但是在Listview中高度设置为wrapcontent就会变成0,显示不出来我的View,需要固定高度为100dip等,这中问题可以解决吗.

Android ListView 自定义Adapter 滑动时报空指针异常

问题背景:在制作一个即时聊天的APP中,聊天界面聊天消息的显示我使用了ListView,并且使用了自定义的Adapter,获取到聊天记录之后ListView可以正常显示,但是一旦滑动就会报空指针异常。我查看了很多博客,都没有提到与这个相关或者类似的错误已经被这个错误逼疯了,希望有了解的大神能够给予指点。 具体相关代码如下: 自定义的Adapter: ``` public class ChatMessageAdapter extends BaseAdapter { private LayoutInflater layoutInflater; private List<MessageShow> messageShowList; public ChatMessageAdapter(Context context, List<MessageShow> messageShowList){ layoutInflater = LayoutInflater.from(context); this.messageShowList = messageShowList; } @Override public int getCount() { return messageShowList.size(); } @Override public Object getItem(int position) { return messageShowList.get(position); } @Override public int getItemViewType(int position) { if(messageShowList.get(position).getMessageType()==0) return 0; else return 1; } //Item类型的总数 @Override public int getViewTypeCount() { return 2; } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { MessageShow messageShow = messageShowList.get(position); ViewHolder viewHolder = null; if(convertView == null){ if(messageShow.getMessageType() == 0){ convertView = layoutInflater.inflate(R.layout.from_message_item,null); viewHolder = new ViewHolder(); // viewHolder.imageView = (ImageView) convertView.findViewById(R.id.from_user_icons); viewHolder.time = (TextView) convertView.findViewById(R.id.from_time); viewHolder.message = (TextView) convertView.findViewById(R.id.from_message); } else{ convertView = layoutInflater.inflate(R.layout.to_message_item,null); viewHolder = new ViewHolder(); // viewHolder.imageView = (ImageView) convertView.findViewById(R.id.to_user_icons); viewHolder.time = (TextView) convertView.findViewById(R.id.to_time); viewHolder.message = (TextView) convertView.findViewById(R.id.to_message); } } else { viewHolder = (ViewHolder) convertView.getTag(); } System.out.println("我到了这里"+position); System.out.println("我添加了适配器: "+messageShow.getContents()); // viewHolder.imageView.setImageResource(R.drawable.photo); //报空指针异常的是这里 viewHolder.message.setText(messageShow.getContents()); viewHolder.time.setText(messageShow.getTime()); return convertView; } private final class ViewHolder{ // ImageView imageView; TextView time; TextView message; } ``` ,ChatActivity代码如下: ``` private List<MessageShow> showMessageList; private ChatMessageAdapter chatMessageAdapter; 、、、省略无关 //初始化数据 private void initData(){ showMessageList = new ArrayList<MessageShow>(); chatMessageAdapter = new ChatMessageAdapter(this,showMessageList); listView.setAdapter(chatMessageAdapter); getMessageRecord(); chatMessageAdapter.notifyDataSetChanged(); } ``` 其中获取聊天记录我已经在控制台打印出来检查过了,没有错误,而ListView能够显示说明Apapter也不会有基本的错误,但是还是报空指针。我对错误的猜测如下: 虽然给的数据集可能有几十项,但是Adapter加载的时候只加载了当前显示的几项,后面的没加载,等我我滑动之后去加载的时候没加载到数据就报空指针了。但是这不太科学啊,我看了好多博客发现都没有专门说到这点,仔细检查代码也不知道应该怎么改,求指教。报错信息如下: ``` I/System.out: 我到了这里1 I/System.out: 我添加了适配器: 图片这些不能点击? I/System.out: 我到了这里2 I/System.out: 我添加了适配器: 还没做那些功能呢233 I/System.out: 我到了这里3 I/System.out: 我添加了适配器: 图片和表情 I/System.out: 我到了这里4 I/System.out: 我添加了适配器: 额 I/System.out: 我到了这里5 I/System.out: 我添加了适配器: 准备等APP开发完之后再说 I/System.out: 我到了这里6 I/System.out: 我添加了适配器: 真的挺费脑的 I/System.out: 我到了这里7 I/System.out: 我添加了适配器: 嗯 加油 E/InputEventReceiver: Exception dispatching input event. D/AndroidRuntime: Shutting down VM W/dalvikvm: threadid=1: thread exiting with uncaught exception (group=0xa6160908) E/AndroidRuntime: FATAL EXCEPTION: main java.lang.NullPointerException at cn.justwithme.withme.Adapaer.ChatMessageAdapter$override.getView(ChatMessageAdapter.java:84) at cn.justwithme.withme.Adapaer.ChatMessageAdapter$override.access$dispatch(ChatMessageAdapter.java) at cn.justwithme.withme.Adapaer.ChatMessageAdapter.getView(ChatMessageAdapter.java:0) ``` 本来有十几项的,第一页只有7项,我在Adapter的输出就只出输出了7项。 ![图片说明](https://img-ask.csdn.net/upload/201702/19/1487495789_116858.png) ![图片说明](https://img-ask.csdn.net/upload/201702/19/1487495801_419892.png)

请问像我这样设置Listview的adapter高度为什么无效?

这是我adapter引入布局文件,我设置RelativeLayout 高度是140dp,但实际高度只有LinearLayout的100dp,为什么??? <?xml version="1.0" encoding="utf-8"?> <RelativeLayout android:id = "@+id/myInfo_cell_RL" android:layout_width="match_parent" android:layout_marginLeft="15dp" android:layout_marginRight="15dp" android:layout_marginTop="12dp" android:background="#00FF00" android:layout_height="140dp"> <LinearLayout android:layout_alignParentRight="true" android:layout_centerVertical="true" android:background="#000000" android:orientation="vertical" android:alpha="0.6" android:layout_width="100dp" android:layout_height="80dp" > <TextView android:id="@+id/myInfoCell_title" android:layout_height="40dp" android:layout_width="match_parent" android:gravity="right|center_vertical" android:textColor="#FFFFFF" android:textSize="18sp" android:text="This is title..." android:lines="1" /> <TextView android:id="@+id/myInfoCell_author" android:layout_height="40dp" android:layout_width="match_parent" android:gravity="right|top" android:textColor="#FFFFFF" android:textSize="15sp" android:text="Helen" /> </LinearLayout> </RelativeLayout>

Android记事本listview不显示内容

调试的错误只有getSlotFromBufferLocked: unknown buffer: 0xa068fd80 SQL数据能正常写入 Adapter.java package com.example.note; import android.annotation.SuppressLint; import android.content.Context; import android.database.Cursor; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.ImageView; import android.widget.LinearLayout; import android.widget.TextView; public class Adapter extends BaseAdapter{ private Context context; private Cursor cursor; private LinearLayout layout; public Adapter(Context context,Cursor cursor) { this.context = context; this.cursor = cursor; } public int getCount() { return cursor.getCount(); } @Override public Object getItem(int position) { return cursor.getPosition(); } @Override public long getItemId(int position) { return position; } public View getView(int position, View convertView, ViewGroup parent) { LayoutInflater inflater = LayoutInflater.from(context); //加载视图的权限 layout = (LinearLayout) inflater.inflate(R.layout.cell, null); TextView contenttv = (TextView) layout.findViewById(R.id.list_content); TextView timetv = (TextView) layout.findViewById(R.id.list_time); ImageView imgiv = (ImageView) layout.findViewById(R.id.list_img); ImageView videoiv = (ImageView) layout.findViewById(R.id.list_video);//截取视频中第一张图进行显示 cursor.moveToPosition(position);//查询 String content = cursor.getString(cursor.getColumnIndex("content"));//查询的内容 String time = cursor.getString(cursor.getColumnIndex("time")); contenttv.setText(content); timetv.setText(time); System.out.println("返回成功"); return layout; } } MainActivity.java package com.example.note; import java.text.SimpleDateFormat; import java.util.Date; import android.app.Activity; import android.content.ContentValues; import android.content.Intent; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.os.Bundle; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.ListView; public class MainActivity extends Activity implements OnClickListener{ private Button textbtn,imgbtn,videobtn; private ListView lv; private Intent i; private Adapter adapter; private NotesDB notesDB; private SQLiteDatabase dbReader; protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initView(); } public void initView(){ lv = (ListView) findViewById(R.id.list); textbtn = (Button) findViewById(R.id.text); imgbtn = (Button) findViewById(R.id.img); videobtn = (Button) findViewById(R.id.video); textbtn.setOnClickListener(this); imgbtn.setOnClickListener(this); videobtn.setOnClickListener(this); notesDB = new NotesDB(this); dbReader = notesDB.getReadableDatabase(); } @Override public void onClick(View v) { i = new Intent(this,add.class); switch (v.getId()) { case R.id.text: i.putExtra("flag","1"); startActivity(i); break; case R.id.img: i.putExtra("flag","2"); startActivity(i); break; case R.id.video: i.putExtra("flag","3"); startActivity(i); break; } } public void selectDB(){ Cursor cursor = dbReader.query(NotesDB.TABLE_NAME, null, null, null , null, null, null); adapter = new Adapter(this,cursor); lv.setAdapter(adapter); } @Override protected void onResume() { super.onResume(); selectDB(); } }

Android的listview怎样动态改变显示的数量

我做了一个简单的小程序,在一个界面上有一个按钮,然后点击按钮就增加一行listview,但是我 我的程序点击却没有反应,应该怎样解决,这是源代码 package com.example.dianjishiyan; import java.util.ArrayList; import java.util.List; import android.app.Activity; import android.content.Context; import android.os.Bundle; import android.view.LayoutInflater; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.view.View.OnClickListener; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.Button; import android.widget.ImageView; import android.widget.LinearLayout; import android.widget.ListView; import android.widget.TextView; public class MainActivity extends Activity implements OnClickListener{ ListView lv; Button bt; myad adaptper; List<crime> a=new ArrayList<crime>(); int b=a.size()+1; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); lv=(ListView) findViewById(R.id.lv); bt=(Button) findViewById(R.id.bt); adaptper=new myad(); lv.setAdapter(adaptper); } class myad extends BaseAdapter{ TextView tv; @Override public int getCount() { // TODO Auto-generated method stub return b; } @Override public String getItem(int position) { return null; //return a[position]; } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { LinearLayout ll=null; if(convertView!=null){ ll=(LinearLayout) convertView; }else{ ll=(LinearLayout) LayoutInflater.from(MainActivity.this).inflate(R.layout.textview, null); } //String b=getItem(position); tv=(TextView) ll.findViewById(R.id.textView1); tv.setText("textview"); return ll; } } @Override public void onClick(View v) { // TODO Auto-generated method stub crime c=new crime(); a.add(c); } } <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" tools:context="com.example.dianjishiyan.MainActivity" > <ListView android:id="@+id/lv" android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1" /> <Button android:id="@+id/bt" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="add" /> </LinearLayout> <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <TextView android:id="@+id/textView1" android:layout_width="match_parent" android:layout_height="50dp" android:layout_margin="5dp" android:gravity="left|center" android:textSize="30sp"/> </LinearLayout> package com.example.dianjishiyan; public class crime { } ![图片说明](https://img-ask.csdn.net/upload/201605/20/1463750507_370477)

Android,Fragment中的ListView为何不显示

这是Fragment的代码 ``` public class LeftMenuFragment extends BaseFragment { private ListView listView; private ArrayList<NewsMenu.NewsMenuData> menuDatas; private MyAdapter myAdapter; private View view; @Override public View initView() { view = View.inflate(mActivity, R.layout.sliding_left_menu,null); listView = (ListView) view.findViewById(R.id.lv_left_menu); return view; } @Nullable @Override public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { return initView(); } @Override public void initData() { } /** * 更新LeftMenu * @param datas */ public void setLeftMenu(ArrayList<NewsMenu.NewsMenuData> datas) { menuDatas = datas; for(NewsMenu.NewsMenuData newsMenuData:menuDatas) { System.out.println(newsMenuData.toString()); } myAdapter = new MyAdapter(); listView.setAdapter(myAdapter); } //ListView的Adapter class MyAdapter extends BaseAdapter{ @Override public int getCount() { return menuDatas.size(); } @Override public NewsMenu.NewsMenuData getItem(int position) { return menuDatas.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { View view = View.inflate(mActivity, R.layout.item_listview_left_menu, null); TextView tvMenu = (TextView) view.findViewById(R.id.tv_item_listview_leftmenu); NewsMenu.NewsMenuData item = getItem(position); tvMenu.setText(item.title); return view; } } } ``` 这是布局文件的代码 ``` <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:id="@+id/sliding_left_menu" android:background="#000" android:layout_width="match_parent" android:layout_height="match_parent"> <TextView android:layout_width="match_parent" android:layout_height="wrap_content" android:textColor="#fff" android:gravity="center_horizontal" android:textSize="20sp" android:text="你好"/> <ListView android:id="@+id/lv_left_menu" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_marginTop="80dp"/> </LinearLayout> ``` 这里面的TextView“你好”是可以显示出来的,当远程调用Fragment中的setLeftMenu方法,为何ListView不显示呢,

android listview 删除之后怎么刷新 listview

这个是TitleAdapter package com.example.ming.myapplication; import android.content.Context; import android.content.Intent; import android.os.AsyncTask; import android.util.Log; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.Button; import android.widget.TextView; import android.widget.Toast; import java.net.MalformedURLException; import java.net.URL; import java.util.List; public class TitleAdapter extends BaseAdapter { Context context; List<Article> postlist2; String id2; String id=""; int ii=0; public TitleAdapter(Context context, List<Article> postlist) { this.context = context; this.postlist2 = postlist; } @Override public int getCount() { return postlist2.size(); } @Override public Object getItem(int position) { return null; } @Override public long getItemId(int position) { return 0; } @Override public View getView(int position, View convertView, ViewGroup parent) { convertView = LayoutInflater.from(context).inflate(R.layout.activity_article, null); Object obj = convertView.getTag(); ii=position; ViewHolder holder;//实现缓存 高效加载数据 //如果为空 if (obj == null) { holder = new ViewHolder(convertView); convertView.setTag(holder); } else { //緩存 通過viewholder存儲 holder = (ViewHolder) obj; } Article posit = postlist2.get(position); holder.tv_tltleid.setText(posit.getWid() + ""); holder.tv_tltlecontent.setText(posit.getTitle() + ""); return convertView; } public class ViewHolder { public View lv_title; public TextView tv_tltleid; public TextView tv_tltlecontent; public Button btn_neirong; public Button btn_delete; public ViewHolder(View rootView) { this.lv_title = rootView; this.tv_tltleid = (TextView) rootView.findViewById(R.id.tv_tltleid); this.tv_tltlecontent = (TextView) rootView.findViewById(R.id.tv_tltlecontent); this.btn_neirong=(Button)rootView.findViewById(R.id.btn_neirong); btn_neirong.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Intent intent2 = new Intent(context, ContentActivity.class); String id2=tv_tltleid.getText().toString(); Log.i("aaa",id2); intent2.putExtra("wid",id2); context.startActivity(intent2); } }); this.btn_delete = (Button) rootView.findViewById(R.id.btn_delete); btn_delete.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { String id = tv_tltleid.getText().toString(); Log.i("1111", id); Log.i("11112", id); String url = "http://192.168.43.124:8080/test1/LoginServlet?jsp=delete&wid=" + id; new LoginTask().execute(url); } }); } class LoginTask extends AsyncTask<String, Integer, String> { @Override protected String doInBackground(String... params) { String par = params[0]; URL url = null; try { url = new URL(par); } catch (MalformedURLException e) { e.printStackTrace(); } String result = HttpUtil.doPost(url); return result; } //第四步 @Override protected void onPostExecute(String result) { super.onPostExecute(result); //保存数据 if (result.equals("1")) { Toast.makeText(context, "删除成功", Toast.LENGTH_SHORT).show(); return; } else { if (result.equals("-1")) { Toast.makeText(context, "删除失败", Toast.LENGTH_SHORT).show(); return; } } } } } } 这个是TitleActivity package com.example.ming.myapplication; import android.content.Context; import android.content.Intent; import android.os.AsyncTask; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.widget.Button; import android.widget.ListView; import com.google.gson.Gson; import com.google.gson.reflect.TypeToken; import org.json.JSONArray; import java.net.MalformedURLException; import java.net.URL; import java.util.ArrayList; import java.util.List; /** * Created by Ming on 2019/6/16. */ public class TitleActivity extends AppCompatActivity { private ListView listView; Article article; JSONArray jsonArray; ListView lv_title; Context context; Button button; String id2="used"; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_title); Intent intent=getIntent(); id2=intent.getStringExtra("id2"); context = this; String url = "http://192.168.43.124:8080/test1/LoginServlet?jsp=titleck&id2="+id2; new LoginTask().execute(url); } class LoginTask extends AsyncTask<String, Integer, String> { @Override protected String doInBackground(String... params) { String par = params[0]; URL url = null; try { url = new URL(par); } catch (MalformedURLException e) { e.printStackTrace(); } String result = HttpUtil.doPost(url); return result; } //第四步 @Override protected void onPostExecute(String result) { super.onPostExecute(result); final List<Article> list = new ArrayList<Article>(); Gson gson1 = new Gson(); final List<Article> list2 = gson1.fromJson(result, new TypeToken<List<Article>>() { }.getType()); for (Article person1 : list) { System.out.println(person1.toString()); } lv_title=(ListView)findViewById(R.id.lv_title); lv_title.setAdapter(new TitleAdapter(context,list2)); } } } 1.

android的listview中的自定义adapter初次打开不显示缓存的网络图片

求助,小弟最近在写用listview 的 adapter ,在 imageview 上显示网络图片,缓存下来的图片保存成 bitmap , 在 adapter 中的 getView 设置了 imageView_image.setImageBitmap(bitmap); 但不知为何每第一次打开列表图片等待很长总是不显示,但在 listview 上下滚动的时候显示出来了,求解

Android Fragment切换导致listview有数据也不显示

网上的方法基本上都试过了,没效果。 适配器能进getView(),返回的count也正常、 ``` ```public class Index extends AppCompatActivity { boolean flag = true;//判断数据是否第一加载 private List<listView> listView = new ArrayList<listView>(); private ListFragment listFragment = new ListFragment(); private MineFragment mineFragment = new MineFragment(); private OrderFragment orderFragment = new OrderFragment(); Fragment currentFragment = listFragment; FragmentManager fm = getSupportFragmentManager(); Fragment f = null; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_index); //解析菜单文件 initData(); final ListViewAdapter listViewAdapter = new ListViewAdapter(Index.this,R.layout.listlayout,listView); final ListView dataList = findViewById(R.id.Data_list); dataList.setAdapter(listViewAdapter); //导航图片设置初始化 ImageView imageView1 = findViewById(R.id.nav_index); ImageView imageView2 = findViewById(R.id.nav_order); ImageView imageView3 = findViewById(R.id.nav_mine); View.OnClickListener listener= new OnClickListener(){ @Override public void onClick(View v) { switch (v.getId()){ case R.id.nav_index: listViewAdapter.notifyDataSetChanged(); dataList.setAdapter(listViewAdapter); showFragment(listFragment); break; case R.id.nav_mine: showFragment(mineFragment); break; default: showFragment(orderFragment); break; } } }; imageView1.setOnClickListener(listener); imageView2.setOnClickListener(listener); imageView3.setOnClickListener(listener); } private void showFragment(Fragment fragment){ FragmentTransaction ft = fm.beginTransaction(); if (currentFragment != fragment){// 判断传入的fragment是不是当前的currentFragmentgit ft.hide(currentFragment);// 不是则隐藏 currentFragment = fragment; // 然后将传入的fragment赋值给currentFragment if (!fragment.isAdded()){ // 判断传入的fragment是否已经被add()过 ft.add(R.id.fragment,fragment).show(fragment).commit(); }else{ ft.show(fragment).commit(); } } } private void initData() { listView list = new listView("系统提示","测试内容信息","2019-3-14",R.drawable.shop1); listView.add(list); listView list1 = new listView("二号餐厅","测试内容信息","2019-3-14",R.drawable.shop2); listView.add(list1); } } 适配器代码 public class ListViewAdapter extends ArrayAdapter { private final int resourceId; public ListViewAdapter(Context context, int resource, List<listView> objects ) { super(context, resource, objects); this.resourceId = resource; } @Override public View getView(int position,View convertView, ViewGroup parent) { listView listView = (listView) getItem(position);// 获取当前项的Fruit实例 View view = LayoutInflater.from(getContext()).inflate(resourceId,null);//实例化一个对象 ImageView listImage = (ImageView) view.findViewById(R.id.shop_img);//获取该布局内的图片视图 TextView listText = (TextView) view.findViewById(R.id.shop_name);//获取该布局内的文字视图 listImage.setImageResource(listView.getImageId());//设置资源 listText.setText(listView.getTitle()); System.out.println("被调用"); return view; } } listview的Xml <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:background="@color/index_gray"> <LinearLayout android:orientation="horizontal" android:layout_width="match_parent" android:layout_height="match_parent"> <ListView android:layout_width="match_parent" android:layout_height="500dp" android:background="@color/index_white" android:id="@+id/Data_list"> </ListView> </LinearLayout> </FrameLayout> Activity.xml <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/con_index" android:layout_width="match_parent" android:background="@color/index_gray" android:layout_height="match_parent"> <fragment android:layout_width="match_parent" android:layout_height="600dp" android:name="com.example.administrator.app.ListFragment" android:id="@+id/fragment"/> <LinearLayout android:layout_width="wrap_content" android:layout_height="60dp" android:padding="5dp" android:orientation="horizontal" android:layout_alignParentBottom="true" android:background="@color/index_white"> <RelativeLayout android:layout_width="match_parent" android:layout_height="wrap_content" > <ImageView android:id="@+id/nav_index" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@mipmap/shouye" android:layout_alignParentLeft="true"/> <ImageView android:id="@+id/nav_order" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@mipmap/dingdan" android:layout_centerHorizontal="true"/> <ImageView android:id="@+id/nav_mine" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@mipmap/wode" android:layout_alignParentRight="true"/> </RelativeLayout> </LinearLayout> </RelativeLayout>

android listview点击显示文本获取文本对应的ID 值

本人刚接触android,现在有一个android listview点击显示文本获取文本相对应文本的ID值,我放了一个隐藏的textview,但是总是报错。现在没有思路不知道该怎么做这个,如果有相类似的实践demo能推荐一个最好。 ![图片说明](https://img-ask.csdn.net/upload/201801/31/1517377283_547158.png)

android listview 点击事件

``` public class CheckActivity extends AppCompatActivity { private List<ExpressIn> expressInList= new ArrayList<>(); private static String s_id; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_check); initExpressIns(); ExpressAdapter adapter=new ExpressAdapter(CheckActivity.this,R.layout.expresslayout,expressInList); ListView listView=(ListView)findViewById(R.id.list_view); listView.setAdapter(adapter); listView.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { Intent intent = new Intent(CheckActivity.this,detailActivity.class); ExpressIn expressIn22 = expressInList.get(position); Toast.makeText(CheckActivity.this,""+expressIn22,Toast.LENGTH_SHORT).show(); } }); } private void initExpressIns(){ List<ExpressIn> expressIns = DataSupport.findAll(ExpressIn.class); for(ExpressIn expressIn:expressIns){ String R_address=expressIn.getR_address(); String R_name=expressIn.getR_name(); String R_se=expressIn.getSelect(); ExpressIn expressIn1= new ExpressIn(R_name,R_address,R_se); expressInList.add(expressIn1); } } } ``` 为什么我点击事件里面 获得不到 expressIn22.getsid();

Map Listview adapter 之间的关系是什么

Map Listview adapter 之间的关系是什么 Map Listview adapter 之间的关系是什么

Android ListView重复加载的问题

我建立一个 ListViewView,并重写了自己的 adapter(继承BaseAdapter),数据源是一个ArrayList. ,ArrayList里的数据是 1,2,3。当我初始化 ListView时,显示的是 1,2,3。 以上看起来非常正常,但当我按 后退键,然后重新 进入 ListView的时候,诡异的事情就发生了。。 当我第二次进入 ListView的时候,屏幕上显示的 数据 成了 1,2,3, 1,2,3 . 然后我按下 后退键,再进入 ListView, 屏幕上的 数据 成了 1,2,3, 1,2,3 ,1,2,3 如此循环往复。。总之,每次进入ListView,都得重新读取ArrayList的数据。请问是什么原因导致的呢? 以下是adapter源码 public class chatListAdapter extends BaseAdapter{ private Context context; //运行上下文 private List<Map<String, Object>> listItems; //联系人信息集合 private LayoutInflater listContainer; //视图容器 private boolean[] hasChecked; //记录联系人选中状态 public final class ListItemView{ //自定义控件集合 public TextView RemoteAudio; public TextView LocalAudio; public TextView RemoteId; public TextView LocalId; public TextView MessageType; public ImageView RemoteImage; public ImageView LocalImage; public TextView RemoteSay; public TextView LocalSay; } public chatListAdapter(Context context, List<Map<String, Object>> listItems) { Log.v("construtor", "constructor11"); this.context = context; listContainer = LayoutInflater.from(context); //创建视图容器并设置上下文 this.listItems = listItems; hasChecked = new boolean[getCount()]; } @Override public int getCount() { // TODO Auto-generated method stub return listItems.size(); } @Override public Object getItem(int arg0) { // TODO Auto-generated method stub return null; } @Override public long getItemId(int arg0) { // TODO Auto-generated method stub return 0; } @Override public View getView(int position, View convertView, ViewGroup viewGroup) { // TODO Auto-generated method stub Log.v("getview","getview11"); final int selectID = position; ListItemView listItemView = null; listItemView = new ListItemView(); if (convertView == null) { //获取list_item布局文件的视图 convertView = listContainer.inflate(R.layout.chat_list_item, null); //获取控件对象 listItemView.RemoteAudio = (TextView)convertView.findViewById(R.id.RemoteAudio); listItemView.LocalAudio = (TextView)convertView.findViewById(R.id.LocalAudio); listItemView.RemoteId = (TextView)convertView.findViewById(R.id.RemoteId); listItemView.LocalId = (TextView)convertView.findViewById(R.id.LocalId); listItemView.MessageType= (TextView)convertView.findViewById(R.id.MessageType); listItemView.RemoteImage = (ImageView)convertView.findViewById(R.id.RemoteImage); listItemView.LocalImage=(ImageView)convertView.findViewById(R.id.RemoteImage); listItemView.RemoteSay=(TextView)convertView.findViewById(R.id.RemoteSay); listItemView.LocalSay=(TextView)convertView.findViewById(R.id.LocalSay); //设置控件集到convertView convertView.setTag(listItemView); }else{listItemView=(ListItemView)convertView.getTag();} //set rma,lca,mst,rid,lid into invisible //put data from list into view String strPosition=""+position; int RR=0; RR++; Log.v("11aa21","RR"+RR); listItemView.RemoteId.setText((String)listItems.get(position).get("RemoteId")); // String idd=Regist.generateId(); // listItemView.RemoteId.setText(" "+idd+" "); Log.v("11aa21","PositionI"+strPosition); Log.v("RemoteID","Remote+"+(String)listItems.get(position).get("RemoteId")); listItemView.LocalId.setText((String) listItems.get(position).get("LocalId")); Log.v("11aa21","PositionI"+strPosition); Log.v("RemoteID","LocalID+"+(String)listItems.get(position).get("LocalId")); //// listItemView.RemoteAudio.setText((String)listItems.get(position).get("RemoteAudio")); listItemView.LocalAudio.setText((String)listItems.get(position).get("LocalAudio")); //// listItemView.MessageType.setText((String)listItems.get(position).get("MessageType")); /// listItemView.RemoteImage.setBackgroundResource(R.drawable.ic_launcher); listItemView.LocalImage.setBackgroundResource(R.drawable.ic_launcher); /// listItemView.RemoteSay.setText((String)listItems.get(position).get("RemoteSay")); listItemView.LocalSay.setText((String)listItems.get(position).get("LocalSay")); // String idd=Regist.generateId(); // listItemView.LocalSay.setText(idd); // listItemView.RemoteSay.setText("rms"+position); Log.i("tttt","ttttt"+listItemView.LocalSay.getText().toString()); //decide wether Ls,LI,RS,RI invisible //if msgtype=??,then set..invisible,set XX onclick method=?? String MsgType=listItemView.MessageType.getText().toString(); Log.i("msgt",MsgType); if (MsgType.equals("9d")){ Log.v("MsgType", "Text"); listItemView.LocalSay.setVisibility(View.INVISIBLE); listItemView.LocalImage.setVisibility(View.INVISIBLE); listItemView.RemoteSay.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub Log.v("1ab",((TextView) v).getText().toString()); Toast.makeText(null, "111",Toast.LENGTH_LONG).show(); } }); } return convertView; } }

Android ListView OnItemSelectedListener时间不能被触发?

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_margin="@dimen/activity_horizontal_margin" android:orientation="horizontal" tools:context=".MainActivity"> <ListView android:id="@+id/mainlist" android:layout_width="match_parent" android:layout_height="match_parent" android:listSelector="@drawable/selector3"> </ListView> </LinearLayout> ListView mainlist=(ListView)findViewById(R.id.mainlist); mainlist.setChoiceMode(AbsListView.CHOICE_MODE_SINGLE); String[] arr1={"第一栏","第二栏","第三栏","第四栏","第五栏"}; ArrayAdapter<String> adapter1=new ArrayAdapter<String>(this,R.layout.layout_app_setting_listitem,arr1); mainlist.setAdapter(adapter1); mainlist.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() { @Override public void onItemSelected(AdapterView<?> parent, View view, int position, long id) { System.out.println(position); } @Override public void onNothingSelected(AdapterView<?> parent) { System.out.println("没有做出选择"); } }); 代码如何可是点击时不会触发该事件时什么原因,Click是可以触发的但是ItemSelected就是不行不知道什么原因,求大神解答

初级玩转Linux+Ubuntu(嵌入式开发基础课程)

课程主要面向嵌入式Linux初学者、工程师、学生 主要从一下几方面进行讲解: 1.linux学习路线、基本命令、高级命令 2.shell、vi及vim入门讲解 3.软件安装下载、NFS、Samba、FTP等服务器配置及使用

我以为我对Mysql事务很熟,直到我遇到了阿里面试官

太惨了,面试又被吊打

Python代码实现飞机大战

文章目录经典飞机大战一.游戏设定二.我方飞机三.敌方飞机四.发射子弹五.发放补给包六.主模块 经典飞机大战 源代码以及素材资料(图片,音频)可从下面的github中下载: 飞机大战源代码以及素材资料github项目地址链接 ————————————————————————————————————————————————————————— 不知道大家有没有打过飞机,喜不喜欢打飞机。当我第一次接触这个东西的时候,我的内心是被震撼到的。第一次接触打飞机的时候作者本人是身心愉悦的,因为周边的朋友都在打飞机, 每

Python数据分析与挖掘

92讲视频课+16大项目实战+源码+¥800元课程礼包+讲师社群1V1答疑+社群闭门分享会=99元 &nbsp; 为什么学习数据分析? &nbsp; &nbsp; &nbsp; 人工智能、大数据时代有什么技能是可以运用在各种行业的?数据分析就是。 &nbsp; &nbsp; &nbsp; 从海量数据中获得别人看不见的信息,创业者可以通过数据分析来优化产品,营销人员可以通过数据分析改进营销策略,产品经理可以通过数据分析洞察用户习惯,金融从业者可以通过数据分析规避投资风险,程序员可以通过数据分析进一步挖掘出数据价值,它和编程一样,本质上也是一个工具,通过数据来对现实事物进行分析和识别的能力。不管你从事什么行业,掌握了数据分析能力,往往在其岗位上更有竞争力。 &nbsp;&nbsp; 本课程共包含五大模块: 一、先导篇: 通过分析数据分析师的一天,让学员了解全面了解成为一个数据分析师的所有必修功法,对数据分析师不在迷惑。 &nbsp; 二、基础篇: 围绕Python基础语法介绍、数据预处理、数据可视化以及数据分析与挖掘......这些核心技能模块展开,帮助你快速而全面的掌握和了解成为一个数据分析师的所有必修功法。 &nbsp; 三、数据采集篇: 通过网络爬虫实战解决数据分析的必经之路:数据从何来的问题,讲解常见的爬虫套路并利用三大实战帮助学员扎实数据采集能力,避免没有数据可分析的尴尬。 &nbsp; 四、分析工具篇: 讲解数据分析避不开的科学计算库Numpy、数据分析工具Pandas及常见可视化工具Matplotlib。 &nbsp; 五、算法篇: 算法是数据分析的精华,课程精选10大算法,包括分类、聚类、预测3大类型,每个算法都从原理和案例两个角度学习,让你不仅能用起来,了解原理,还能知道为什么这么做。

如何在虚拟机VM上使用串口

在系统内核开发中,经常会用到串口调试,利用VMware的Virtual Machine更是为调试系统内核如虎添翼。那么怎么搭建串口调试环境呢?因为最近工作涉及到这方面,利用强大的google搜索和自己

程序员的兼职技能课

获取讲师答疑方式: 在付费视频第一节(触摸命令_ALL)片头有二维码及加群流程介绍 限时福利 原价99元,今日仅需39元!购课添加小助手(微信号:csdn590)按提示还可领取价值800元的编程大礼包! 讲师介绍: 苏奕嘉&nbsp;前阿里UC项目工程师 脚本开发平台官方认证满级(六级)开发者。 我将如何教会你通过【定制脚本】赚到你人生的第一桶金? 零基础程序定制脚本开发课程,是完全针对零脚本开发经验的小白而设计,课程内容共分为3大阶段: ①前期将带你掌握Q开发语言和界面交互开发能力; ②中期通过实战来制作有具体需求的定制脚本; ③后期将解锁脚本的更高阶玩法,打通任督二脉; ④应用定制脚本合法赚取额外收入的完整经验分享,带你通过程序定制脚本开发这项副业,赚取到你的第一桶金!

MFC一站式终极全套课程包

该套餐共包含从C小白到C++到MFC的全部课程,整套学下来绝对成为一名C++大牛!!!

C++语言基础视频教程

C++语言基础视频培训课程:本课与主讲者在大学开出的程序设计课程直接对接,准确把握知识点,注重教学视频与实践体系的结合,帮助初学者有效学习。本教程详细介绍C++语言中的封装、数据隐藏、继承、多态的实现等入门知识;主要包括类的声明、对象定义、构造函数和析构函数、运算符重载、继承和派生、多态性实现等。 课程需要有C语言程序设计的基础(可以利用本人开出的《C语言与程序设计》系列课学习)。学习者能够通过实践的方式,学会利用C++语言解决问题,具备进一步学习利用C++开发应用程序的基础。

北京师范大学信息科学与技术学院笔试10复试真题

北京师范大学信息科学与技术学院笔试,可以更好的让你了解北师大该学院的复试内容,获得更好的成绩。

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

网络工程师小白入门--【思科CCNA、华为HCNA等网络工程师认证】

本课程适合CCNA或HCNA网络小白同志,高手请绕道,可以直接学习进价课程。通过本预科课程的学习,为学习网络工程师、思科CCNA、华为HCNA这些认证打下坚实的基础! 重要!思科认证2020年2月24日起,已启用新版认证和考试,包括题库都会更新,由于疫情原因,请关注官网和本地考点信息。题库网络上很容易下载到。

Python界面版学生管理系统

前不久上传了一个控制台版本的学生管理系统,这个是Python界面版学生管理系统,这个是使用pycharm开发的一个有界面的学生管理系统,基本的增删改查,里面又演示视频和完整代码,有需要的伙伴可以自行下

软件测试2小时入门

本课程内容系统、全面、简洁、通俗易懂,通过2个多小时的介绍,让大家对软件测试有个系统的理解和认识,具备基本的软件测试理论基础。 主要内容分为5个部分: 1 软件测试概述,了解测试是什么、测试的对象、原则、流程、方法、模型;&nbsp; 2.常用的黑盒测试用例设计方法及示例演示;&nbsp; 3 常用白盒测试用例设计方法及示例演示;&nbsp; 4.自动化测试优缺点、使用范围及示例‘;&nbsp; 5.测试经验谈。

Tomcat服务器下载、安装、配置环境变量教程(超详细)

未经我的允许,请不要转载我的文章,在此郑重声明!!! 请先配置安装好Java的环境,若没有安装,请参照我博客上的步骤进行安装! 安装Java环境教程https://blog.csdn.net/qq_40881680/article/details/83585542 Tomcat部署Web项目(一)·内嵌https://blog.csdn.net/qq_40881680/article/d...

2019数学建模A题高压油管的压力控制 省一论文即代码

2019数学建模A题高压油管的压力控制省一完整论文即详细C++和Matlab代码,希望对同学们有所帮助

图书管理系统(Java + Mysql)我的第一个完全自己做的实训项目

图书管理系统 Java + MySQL 完整实训代码,MVC三层架构组织,包含所有用到的图片资源以及数据库文件,大三上学期实训,注释很详细,按照阿里巴巴Java编程规范编写

linux下利用/proc进行进程树的打印

在linux下利用c语言实现的进程树的打印,主要通过/proc下的目录中的进程文件,获取status中的进程信息内容,然后利用递归实现进程树的打印

微信小程序开发实战之番茄时钟开发

微信小程序番茄时钟视频教程,本课程将带着各位学员开发一个小程序初级实战类项目,针对只看过官方文档而又无从下手的开发者来说,可以作为一个较好的练手项目,对于有小程序开发经验的开发者而言,可以更好加深对小程序各类组件和API 的理解,为更深层次高难度的项目做铺垫。

[已解决]踩过的坑之mysql连接报“Communications link failure”错误

目录 前言 第一种方法: 第二种方法 第三种方法(适用于项目和数据库在同一台服务器) 第四种方法 第五种方法(项目和数据库不在同一台服务器) 总结 前言 先给大家简述一下我的坑吧,(我用的是mysql,至于oracle有没有这样的问题,有心的小伙伴们可以测试一下哈), 在自己做个javaweb测试项目的时候,因为买的是云服务器,所以数据库连接的是用ip地址,用IDE开发好...

人工智能-计算机视觉实战之路(必备算法+深度学习+项目实战)

系列课程主要分为3大阶段:(1)首先掌握计算机视觉必备算法原理,结合Opencv进行学习与练手,通过实际视项目进行案例应用展示。(2)进军当下最火的深度学习进行视觉任务实战,掌握深度学习中必备算法原理与网络模型架构。(3)结合经典深度学习框架与实战项目进行实战,基于真实数据集展开业务分析与建模实战。整体风格通俗易懂,项目驱动学习与就业面试。 建议同学们按照下列顺序来进行学习:1.Python入门视频课程 2.Opencv计算机视觉实战(Python版) 3.深度学习框架-PyTorch实战/人工智能框架实战精讲:Keras项目 4.Python-深度学习-物体检测实战 5.后续实战课程按照自己喜好选择就可以

2019 AI开发者大会

2019 AI开发者大会(AI ProCon 2019)是由中国IT社区CSDN主办的AI技术与产业年度盛会。多年经验淬炼,如今蓄势待发:2019年9月6-7日,大会将有近百位中美顶尖AI专家、知名企业代表以及千余名AI开发者齐聚北京,进行技术解读和产业论证。我们不空谈口号,只谈技术,诚挚邀请AI业内人士一起共铸人工智能新篇章!

机器学习初学者必会的案例精讲

通过六个实际的编码项目,带领同学入门人工智能。这些项目涉及机器学习(回归,分类,聚类),深度学习(神经网络),底层数学算法,Weka数据挖掘,利用Git开源项目实战等。

Python数据分析师-实战系列

系列课程主要包括Python数据分析必备工具包,数据分析案例实战,核心算法实战与企业级数据分析与建模解决方案实战,建议大家按照系列课程阶段顺序进行学习。所有数据集均为企业收集的真实数据集,整体风格以实战为导向,通俗讲解Python数据分析核心技巧与实战解决方案。

YOLOv3目标检测实战系列课程

《YOLOv3目标检测实战系列课程》旨在帮助大家掌握YOLOv3目标检测的训练、原理、源码与网络模型改进方法。 本课程的YOLOv3使用原作darknet(c语言编写),在Ubuntu系统上做项目演示。 本系列课程包括三门课: (1)《YOLOv3目标检测实战:训练自己的数据集》 包括:安装darknet、给自己的数据集打标签、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算和画出PR曲线)和先验框聚类。 (2)《YOLOv3目标检测:原理与源码解析》讲解YOLOv1、YOLOv2、YOLOv3的原理、程序流程并解析各层的源码。 (3)《YOLOv3目标检测:网络模型改进方法》讲解YOLOv3的改进方法,包括改进1:不显示指定类别目标的方法 (增加功能) ;改进2:合并BN层到卷积层 (加快推理速度) ; 改进3:使用GIoU指标和损失函数 (提高检测精度) ;改进4:tiny YOLOv3 (简化网络模型)并介绍 AlexeyAB/darknet项目。

2021考研数学张宇基础30讲.pdf

张宇:博士,全国著名考研数学辅导专家,教育部“国家精品课程建设骨干教师”,全国畅销书《张宇高等数学18讲》《张宇线性代数9讲》《张宇概率论与数理统计9讲》《张宇考研数学题源探析经典1000题》《张宇考

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

DirectX修复工具V4.0增强版

DirectX修复工具(DirectX Repair)是一款系统级工具软件,简便易用。本程序为绿色版,无需安装,可直接运行。 本程序的主要功能是检测当前系统的DirectX状态,如果发现异常则进行修复

期末考试评分标准的数学模型

大学期末考试与高中的考试存在很大的不同之处,大学的期末考试成绩是主要分为两个部分:平时成绩和期末考试成绩。平时成绩和期末考试成绩总分一般为一百分,然而平时成绩与期末考试成绩所占的比例不同会导致出现不同

Vue.js 2.0之全家桶系列视频课程

基于新的Vue.js 2.3版本, 目前新全的Vue.js教学视频,让你少走弯路,直达技术前沿! 1. 包含Vue.js全家桶(vue.js、vue-router、axios、vuex、vue-cli、webpack、ElementUI等) 2. 采用笔记+代码案例的形式讲解,通俗易懂

c语言项目开发实例

十个c语言案例 (1)贪吃蛇 (2)五子棋游戏 (3)电话薄管理系统 (4)计算器 (5)万年历 (6)电子表 (7)客户端和服务器通信 (8)潜艇大战游戏 (9)鼠标器程序 (10)手机通讯录系统

相关热词 c# 不能序列化继承类 c# char* 调用 c# 开发dll模板 c#添加控件到工具箱 c#控制台组合数 编程计算猴子吃桃问题c# c# wpf 背景透明 随机抽取号码软件c# c# 开发环境 c# 属性和字段
立即提问