百度移动端面试回忆

2023-05-16

百度一面:

1. 自我介绍

2. 悲观锁和乐观锁

乐观锁:

 总是认为不会产生并发问题,每次去取数据的时候总认为不会有其他线程对数据进行修改,因此不会上锁,但是在更新时会判断其他线程在这之前有没有对数据进行修改,一般会使用版本号机制或CAS操作实现。

  •  version方式(版本号机制):一般是在数据表中加上一个数据版本号version字段,表示数据被修改的次数,当数据被修改时,version值会加一。当线程A要更新数据值时,在读取数据的同时也会读取version值,在提交更新时,若刚才读取到的version值为当前数据库中的version值相等时才更新,否则重试更新操作,直到更新成功。
  • CAS操作方式:即compare and swap 或者 compare and set,涉及到三个操作数,数据所在的内存值,预期值,新值。当需要更新时,判断当前内存值与之前取到的值是否相等,若相等,则用新值更新,若失败则重试,一般情况下是一个自旋操作,即不断的重试。

悲观锁:

 总是假设最坏的情况,每次取数据时都认为其他线程会修改,所以都会加锁(读锁、写锁、行锁等),当其他线程想要访问数据时,都需要阻塞挂起。可以依靠数据库实现,如行锁、读锁和写锁等,都是在操作之前加锁,在Java中,synchronized的思想也是悲观锁

3. Android跨线程通信, Handler

Android进阶——Android消息机制之Looper、Handler、MessageQueen

Android消息机制图解

4. Android跨进程通信,Binder

Android跨进程通信:图文详解 Binder机制 原理

5. Android的性能优化

6. 动态链接和静态链接的区别

  • 静态连接库就是把(lib)文件中用到的函数代码直接链接进目标程序,程序运行的时候不再需要其它的库文件。
  • 动态链接就是把调用的函数所在文件模块(DLL)和调用函数在文件中的位置等信息链接进目标程序,程序运行的时候再从DLL中寻找相应函数代码,因此需要相应DLL文件的支持。 动态链接的主要目的:把程序与他们使用的特定的函数库版本中分离开来。

静态链接库与动态链接库都是共享代码的方式,如果采用静态链接库,则无论你愿不愿意,lib 中的指令都全部被直接包含在最终生成的 EXE 文件中了。但是若使用 DLL,该 DLL 不必被包含在最终 EXE 文件中,EXE 文件执行时可以“动态”地引用和卸载这个与 EXE 独立的 DLL 文件。 静态链接库和动态链接库的另外一个区别在于静态链接库中不能再包含其他的动态链接库或者静态库,而在动态链接库中还可以再包含其他的动态或静态链接库。

动态链接的优点:

  1. 可执行文件的体积可以非常小,节省磁盘空间和虚拟内存,能更加有效的利用磁盘空间。
  2. 链接-编辑阶段的时间会缩短(因为链接器的有些工作被推迟到载入)
  3. 所有动态链接到某个特定函数库的可执行文件在运行时共享该函数库在内存中的一个单独拷贝。这就提供了更好的I/O和交换空间利用率,节省了物理内存,提高了系统整体性能。

不足之处:

  • 使用静态链接生成的可执行文件体积较大,包含相同的公共代码,造成浪费;     
  •  使用动态链接库的应用程序不是自完备的,它依赖的DLL模块也要存在,如果使用载入时动态链接,程序启动时发现DLL不存在,系统将终止程序并给出错误信息。而使用运行时动态链接,系统不会终止,但由于DLL中的导出函数不可用,程序会加载失败;速度比静态链接慢。当某个模块更新后,如果新模块与旧的模块不兼容,那么那些需要该模块才能运行的软件,统统撕掉。这在早期Windows中很常见。

8. TCP三次握手,四次挥手

TCP建立连接和释放连接过程

