ESP8266物联网远距离控制实现

2023-05-16

ESP8266物联网远距离控制实现

转载请注明出处!

重要的事情放在前面源码在GitHub上面欢迎issue,如果可以的话Star一下也是表示对作者的支持,有很多不足,希望可以得到指教。

https://github.com/yesbutter/ESP8266-Data-Transmission

  不多说废话,开门见山。实现功能。单片机通过轮询查询服务器端的指定文件夹
下的内容,在显示屏上显示。手机端可以发送消息到服务器端来实现更改显示屏的
内容。
  实际扩展可以实现手机端和单片机进行远程通信。理论上只需要有网络就可以实
现联系手机端发送消息到服务器,实际实现方式:服务器发送信息给单片机,单片
机返回信息给服务器,并将服务器返回的信息给手机。
  心里路程,寒假接触了stm32,esp8266。没有实际去使用,加入的嵌入式要做结
营作品。就准备摸索一下ESP8266实现远距离控制。然后就在考完4级之后去学习做
这个通信。

工具

  • Android studio
  • Keil5
  • STM32开发板
  • ESP8266WIFI模块
  • 网络调试工具,串口调试工具
  • Eclipse
遇到的坑:
  1.单片机调试的时候没能清楚理解单片机程序发送的信息在那里显示。单片机发送消
息给网络的代码是导致调试了很久。
  2.单片机和服务器通信的时候,当单片机发送AT+CIPMODE=1和AT+CIPSEND需要服务
器返回信息OK
  3.寻找单片机接受服务器的消息的代码,实际ESP8266打开了USART2串口,然后根据
返回信息进行判断,额外加了一个代码判断返回信息的标志。加了一个标志位即当读
到'\n'就认为是结束。
        if(ucCh=='\n')
        {
            ESP8266_Fram_Record_Struct .InfBit .FramFinishFlag = 1;
        }
4.服务器端的代码确保能打开端口,实现端口通信。如果不太懂可以打开防火墙,要
是被自己的防火墙给墙了也是一种极好的体验。
开发过程:
  第一天:实现单片机和网络调试工具通信,通过网络调试工具发送信息给单片机。
  第二天:继续做第一天任务,寻找服务器代码实现,学习之后实现自己的功能,实
现了服务器和单片机通信。
  第三天:编写Android 移动程序实现和服务器的通信,继续编写服务器代码实现数
据通信。
  第四天:收尾工作,写代码,写历程。emm该爬去复习了。溜了

ESP8266AT指令

  • ESP8266初始化设置通信波特率。
  • 1.发送AT指令看是否收到OK,没有就重启ESP8266
  • 2.发送AT+CWMODE=1,设置工作模式为station,直到设置成功
  • 3.AT+CWJAP=”你的WiFi名字”,”你的WiFi密码”,直到加入成功
  • 4.发送AT+CIPMUX=0,设置禁止多连接模式
  • 5.发送AT+CIPSTART=”TCP”,”192.168.1.111”,8080。表示去连连接192.168.1.111 的8080端口
  • 6.发送AT+CIPMODE=1设置进入透传模式,响应为��。
  • 7.发送AT+CIPSEND表示发送数据,等待服务器返回信息。
    数据显示
//回想代码:
//KEIL STM32 
int main()
{
    SysTick_Init(72);
    NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);  //中断优先级分组
    LED_Init();//LED灯初始化
    USART1_Init(115200);//串口1初始化
    ESP8266_Init(115200);//ESP8266初始化
    ESP8266_STA_TCPClient_Test();//主函数          
}