9. 如何实现线程同步

  • 同步方法。使用synchronized关键字修饰的方法。由于java的每个对象都有一个内置锁,当用关键字修饰此方法时,内置锁会保护整个方法。在调用该方法前,需要获得内置锁,否则该线程就处于阻塞状态。 代码如:public synchronized void save(){} synchronized关键字也可以静态方法,此时如果调用该静态方法,将会锁住整个类。
  • 同步代码块。即有synchronized关键字修饰的语句块。被关键字修饰的的语句块会自动加上内置锁,从而实现同步。 代码如:synchronized(object){ }   同步是一种高开销的操作,因此应该尽量减少同步的内容。通常没有必要去同步整个方法,使用关键字synchronized修饰关键代码即可
  • 使用特殊域变量修饰符volatile实现线程同步。不保证对变量的任何操作都是原子性的
  • 使用重入锁实现线程同步,ReentrantLock
  • 使用ThreadLocal管理局部变量实现线程同步 

14. 设计模式,讲解一下观察者模式的使用场景,给一个简单的实现案例

15. 手撕代码:将任意一个double型的角度转化为0-360度

public double convertToAngle(double angle){
		int circle = (int) (angle / 360);
		if(angle > 0){
			angle-=circle*360;
		}else{
			angle+=360*(1-circle);
		}
		return angle;
	}

16. 手撕代码:找出一个有序数组中某个数字出现的区间(数字在排序数组出现得次数)

public class Solution {
    public int GetNumberOfK(int [] array , int k) {
        int length = array.length;
        if(length == 0){
            return 0;
        }
        int firstK = getFirstK(array, k, 0, length-1);
        int lastK = getLastK(array, k, 0, length-1);
        if(firstK != -1 && lastK != -1){
             return lastK - firstK + 1;
        }
        return 0;
    }
    //递归写法
    private int getFirstK(int [] array , int k, int start, int end){
        if(start > end){
            return -1;
        }
        int mid = (start + end) >> 1;
        if(array[mid] > k){
            return getFirstK(array, k, start, mid-1);
        }else if (array[mid] < k){
            return getFirstK(array, k, mid+1, end);
        }else if(mid-1 >=0 && array[mid-1] == k){
            return getFirstK(array, k, start, mid-1);
        }else{
            return mid;
        }
    }
    //循环写法
    private int getLastK(int [] array , int k, int start, int end){
        int length = array.length;
        int mid = (start + end) >> 1;
        while(start <= end){
            if(array[mid] > k){
                end = mid-1;
            }else if(array[mid] < k){
                start = mid+1;
            }else if(mid+1 < length && array[mid+1] == k){
                start = mid+1;
            }else{
                return mid;
            }
            mid = (start + end) >> 1;
        }
        return -1;
    }
}

 

百度二面:

1. 自我介绍

2. 问项目细节,问实习经历

3. 死锁的定义,死锁产生的条件,解决死锁的方法

死锁是指两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去。此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程称为死锁进程

死锁产生条件:

1)互斥条件:指进程对所分配到的资源进行排它性使用,即在一段时间内某资源只由一个进程占用。如果此时还有其它进程请求资源,则请求者只能等待,直至占有资源的进程用毕释放。

2)请求和保持条件:指进程已经保持至少一个资源,但又提出了新的资源请求,而该资源已被其它进程占有,此时请求进程阻塞,但又对自己已获得的其它资源保持不放。

3)不剥夺条件:指进程已获得的资源,在未使用完之前,不能被剥夺,只能在使用完时由自己释放。

4)环路等待条件:指在发生死锁时,必然存在一个进程——资源的环形链,即进程集合{P0,P1,P2,···,Pn}中的P0正在等待一个P1占用的资源;P1正在等待P2占用的资源,……,Pn正在等待已被P0占用的资源。

处理死锁:

1)预防死锁。该方法是通过设置某些限制条件,去破坏产生死锁的四个必要条件中的一个或几个来预防产生死锁。

2)避免死锁。在资源的动态分配过程中,用某种方法防止系统进入不安全状态,从而可以避免产生死锁。(银行家算法)

3)检测死锁。通过检测机构及时地检测出死锁的发生,然后采取适当的措施,把进程从思索中解脱出来。

4)解除死锁。当检测到系统中已发生死锁时,就采取相应的措施,将进程从死锁状态中解脱出来。常用方法是---撤销一些进程,回收他们的资源,将他们分配给已处于阻塞状态的进程,使其能继续运行。

4. 读过哪些Android源代码,Android消息队列,EventBus等等

5. MVC和MVP的区别

6. 红黑树

7. HashMap的实现原理

8. Android内存管理

Android内存管理分析总结

9. Volatile关键字

Java并发编程:volatile关键字解析

注意:Volatile关键字不保证操作的原子性

10. 手写代码:从一个Activity中向另外一个Activity传送BitMap

1) . 通过Intent的Bundle

Resources res=getResources();  
Bitmap bmp=BitmapFactory.decodeResource(res, R.drawable.ic_launcher);  
          
Bundle b = new Bundle();  
b.putParcelable("bitmap", bmp);  
          
Intent intent = new Intent(this, MainActivity2.class);  
intent.putExtras(b);  
startActivity(intent);  

 

2). 把Bitmap写进字节流

Resources res=getResources();  
Bitmap bmp=BitmapFactory.decodeResource(res, R.drawable.ic_launcher);  
ByteArrayOutputStream baos = new ByteArrayOutputStream();  
bmp.compress(Bitmap.CompressFormat.PNG, 100, baos);  
byte[] bytes=baos.toByteArray();  
          
Bundle b = new Bundle();  
b.putByteArray("bitmap", bytes);  
Intent intent = new Intent(this, MainActivity2.class);  
intent.putExtras(b);  
startActivity(intent);  

11. Android FrameWork源码

12. 手撕代码: 找出数组中最小的k个数


import java.util.ArrayList;
public class Solution {
   public ArrayList<Integer> GetLeastNumbers_Solution(int[] input, int k) {

		ArrayList<Integer> result = new ArrayList<Integer>();
		int len = input.length;
		if (k > len || k <= 0 || len == 0) {
			return result;
		}

		int index = Partition(input,len,0,len-1);
		while(index != k - 1){
			if(index > k - 1){
				index = Partition(input,len,0,index - 1);
			}else{
				index = Partition(input,len,index + 1,len -1 );
			}
		}

		for(int i = 0 ; i < k ; i++){
			result.add(input[i]);
		}
		return result;
	}

	public int Partition(int[] array, int length, int start, int end) {
		if (array == null || length == 0 || start < 0 || end >= length) {
			return (Integer) null;
		}

		int key = array[start];
		int low = start;
		int high = end;
		while (low < high) {
			while (low < high && array[high] >= key) {
				high--;
			}
			array[low] = array[high];

			while (low < high && array[low] <= key) {
				low++;
			}
			array[high] = array[low];
		}
		array[low] = key;
		return low;
	}
}

 

百度三面:

1. 自我介绍

2. 栈和队列的区别,优先队列的使用场景

优先队列(可实现自动排序):

一个基于优先级堆的无界优先级队列。优先级队列的元素按照其自然顺序进行排序,或者根据构造队列时提供的 Comparator 进行排序,具体取决于所使用的构造方法。优先级队列不允许使用 null 元素。依靠自然顺序的优先级队列还不允许插入不可比较的对象(这样做可能导致 ClassCastException)。

此队列的 是按指定排序方式确定的最小 元素。如果多个元素都是最小值,则头是其中一个元素——选择方法是任意的。队列获取操作 pollremovepeekelement 访问处于队列头的元素。

优先级队列是无界的,但是有一个内部容量,控制着用于存储队列元素的数组大小。它通常至少等于队列的大小。随着不断向优先级队列添加元素,其容量会自动增加。无需指定容量增加策略的细节。

3. 手撕代码:实现斐波那契数列

public class Solution {
    public int Fibonacci(int n) {
        if(n <= 1){
            return n;
        }
        int fibNMinusTwo = 0; // Fibonacci(n-2)
        int fibNMinusOne = 1; // Fibonacci(n-1);
        int fibN = 0;
        for(int i = 2; i <=n ; i++){
        	//Fibonacci(n) = Fibonacci(n-1) + Fibonacci(n-2) 
            fibN = fibNMinusOne + fibNMinusTwo; 
            fibNMinusTwo = fibNMinusOne;
            fibNMinusOne = fibN;
        }
       return fibN;
    }
}

4. MVC和MVP的区别

5. 实习和项目经历