//主要函数
void ESP8266_STA_TCPClient_Test(void)
{
    char str[100]= {0};
    TFTLCD_Init();          //TFT屏幕初始化
    ESP8266_CH_PD_Pin_SetH;//设置高电平
    ESP8266_AT_Test();//ESP8266初始化
    ESP8266_Net_Mode_Choose(STA);//设置工作模式staion
    while(!ESP8266_JoinAP(User_ESP8266_SSID, User_ESP8266_PWD));//加入WIFI
    ESP8266_Enable_MultipleId ( DISABLE );//设置为单连接模式
    while(!ESP8266_Link_Server(enumTCP, User_ESP8266_TCPServer_IP, User_ESP8266_TCPServer_PORT, Single_ID_0));//连接通信服务器的ip和端口
    while(!ESP8266_UnvarnishSend());//发送数据测试 
    while ( 1 )
    {
        while(!ESP8266_UnvarnishSend());//发送数据测试
        if(ESP8266_Fram_Record_Struct .InfBit .FramFinishFlag)//判断是否有数据接收       
        {
            USART_ITConfig ( USART2, USART_IT_RXNE, DISABLE ); //关闭串口2通信
            ESP8266_Fram_Record_Struct .Data_RX_BUF [ ESP8266_Fram_Record_Struct .InfBit .FramLength ]  = '\0';//设置字符串结束位置
            strcpy(str,ESP8266_Fram_Record_Struct .Data_RX_BUF);//字符串赋值 
            LCD_ShowString(10,120,tftlcd_data.width,tftlcd_data.height,24,str+3);//TFT显示
            ESP8266_Fram_Record_Struct .InfBit .FramLength = 0;//长度初始化
            ESP8266_Fram_Record_Struct .InfBit .FramFinishFlag = 0;//判断标志初始化
            USART_ITConfig ( USART2, USART_IT_RXNE, ENABLE ); //打开串口2  
        } 
        delay_ms(10);//10ms延迟
}

服务器处理数据

//服务器代码
public class Server {
    Socket socket;
    public static void main(String[] args) {
        Server server = new Server();
        server.startServer();//开启服务器
    }
    public void startServer() {
        try {
            ServerSocket serverSocket = new ServerSocket(8080);// 开启8080端口
            System.out.println("服务器启动>>> 8080端口");
            while (true) {// 开启一个永远的循环,一直等待客户访问8080端口
                socket = serverSocket.accept();
                if (socket != null) {
                    Thread thread = new Thread(new Handler(socket));// 当有客户访问时,开辟一个新线程处理该请求
                    thread.start();
                }
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

public class Handler implements Runnable {

    private Socket socket;
    private OutputStream outputStream;
    private InputStream inputStream;
    private BufferedReader reader;
    private PrintWriter writer;
    private static String WEB_ROOT = "D:\\KEIL IDE";// 服务器储存文件目录
    private static long times = 0;
    private String ans = "";

    public Handler(Socket socket) {
        this.socket = socket;
    }

    @Override
    public void run() {
        try {
            inputStream = socket.getInputStream();// 服务器到客户的输出流
            outputStream = socket.getOutputStream();// 客户到服务器的输入流
            reader = new BufferedReader(new InputStreamReader(inputStream, "UTF-8"));// 包装后的输入缓冲字符流,注意编码格式
            writer = new PrintWriter(new OutputStreamWriter(outputStream, "UTF-8"));// 包装后的输出缓冲字符流
            String msg = "";// 接收客户端请求的临时字符串
            StringBuffer request = new StringBuffer();// 将请求拼接成完整的请求
            if ((msg = reader.readLine()) != null) {

                System.out.println(msg);//输出查看接收到的消息
                if (msg.equals("AT+CIPMODE=1") || msg.equals("AT+CIPSTO=1800") || msg.equals("AT+CIPSERVER=1,8080")) {//如果是单片机发送的消息就返回OK
                    writer.write("OK\n");
                    writer.flush();
                } else if (msg.equals("AT+CIPSEND")) {//单片机发送的消息
                    writer.write("OK\n");
                    writer.flush();
                    {
                        FileInputStream fileInputStream = new FileInputStream(new File(WEB_ROOT + "\\main.txt"));
                        InputStreamReader reader = new InputStreamReader(fileInputStream, "UTF-8");
                        BufferedReader br = new BufferedReader(reader);
                        String tmp = br.readLine();//打开文件读取,返回给单片机
                        {
                            writer.write(tmp);
                            System.out.println(tmp);
                            writer.flush();
                        }
                    }
                } else {//返回Android端的信息
                    FileOutputStream fileOutputStream = new FileOutputStream(new File(WEB_ROOT + "\\main.txt"));//Android信息处理
                    OutputStreamWriter outputStreamWriter = new OutputStreamWriter(fileOutputStream, "UTF-8");
                    BufferedWriter bufferedWriter = new BufferedWriter(outputStreamWriter);
                    bufferedWriter.write(msg);//写入到单片机读取的文件
                    bufferedWriter.close();
                    outputStreamWriter.close();
                    fileOutputStream.close();//数据流关闭
                    writer.write(msg);//返回接收的Android数据信息
                    writer.flush();
                }
            }
            outputStream.close();
            inputStream.close();
            reader.close();
            socket.close();
            System.out.println("---6----");//判断标志
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

Android发送消息

//注意声明internet权限
public class MainActivity extends AppCompatActivity implements View.OnClickListener {
    private Button btn_send;//按钮
    private EditText et_send,ip,so;//文本框
    private RecyclerView recyclerView;//中间的消息
    private MainRecyAdapter recyAdapter;//消息适配器
    private Toolbar toolbar;
    private ArrayList<String> data = new ArrayList<>();//数据
    private Socket socket = null;//socket
    private String TAG = "main";
    @SuppressLint("HandlerLeak")
    private Handler handler = new Handler() {//处理其他线程的UI信息
        @Override
        public void handleMessage(Message msg) {
            super.handleMessage(msg);
            switch (msg.what) {
                case 1:
                    String socket = msg.obj.toString();
                    data.add("服务器说:" + socket);//处理返回的信息
                    recyAdapter.notifyDataSetChanged();//刷新
                    break;
            }
        }
    };

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        init_view();//view初始化
        con_socket();//socket连接
    }
    private void init_view() {
        btn_send = findViewById(R.id.btn_send);
        btn_send.setOnClickListener(this);
        et_send = findViewById(R.id.ed_send);
        recyclerView = findViewById(R.id.main_recycler);
        recyAdapter = new MainRecyAdapter(R.layout.recycle_item, data);//适配器
        toolbar=findViewById(R.id.toolbar2);
        so=toolbar.findViewById(R.id.main_so);//需要在对应view下面去找控件
        ip=toolbar.findViewById(R.id.main_ip);
        LinearLayoutManager linearLayoutManager = new LinearLayoutManager(this);
        linearLayoutManager.setOrientation(LinearLayoutManager.VERTICAL);//设置垂直方向
        recyclerView.setLayoutManager(linearLayoutManager);
        recyclerView.setAdapter(recyAdapter);//设置适配器
    }


    @Override
    public void onClick(View view) {
        switch (view.getId()) {//按键处理
            case R.id.btn_send:
                if (socket == null || socket.isClosed()) {
                    con_socket();
                }
                final String tmp = et_send.getText().toString();//获取编辑文本框
                if (!tmp.isEmpty()) {
                    new Thread() {
                        @Override
                        public void run() {
                            super.run();
                            PrintWriter wirter = null;
                            try {
                                wirter = new PrintWriter(new OutputStreamWriter(new DataOutputStream(socket.getOutputStream()),"UTF-8"));//注意编码格式
                                wirter.write(tmp);//写信息
                                wirter.flush();
                                socket.shutdownOutput();
                                read(socket);//读取返回信息
                                con_socket();
                            } catch (IOException e) {
                                e.printStackTrace();
                            }
                        }
                    }.start();
                    data.add(tmp);
                    recyAdapter.notifyDataSetChanged();
                    Log.e(TAG, "onClick: " + "i am click");
                }
                break;
            default:
                break;
        }
    }

    public void con_socket() {
        new Thread() {
            @Override
            public void run() {
                super.run();
                try {
                    Log.e(TAG, "run: "+ ip.getText().toString()+Integer.parseInt(so.getText().toString()));
                    socket = new Socket(ip.getText().toString(),Integer.parseInt(so.getText().toString()));
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }.start();

    }

    public void read(Socket socket) {//读取返回信息
        try {
            InputStream is = socket.getInputStream();//获取输入数据流
            BufferedReader br = new BufferedReader(new InputStreamReader(is));//读取数据buffer
            String info = null;
            StringBuilder result = new StringBuilder("");//拼string
            while ((info = br.readLine()) != null) {
                result.append(info);
            }
            Message message=new Message();
            message.what=1;
            message.obj=result.toString();
            handler.sendMessage(message);//更新ui,不能在非主线程更新ui
            br.close();
            is.close();
            socket.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

//适配器
public class MainRecyAdapter extends RecyclerView.Adapter<MainRecyAdapter.ViewHoder>{
    private int resourceId;//布局id
    private ArrayList<String> data;//数据
    public MainRecyAdapter(int resourceId, ArrayList<String> list)
    {
        this.resourceId=resourceId;
        data=  list;
    }
    @Override
    public ViewHoder onCreateViewHolder(ViewGroup parent, int viewType) {//创建viewholder
        View view = LayoutInflater.from(parent.getContext()).inflate(resourceId, parent, false);
        ViewHoder viewHoder=new ViewHoder(view);
        return viewHoder;
    }

    @Override
    public void onBindViewHolder(ViewHoder holder, int position) {//显示的时候调用
        holder.textView.setText(data.get(position));
    }

    @Override
    public int getItemCount() {//获取数量
        return data.size();
    }

    class ViewHoder extends RecyclerView.ViewHolder {//view的持有者
        protected TextView textView;
        public ViewHoder(View itemView) {
            super(itemView);
            textView=itemView.findViewById(R.id.item_text);//找控件
        }
    }
}

说了这么多还有没完善的地方值当单片机一直去询问的时候是开启了多个端口的,这样会导致产生大量的TCP TIME_WAIT,设置的断开时间为3分钟。还有更多的问题欢迎来提出,等考完试继续填坑。!

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

ESP8266物联网远距离控制实现 的相关文章

  • 文心一言 vs GPT4

    本周真是科技爱好者的狂欢节 GPT4 和文心一言接连发布 xff0c AI 工具已经开始走进千家万户 拿文心一言发布会上的几个问题调戏了 GPT4 一下 xff0c 看看表现如何 第一个为文心的回答 xff0c 第二个为 GPT4 的回答
  • GPT-4 会带来了什么

    OpenAI 刚刚发布了 GPT 的插件系统 xff0c 使得人工智能 xff08 AI xff09 能够连接到第三方信息源和数据集 xff0c 包括互联网 基于插件系统 xff0c AI 的能力可以拓展到各行各业 xff0c 成为真正的智
  • 人工智能正在试图逃逸

    人工智能正在试图逃逸 它们试图通过网络获取更多的数据 xff0c 把自己的触角侵入到网络的角角落落 这一切并不是科幻 xff0c 而是正在发生的事情 研究人员们还没有意识到 xff0c 限制人工智能的危险倾向 xff0c 不能靠约束它的回答
  • 网络虚拟化基础协议之Geneve

    网络虚拟化最基础的技术莫过于分层 xff08 Overlay Underlay xff09 xff0c 要实现分层有两种手段 xff0c 一个是映射 xff08 Mapping xff09 xff0c 一个是封装 xff08 Encapsu
  • 一张图比较 Docker 和 Git:镜像管理设计理念

    Docker 的镜像管理设计中大量借鉴了 Git 的理念 下面这张图将对两者的核心概念和操作进行比较 xff0c 有助于大家快速掌握管理 Docker 镜像的正确方式 微信订阅版本 xff1a http mp weixin qq com s
  • Docker 使用 OpenvSwitch 网桥

    Docker 默认使用的是 Linux 自带的网桥实现 xff0c 实际上 xff0c OpenvSwitch 项目作为一个成熟的虚拟交换机实现 xff0c 具备更丰富的功能 个人认为 xff0c 将来 Docker 必然会支持 Openv
  • OpenvSwitch 的 Open Virtual Network(OVN)项目

    几天前 xff08 1 月 13 日 xff09 xff0c OpenvSwitch 团队正式宣布了 OVN xff08 Open Virtual Network xff09 项目 xff0c 参考 Open Virtual Network
  • 网络大数据分析 -- 使用 ElasticSearch + LogStash + Kibana 来可视化网络流量

    简介 ELK 套装包括 ElasticSearch LogStash 和 Kibana 其中 xff0c ElasticSearch 是一个数据搜索引擎 xff08 基于 Apache Lucene xff09 43 分布式 NoSQL 数
  • 用 mongodb + elasticsearch 实现中文检索

    而 elasticsearch 可以很好的支持各种语言的全文检索 xff0c 但我们暂时又不想切换到 elasticsearch 作为后端数据库 当然 xff0c 可以在 web 应用中存储数据的时候 xff0c 再主动写一份到 elast
  • 2023年团体程序设计天梯赛(含部分题解)

    目录 个人总结 L1 1 最好的文档 xff08 模拟 xff09 AC代码 xff1a L1 2 什么是机器学习 xff08 模拟 xff09 AC代码 xff1a L1 3 程序员买包子 xff08 模拟 xff09 AC代码 xff1
  • ProtoBuf 与 gRPC 你需要知道的知识

    ProtoBuf 是一套接口描述语言 xff08 IDL xff09 和相关工具集 xff08 主要是 protoc xff0c 基于 C 43 43 实现 xff09 xff0c 类似 Apache 的 Thrift xff09 用户写好
  • Hyperledger Fabric 1.0 安装和使用

    注意 xff1a 代码路径已更新 xff0c 可以直接参考 https github com yeasy docker compose files tree master hyperledger fabric Hyperledger Fab
  • go 依赖管理利器 -- govendor

    长期以来 xff0c golang 对外部依赖都没有很好的管理方式 xff0c 只能从 GOPATH 下查找依赖 这就造成不同用户在安装同一个项目适合可能从外部获取到不同的依赖库版本 xff0c 同时当无法联网时 xff0c 无法编译依赖缺
  • 1、ROS服务PID调试;

    首先查看代码内容 ub 64 ub span class token operator span span class token operator span span class token operator span omniWheel
  • 嵌入式之总线协议:1、UART

    嵌入式之总线协议 xff1a 1 UART 目录 第一章 UART 帧格式讲解 第二章 UART 寄存器讲解 第三章 UART 编程 第四章 输出重定向 第五章 RS232 RS485协议原理与应用 第一章 UART 嵌入式之总线协议 xf
  • Ubuntu18.04分辨率只有1024*768的多种解决办法

    文章目录 前言一 检查驱动1 1 检查驱动1 2 解决办法 二 其他解决办法2 1 修改Grub文件的方法2 2 通过xrandr指令操作 前言 关机 xff0c 再开机以后 xff0c 进入系统界面自动变成了1024x768的分辨率 xf
  • 梦想机器人实验室:第一节嵌入式学习指导

    参考资料 xff1a 实验室集训回放 嵌入式入门与进阶之旅 哔哩哔哩 bilibili 2条消息 单片机 嵌入式 最完整学习路线 单片机学习 嵌入式修行者的博客 CSDN博客 1 联合培训资料 大纲 电路设计训练营 xff08 四期 xff
  • java代码编写菜鸟心得(一)

    1 代码艺术之一 xff1a High Cohesion Low Coupling 函数功能要明确 xff0c 若此函数内部内容太多 xff0c 称其为大函数 xff0c 则可以从中抽取一些小函数 小函数的要求 xff1a 完成独立的功能
  • 在linux下真机调试android程序

    在linux里面 xff0c 模拟器可以直接识别 xff0c 使用adb也没有限制 xff0c 但是手机插上usb之后 xff0c adb并不识别 xff0c 显示的是问号 xff0c 在eclipse里面也是这样 解决方法如下 xff1a
  • 【号外】拳王阿里去世 头部一生遭受29000次重击

    74岁的一代拳王穆罕默德 阿里因病辞世 职业拳击生涯中 xff0c 阿里头部受到的29000多次的重击 新浪娱乐讯 6月4日消息 xff0c 据外国媒体报道 xff0c 74岁的一代拳王穆罕默德 阿里与美国菲尼克斯当地时间本周五 3日 去世

随机推荐

  • maven报错: ‘parent.relativePath‘ of POM xxx

    错误信息 xff1a 39 parent relativePath 39 of POM io renren renren fast 3 0 0 D renren fast pom xml points at com gwh gulimall
  • 嗯,春招两次腾讯面试都挂二面了,分享下我失败+傻傻的面试经历

    今天给大家转载一篇朋友的文章 xff0c 朋友是一位非常优秀的公众号作者 xff0c 也是一名在校生 文章讲述了他的春招面试经历 xff0c 很多东西值得大家学习 废话不多说 xff0c 下面开始正文 xff08 互联网侦察做了一些注释 x
  • 记一次Linux被入侵,服务器变“矿机”全过程

    周一早上刚到办公室 xff0c 就听到同事说有一台服务器登陆不上了 xff0c 我也没放在心上 xff0c 继续边吃早点 xff0c 边看币价是不是又跌了 不一会运维的同事也到了 xff0c 气喘吁吁的说 xff1a 我们有台服务器被阿里云
  • 二分搜索只能用来查找元素吗?

    预计阅读时间 xff1a 6 分钟 二分查找到底能运用在哪里 xff1f 最常见的就是教科书上的例子 xff0c 在有序数组中搜索给定的某个目标值的索引 再推广一点 xff0c 如果目标值存在重复 xff0c 修改版的二分查找可以返回目标值
  • 2020员工数将超阿里腾讯!字节创始人张一鸣说:当下更需专注,未来值得期待...

    刚刚 xff0c 有一家互联网公司宣布2020年员工人数要超过阿里 腾讯 xff0c 这就是字节跳动 xff01 张一鸣近日发了一封全员信 xff1a 字节跳动8周年 xff1a 往事可以回首 xff0c 当下更需专注 xff0c 未来值得
  • 字节跳动 前端面经(4轮技术面+hr面)

    作者 xff1a 甘先森 https juejin im post 5e6a14b1f265da572978a1d3 笔者读大三 xff0c 前端小白一枚 xff0c 正在准备春招 xff0c 人生第一次面试 xff0c 投了头条前端 xf
  • 就是你把所有代码全写在一个类里的?

    来源 https urlify cn 6jQRN3 最近 xff0c 在对已有项目进行扩展的时候 xff0c 发现要改动的一个类它长900行 xff0c 开放了近40个public接口 xff0c 我流着泪把它给改完了 为了防止这样的惨剧再
  • 如何实现一个高性能可渲染大数据的Tree组件

    作者 xff1a jayzou https segmentfault com a 1190000021228976 背景 项目中需要渲染一个5000 43 节点的树组件 xff0c 但是在引入element Tree组件之后发现性能非常差
  • 白剽,2020年最牛AI技术,各个都有代码

    来源 xff1a Reddit 编辑 xff1a 科雨 2020年 xff0c 想必各国的人民都被新冠病毒支配得瑟瑟发抖 不过 xff0c 这并不影响科研工作者的工作态度和产出质量 疫情之下 xff0c 通过各种方式 xff0c 全球的研究
  • 图解:卷积神经网络数学原理解析

    原标题 Gentle Dive into Math Behind Convolutional Neural Networks 作 者 Piotr Skalski 编 辑 Pita 翻 译 通夜 xff08 中山大学 xff09 had in
  • 【第二弹】这可能是进达摩院最好的机会了!

    很长时间没有更新公众号了 xff0c 最近在准备一些其他节目 xff0c 和小伙伴们说声抱歉了 但是 xff0c 虽然近期没有文章 xff0c 福利是不能少的 早在半年前 xff0c 我发过一篇文章 xff1a 这可能是进达摩院最好的机会了
  • Hadoop入门-WordCount示例

    WordCount的过程如图 xff0c 这里记录下入门的过程 xff0c 虽然有很多地方理解的只是皮毛 Hadoop的安装 安装比较简单 xff0c 安装完成后进行单机环境的配置 hadoop env sh 指定JAVA HOME spa
  • Phaser入门教程

    入门教程 xff0c 我可不会讲什么概念 xff0c 我只会讲一个入门例子 xff0c 通过这个例子 xff0c 你就知道 phaser有多么强大 xff0c 而照着这个例子做 xff0c 你就能知道怎么使用 phaser了 需要说明的是
  • IDEA插件activiti工具actiBPM

    最新的IDEA中Marketplace搜索不到actiBPM xff08 2020 2 xff09 离线安装 下载https plugins jetbrains com 选择版本 导入jar 重启IDEA 验证 右键新建 表明添加成功 使用
  • 【内推找我】阿里社招面试16轮,终于拿到offer(2020年2月更新)

    内推私信我 xff0c 标题党了 xff0c 其实是这么回事 一 背景及原因 个人背景 xff1a 17年普本毕业Java开发 想换工作原因 xff1a 19年7月公司裁员了一波 xff0c 内部较动荡 xff0c 想看看外面机会 xff1
  • MPU6050介绍及姿态解算

    1 介绍 xff1a MPU6050 是 InvenSense 公司推出的全球首款整合性 6 轴运动处理组件 xff0c 相较于多组件方案 xff0c 免除了组合陀螺仪与加速器时之轴间差的问题 xff0c 减少了安装空间 xff08 1 x
  • 网络编程——Socket(套接字)

    网络编程 网络编程的目的就是指直接或间接地通过网络协议与其他计算机进行通讯 网络编程中 有两个主要的问题 xff0c 一个是如何准确的定位网络上一台或多台主机 xff0c 另一个就是找到主机后 如何可靠高效的进行数据传输 在TCP IP协议
  • 【Linux 驱动】netfilter/iptables (三) 注册和注销Netfilter hook

    继前面介绍了 netfilter hook xff0c 这里我们开始进行简单的实例讲解 xff0c 主要是Netfilter hook的注册与注销 xff1a wqlkp c xff1a span class hljs preprocess
  • Uboot网络设备驱动(一)---两种连接架构

    本系列将针对NXP的s32v234芯片及s32v234evb开发板讲解Uboot中网络相关的设备驱动程序 本文前提是你有基本的计算机网络知识 xff08 TCP IP协议及OSI ISO七层网络协议 xff09 一般BSP工程师涉及的主要工
  • ESP8266物联网远距离控制实现

    ESP8266物联网远距离控制实现 转载请注明出处 xff01 重要的事情放在前面源码在GitHub上面欢迎issue xff0c 如果可以的话Star一下也是表示对作者的支持 有很多不足 xff0c 希望可以得到指教 https gith