6. C++和Java的区别

  • java为解释性语言(源代码通过java编译器编译成字节码交由JVM解释执行),C/C++为编译型语言(源代码经过编译和链接后生成可执行的二进制编码). 注:java的执行速度比C/C++的执行速度慢,java能够跨平台执行,C/C++不可以。
  • java纯面向对象(所有代码在类中实现,除基本类型外,所有类型都为类),C++兼具面向过程和面向对象编程的特点。 注:java不存在全局变量或者全局函数,C++可以定义全局变量和全局函数。
  • java中没有指针的概念,防止了C++语言中操作指针可能引起的系统问题,使程序变得更加安全。
  • java不支持多继承(java引入了接口的概念,可以同时实现多个接口,也具有多态性)  C++支持多继承
  • C++需要开发人员去管理对内存的分配,包括申请和释放。(释放资源的代码放在析构函数中)  java自己提供了垃圾回收器来实现垃圾的自动回收,不需要显示的管理内存的分配。(java不存在析构函数,引入了finalize()方法,当垃圾回收将要释放无用内存时,会首先调用该方法)
  • C++支持运算符重载;java不支持运算符重载
  • C++支持预处理,java没有预处理器,不支持预处理功能(包括头文件和宏的定义) 注:java提供了import 机制与C++的预处理器功能类似。
  • C++支持默认的函数参数,java不支持默认函数参数。
  • C++支持goto语句,java不支持goto语句(java中goto是保留关键字)。 注:goto语句也称为无条件转移语句,其一般格式如下:  goto 语句标号; 其中语句标号是按标识符规定书写的符号, 放在某一语句行的前面,标号后加冒号(:)。语句标号起标识语句的作用,与goto 语句配合使用。  如: label: i++;  loop: while(x<7);
  • C++支持自动强制类型转换,java不支持强制类型转换(java需要开发人员显示的强制类型转换)。 注:java引入泛型的概念,更好的处理类型的问题。
  • java具有平台无关性。(每种类型分配固定的长度)  C++具有平台性。(同一种类型在不同的平台分配的长度不同)
  • java包含一些标准库,用于完成特定的任务,同时这些库简单易用,能够大大的缩短开发周期。(提供了访问数据库的JDBC库,用于实现分布式对象的RMI等标准库)  C++依靠一些非标准的,由其他厂商提供的库。

7. 值传递和引用传递,那个效率更高

值传递:方法调用时,实际参数把它的值传递给对应的形式参数,方法执行中形式参数值的改变不影响实际参数的值。

引用传递:也称为传地址。方法调用时,实际参数的引用(地址,而不是参数的值)被传递给方法中相对应的形式参数,在方法执行中,对形式参数的操作实际上就是对实际参数的操作,方法执行中形式参数值的改变将会影响实际参数的值。 

引用传递的效率高于值传递(直接访问内存)

在 Java 应用程序中永远不会传递对象,而只传递对象引用。因此是按引用传递对象。但重要的是要区分参数是如何传递的。Java 应用程序按引用传递对象这一事实并不意味着 Java 应用程序按引用传递参数。参数可以是对象引用,而 Java 应用程序是按值传递对象引用的。

Java 应用程序中的变量可以为以下两种类型之一:引用类型或基本类型。当作为参数传递给一个方法时,处理这两种类型的方式是相同的。两种类型都是按值传递的;没有一种按引用传递。


按 值传递意味着当将一个参数传递给一个函数时,函数接收的是原始值的一个副本。因此,如果函数修改了该参数,仅改变副本,而原始值保持不变。按引用传递意味 着当将一个参数传递给一个函数时,函数接收的是原始值的内存地址,而不是值的副本。因此,如果函数修改了该参数,调用代码中的原始值也随之改变。


当传递给函数的参数不是引用时,传递的都是该值的一个副本(按值传递)。区别在于引用。在 C++ 中当传递给函数的参数是引用时,您传递的就是这个引用,或者内存地址(按引用传递)。在 Java 应用程序中,当对象引用是传递给方法的一个参数时,您传递的是该引用的一个副本(按值传递),而不是引用本身。


Java 应用程序按值传递所有参数,这样就制作所有参数的副本,而不管它们的类型。

Java的参数传递到底是引用传递还是值传递

8. 什么时候接触Android的,为什么会做Android

9. 是否有读研的想法

10. 操作系统页面置换算法

页面置换算法

11. LRU算法的实现

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

百度移动端面试回忆 的相关文章

  • ubuntu 安装openssl-devel

    需要安装openssl devel xff0c Github上的说明要用yum工具安装 xff0c 反复安装不上 xff0c 提示没有repos xff08 回购 xff09 xff0c 最后找到了方法 在Ubuntu系统里这是分开的两个
  • 1分钟教会你二进制撩妹(汉)读心术

    近些年来 xff0c 小魔发现 xff0c 对于年轻的男女而言 xff0c 一些传统的节日似乎都变成了情人节或者脱单节 xff0c 就连 光棍节 xff0c 实际上很多人都是抱着节前或者是当天脱单而过的 双11 光棍节 即将来临 xff0c
  • VLAN基础配置及Access接口、Trunk接口、Hybrid接口

    文章说明 xff1a 1 本文使用的软件是eNSP 2 退到下一层用命令quit xff0c 简写q 3 部分命令使用的是简写 和完整命令一样的作用 xff0c 按键盘上的 34 Tab 34 建可自动补全命令 用于查询的命令 xff1a
  • c++pthread多线程消费者问题

    分布式选修课上讲了多线程编程 xff0c 布置了一个生产者消费者的作业 xff0c 觉得挺有意思 xff0c 并且网络上的消费者问题多使用c语言编写 xff0c 故在此记录c 43 43 解决方法 由于是消费者线程各自计数 xff0c 故使
  • 红包动画

    lt DOCTYPE html gt lt html lang 61 34 en 34 data dpr 61 34 1 34 style 61 34 font size 32px 34 gt lt head gt lt meta char
  • Android中<xliff:g></xliff:g>的用法

    在查阅修改Android源码的过程中经常能在字符串资源中看到类似下面的标签 xff1a span class hljs tag lt span class hljs title resources span span class hljs
  • vue单文件组件的格式规范

    lt template gt lt template gt lt script gt export default name 39 39 mixins components props data return computed watch
  • Linux命令行安装weblogic12c

    Linux命令行安装weblogic12c 一 安装jdk 若已安装可跳过 1 Oracle官网下载jdk linux安装包 2 卸载linux系统中自带的jdk 使用rpm qa grep java查询出系统自带的jdk xff1b 使用
  • Ubuntu 远程免密码登录设置

    我们正常使用 ssh 远程登录服务器进行操作 xff0c 需要输入用户名 服务器ip以及密码 xff0c 当我们需要同时管理多个服务器的时候 xff0c 每次都需要重复输入这些东西会显得特别麻烦和浪费时间 xff0c 因此我们可以通过配置密
  • Mybatis resultMap启动时报错:Could not resolve type alias userResultMap Cannot find class: userResultMap

    MyBatis中在查询进行select映射的时候 xff0c 返回类型可以用resultType xff0c 也可以用resultMap xff0c resultType是直接 表示返回类型的 xff0c 而resultMap则是对外部Re
  • synchronized-锁总结

    目录 一 相关知识点 1 1 对象头 1 2 锁相关概念 1 3 查看对象头工具 二 锁流程 2 1 加锁 xff1a monitorenter 2 2 释放锁 xff1a monitorexit 一 相关知识点 在 JDK1 6 之前 x
  • 软件工程师校招面试救急包

    LeetCode牛人总结 xff08 手撕代码前看看 xff0c 抱佛脚 xff09 https github com labuladong fucking algorithm blob master README md 剑指offer x
  • 微信SDK中含有的支付功能怎么去掉?

    一 说在前面的话 这两天遇到一个特别让我DT的问题 xff0c 估计大家通过标题就能知道问题了 没错 xff0c 就是在应用中集成了微信SDK后 xff0c 它自动支持了微信分享 登录 收藏 支付等功能 这一点没啥 xff0c TM的关键点
  • Android中图片的镂空效果(不规则图形的镂空)

    一 说在前面的话 我们在做新手引导时 xff0c 经常会遇到凸显某一块功能时需求 xff0c 类似于下图 xff1a 看到这个功能点可能会有点头大 xff0c 不过好在Android为我们提供一个美好的工具 xff1a PorterDuff
  • 利用三层交换机实现VLAN间路由

    原理概述 xff1a VLAN将一个物理的LAN在逻辑上划分成多个广播域 VLAN内的主机间可以直接通信 xff0c 而VLAN间不能直接互通 在现实网络中 xff0c 经常会遇到需要跨VLAN相互访问的情况 xff0c 工程师通常会选择一
  • Failed to resolve attribute at index 6: TypedValue{t=0x2/d=0x7f0400cd a=7 r=0x7f06006e}

    今天在开发时 xff0c 遇到一个程序的Bug xff0c 记录一下 在Dialog中展示一个布局 xff0c 布局中包含了TextView报了下面的错误 xff0c 最开始还以为是颜色设置的问题 xff0c 反复核对了一下颜色设置并没有问
  • TextView的TextColor中使用selector的问题

    在TextView中如果设置选中 点击 获取焦点时 xff0c 文字颜色发生改变时 xff0c 一般我们会通过代码中设置 不过Android给我们提供了一个更简洁的方式 xff0c 就是通过selector去改变 只需要在Res目录下创建一
  • 彻底理解Java中堆和栈的区别

    1 概述 在Java中 xff0c 内存分为两部分 xff0c 一种是堆内存 xff0c 另一种就是栈内存 2 Java中变量在内存中的分配 1 类变量 static修饰的变量 xff1a 在程序加载时系统就为它在堆中开辟了内存 xff0c
  • 深入了解多线程的原理

    说在前面的话 使用多线程的目的 在多个CPU核心下 xff0c 多线程的好处是显而易见的 xff0c 不然多个CPU核心只跑一个线程其他的核心就都浪费了即便不考虑多核心 xff0c 在单核下 xff0c 多线程也是有意义的 xff0c 因为
  • An operation is not implemented: not implemented被坑之路[Kotlin]

    吐槽一下 xff0c 程序猿的辛酸史 今天在开发新项目时 xff0c 首次使用了Kotlin语言 xff0c 对于之前只在纸上谈兵 xff0c 未在项目中使用过的码农 xff0c 很是一脸懵逼 但是迫于公司的要求 xff0c 只能硬头皮冲吧

随机推荐

  • 开发Android Camera—使用Kotlin语言,完成第一个自定义相机

    对于首次使用Kotlin语言开发 xff0c 在网上苦于寻找不到Kotlin语言编写的相机代码 xff0c 故写下这篇博客 好了 xff0c 咱们进入主题 在Android 5 0 xff08 SDK 21 xff09 中 xff0c Go
  • Android ConstraintLayout性能分析

    这篇文件是讲述ConstraintLayout性能的分析 xff0c 如果对于使用ConstraintLayout不是很了解的情况下 xff0c 请查看Android ConstraintLayout完全解析和性能分析 xff08 章节一
  • 针对drawableStart(Top、End、Bottom)边距的设置-Android布局技巧

    作为Android程序猿 xff0c 在开发布局的过程中 xff0c 我们的宗旨是能用一个View完成的效果 xff0c 绝不会用两个View或者嵌套View来完成 至于它的好处 xff0c 就不言而喻了吧 不懂的自行到网上看 xff0c
  • markdown基本语法

    转载自 Cmd 技术渲染的沙箱页面 xff0c 点击此处编写自己的文档 Cmd Markdown 简明语法手册 标签 xff1a Cmd Markdown 1 斜体和粗体 使用 和 表示斜体和粗体 示例 xff1a 这是 斜体 xff0c
  • unix环境高级编程——UNIX体系架构

    本期主题 xff1a unix环境高级编程 UNIX体系架构 文件IO 0 初始UNIX1 系统调用2 库函数2 1 C语言的运行库 3 shell 0 初始UNIX 这里略过unix的历史不讲 xff0c 网上有比较详细的资料 我们可以将
  • HTML基础<1>

    一 图片标签与超链接 lt br gt 是空格 lt hr gt 是横线 lt img src 61 34 34 width 61 34 34 height 61 34 34 gt lt a href 61 34 https www bai
  • Android Lottie动画

    Android Lottie动画 在Android中 xff0c 往往UI会让写一些动画效果 xff0c 比如启动页心形跳动 xff0c 返回效果等 一般我们在项目中常用的动画无非是以下几种 xff1a 普通动画帧动画属性动画通过改变Lay
  • 我与人工智能的故事

    本文作者 xff1a 诸葛越 前 言 人工智能的三次浪潮 2018年年初 xff0c 招聘季正如火如荼地进行 xff0c 而 数据科学家 和 算法工程师 绝对算得上热门职业 人工智能 机器学习 深度学习 建模 卷积神经网络 等关键词 xff
  • GitHub安装和使用

    GitHub安装和使用 GitHub是一个基于git的代码托管平台 xff0c 付费用户可以建私人仓库 xff0c 一般的免费用户只能使用公共仓库 xff0c 也就是代码要公开 Github 由Chris Wanstrath PJ Hyet
  • Linux系统java安装

    1 下载 进入Oracle官网进行JDK下载 2 创建目录 span class token function mkdir span usr java span class token function cd span usr java 3
  • 过年之抢红包算法

    前言 昨天是大年初一 xff0c 怎么说呢 xff0c 因为在读大学 xff0c 没有出来工作 xff0c 所以昨晚也是陆陆续续有收到一些红包 然后想起自己对算法感兴趣 xff0c 以前也看过一些公众号有讲过抢红包算法 xff0c 今天就更
  • DL基本知识(七)FTRL优化器

    契机 最近工作方向为缩减模型规模 xff0c 切入点为L1正则化 xff0c 选择该切入点的理由如下 xff0c 众所周知 xff0c L1正则化能令权重矩阵更稀疏 在推荐系统中特征多为embedding xff0c 权重矩阵稀疏意味着一些
  • 生产者消费者问题的C语言实现

    实验六 生产者 消费者问题实验 一 实验目的 掌握Linux下生产者 消费者问题算法的实现 二 实验原理 1 clone系统调用 xff1a 功能 xff1a 创建一个轻进程或线程 用法 xff1a intclone int fn void
  • 项目中使用ts的一些技巧

    项目上使用ts一年多了 xff0c 一边写 xff0c 一边看 xff0c 总结了一些小技巧 xff0c 写了一些分享给大家 xff0c 如果对你有所帮助就转评赞三连来一个 xff0c 那么我们开始今天的正题 xff1b 1 type联合类
  • 史上最全的ubuntu服务器搭建环境教程~~~

    ubuntu服务器搭建环境 1 先安装xshell xff1a 远程服务器连接 xff08 取代直接在浏览器 上 访问 xff09 2 安装xftp xff08 ftp文件传输 xff09 直接双击红色圈圈即可 3 安装mysql数据库 x
  • ubuntu server 18.04 启用root账户自动登录

    新安装Ubuntu server 18 04 后 xff0c 不能使用root账户进行ssh登录 解决方案 设置root用户密码 sudo passwd root 修改文件 usr share lightdm lightdm conf d
  • THML基础<2>

    一 基本的JavaScript命令document write 打印指定的文本内容到页面上 alert 弹出框 lt script type 61 34 text javascript 34 gt document write 34 Hel
  • 【机翻】Contrastive Learning based Hybrid Networks for Long-Tailed Image Classification

    Contrastive Learning based Hybrid Networks for Long Tailed Image Classification Abstract 在长尾图像分类中 xff0c 判别式图像表示的学习起着非常重要
  • 视图绑定(ViewBinding )与数据绑定(Databinding)

    视图绑定 xff08 ViewBinding xff09 与数据绑定 xff08 Databinding xff09 什么是ViewBinding viewbinding是android jetpack的一个特性 xff0c 通过viewb
  • 百度移动端面试回忆

    百度一面 xff1a 1 自我介绍 2 悲观锁和乐观锁 乐观锁 xff1a 总是认为不会产生并发问题 xff0c 每次去取数据的时候总认为不会有其他线程对数据进行修改 xff0c 因此不会上锁 xff0c 但是在更新时会判断其他线程在这之前