首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

linux下的so、o、lo、a、la文件的区别

o: 编译的目标文件 a: 静态库,其实就是把若干o文件打了个包 so: 动态链接库(共享库) lo: 使用libtool编译出的目标文件,其实就是在o文件中添加了一些信息 la: 使用libtool编译出的库文件...当要生成的文件是诸如libmylib.la的时候,比如: $libtool –mode=link gcc -o libmylib.la -rpath /usr/lib –L/usr/lib –la 其依赖的库的搜索基本类似...,a对b的依赖并没有写入到liba.la中,那么如果用以下命令编译: $libtool –mode=link gcc -o myprog -rpath /usr/lib –L/usr/lib –la 激发出的...$ unicore32-Linux-gcc –o myprog /usr/lib/liba.so \ -Wl,–rpath-link -Wl,/home/UNITY_float/install/usr/...libtool中有一个变量“hardcode_libdir_flag_spec”,该变量本来是传递“-rpath”选项的,但我们可以修改它,添加我们需要的路径,传递给unicore32-linux-gcc

9K30

【答疑解惑】i++,++i,i+=的区别

表达式 a = i++; 它等价于 a = i ; i = i + 1; 表达式 a = ++i 它等价于 i = i + 1; a = i; 1、 首先两者的区别是:前者是先赋值,然后再自增;...后者是先自增,后赋值 2、 ++i 和i++ 的使用,一般来说在循环域里面,这两者并没有什么很大的区别,因为编译器一般都会给你做优化。...但是要注意其生存周期,我们要注意i值在程序流中的变化,如果是for、while循环判断中要特别注意++i的值比i++值要提前。...没有结果,因为不同的编译器做出来的结果,你要纠结这个,哎我只能说那些书上纯粹是搞人。 以上我们只需记住先序后续递增,循环判断时的条件即可。...i += 2; 这个是 i = i + 2; 自身值加上2后赋值给自己。这个没有争议。 来骚年练习一下 i += (++i)+(++i)+(++i); 呵呵!!!

1.8K50
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    java中i++ 和 ++i的区别

    今天同事扔给我两道面试题,由于我2年前就接触过这道题,所以没啥意思,我看完后扔到一个交流群里,回答这道题的绝大部分人竟然都答错了;很多人很清晰的知道这两道题想考察面试者对 i++ 和 ++i 的理解...,也很清晰的知道这二者的区别,但是题还是做不对;两道题如下,大家可以先思考一下,给个答案,然后再去验证自己的想法。...(这是一道典型的看着非常简单的题,但是不少人还是会因为粗心栽跟头) 第一题: int a = 0; for (int i = 0; i i++) {...(int i = 0; i i++) { b = ++ b; } System.out.println(b); 我估计会有不少人做错...i++ 和 ++i 在理论上的区别是: i++:是先把i拿出来使用,然后再+1; ++i :是先把i+1,然后再拿出来使用; 答案见下: 第一题:a=0 第二题:b=99 再升级一下 第三题

    1.2K30

    java中 i = i++和 j = i++ 的区别

    由于i++和i--的使用会导致值的改变,所以在处理后置的++和--的时候,java的编译器会重新为变量分配一块新的内存空间,用来存放原来的值, 而完成赋值运算之后,这块内存会被释放。...(1)对于j = i++的情况 ?   ...i的原始值存放在后开辟的内存中,最后将这个值赋给j,进行j = i++运算之后,j会得到i的值,而i又将自加,所以,在释放内存之后,原来存放j和i的地方将得到的值分别是:j(此时的值等于初始i的值)和i...(i自加后的值)。...每一次的循环结束,用来保存i的原始值的内存的数据会被销毁,然后i的新的值又会被放在一段新的内存中,在进行上述的循环,所以最终能够实现j的数据的增加。 (2)对于i = i++的情况 ?

    1.4K100

    面试官:i = i++和 i = ++i 的有什么区别?

    "i="+i); System.out.println("j="+j); System.out.println("k="+k); } } 你能肯定并且准确的说出你的答案吗...其中一个方法对应一个栈帧 此题目我们只需要用到栈帧里面的局部变量表和操作数栈 2.1、第一步 int i = 1 只是一个简单的赋值操作 2.2、第二步 i = i++ 结果:i还是等于1 2.3、第三步...int j = i++ 结果:i在局部变量表中变成了2,操作数栈中的 i 值为1,并且将 i 的值返回给 j,即此条语句以后,i = 2,j = 1 2.4、第四步 int k = i + ++i *...i++ 结果:局部变量表中的i = 4,k = 11 2.5、结果 3、i = ++i 按理说根据上面的分析过程,再来分析 i = ++i,就很简单了。...我们的 i 变量先在局部变量表中进行自增,然后再将 i 进栈,然后再把栈中的数据返回给我们的变量 i 。

    1.2K20

    i386和i686的区别

    GNU/Linux分为alpha、PowerPC、Sun等各个不同版本,所有从Intel386-P4都用i386版本,但i386版本中有几个内核(i486,i486,i586,i686),安装时安装程序检测到你得...与cpu的指令集有关.I代表与intel的指令集兼容,后面的数字是指cpu的分类。...而i386的软件包既可在i386的电脑上执行,也可在后面所有的cpu上执行(如奔三、奔四,但不能发挥cpu的最佳性能。)...i686指的是Pentium Pro以及此后的Intel IA32 CPU,也就是平常我们所说的P6系列处理器。 i386不用说了,泛指80386以后的。...i686是pentiumpro及以后的通用arch,而i386是所有x86的通用arch,i386包括而i686没有包括的就是386、486、586(pentium)、pentium-mmx 现在应该没有人还在用

    1.8K20

    i386i686x86-64的区别

    架构的64位cpu. 3.I686 只是i386的一个子集,支持的cpu从Pentium 2 (686)开始,之前的型号不支持....i386和i686的区别: 现在所有的intel 32位体系(包括AMD等兼容CPU)都叫i386体系,包括P4。、i686仍然属于i386体系,不过对CPU(相对于386)的特性作了指令优化。...GNU/Linux分为alpha、PowerPC、Sun等各个不同版本,所有从Intel386-P4都用i386版本,但i386版本中有几个内核(i486,i486,i586,i686),安装时安装程序检测到你得...而i386的软件包既可在i386的电脑上执行,也可在后面所有的cpu上执行(如奔三、奔四,但不能发挥cpu的最佳性能。)...i686是pentiumpro及以后的通用arch,而i386是所有x86的通用arch,i386包括而i686没有包括的就是386、486、586(pentium)、pentium-mmx 现在应该没有人还在用

    4.9K10

    图解 i++ 和 ++i 的区别!看了必懂

    先看一段代码: int i = 0; int a = i++; sout("a的值是:"+i); sout("i的值是:"+i); 最终的编译之后的核心字节码如下 L0 BITPUSH 0 //将常量...ISTORE_2 弹出的栈顶元素值依旧是0,并未改变 最终的输出的结果为: a的值是: 0 i的值是: 1; 我这里画了一个图来帮助大家理解 再来看看++i int i = 0; int a = ++...i; sout("a的值是:"+i); sout("i的值是:"+i); 对于++i 来说,对应的字节码如下,先自增再入栈,那么结果就很清晰了 最终的核心编译之后的字节码如下 L0 BITPUSH 0...//从局部变量表的第二个slot槽中,取出该值,压入操作栈顶 IRETURN //返回栈顶元素 最终的输出的结果为: a的值是: 1 i的值是: 1; 总结 i++ 和 ++i 在理论上的区别是...: i++:是先把i拿出来使用,然后再+1; ++i :是先把i+1,然后再拿出来使用;

    43220

    从 JVM 层面理解 i++ 和 ++i 的真正区别!

    前言 如果只用普通的知识解释i++和++i的话 i++ 先将i赋值再++ ++i 先++再赋值 但是这简单的回答并不能入吸引面试官的眼球,如果用java字节码指令分析则效果完全不同。...代码实现 public class OperandStackTest { /** 程序员面试过程中, 常见的i++和++i 的区别 */ public static void...然后将局部变量表1位置的数入栈执行输出操作 所以i2的值为11 总结 由于没有赋值操作,区别不大。...第四类问题 先将i9=10入栈,然后存在局部变量表8的位置 int i10 = i9++ + ++i9; 先iload将8位置的i9入栈然后执行iinc将8处的i9加一,然后执行++i9,在将8处的...i9加一 此时i9=10+1+1为12,然后将8位置的i9入栈,执行add将栈中的两i9相加,得到的值存储到局部变量表9的位置 所以i10=10+12(i9++后还是10,++i9后是12,因为执行了两次

    77130

    【118期】面试官:你真的清楚 i = i++和 i = ++i 的区别吗?

    只是一个简单的赋值操作 2.2、第二步 i = i++ ? 结果:i还是等于1 2.3、第三步 int j = i++ ?...结果:i在局部变量表中变成了2,操作数栈中的 i 值为1,并且将 i 的值返回给 j,即此条语句以后,i = 2,j = 1 2.4、第四步 int k = i + ++i * i++ ?...结果:局部变量表中的i = 4,k = 11 2.5、结果 ? 3、i = ++i 按理说根据上面的分析过程,再来分析 i = ++i,就很简单了。...我们的 i 变量先在局部变量表中进行自增,然后再将 i 进栈,然后再把栈中的数据返回给我们的变量 i 。...; System.out.println(i); // 结果:i = 2 } } 最后的最后:本文的思考过程和计算推导仅针对Java语言。

    1.5K10

    深入解析i++和++i的区别及性能影响

    这种情况下,我们通常会用到两种常见的操作符:i++和++i。最近在阅读博客时,我偶然看到了有关i++和++i性能的讨论。之前我一直在使用它们,但从未从性能的角度考虑过,这让我突然产生了兴趣。...尽管它们看起来相似,但它们之间存在微妙而重要的区别。在本文中,我们将详细解释i++和++i之间的区别,以及它们对代码性能的影响。...ii.jpg i++ 和 ++i 的区别 i++操作符:这是一个后缀自增操作符。它会先使用变量的当前值,然后再将变量的值加1。...输出如下: b=4 i=4 区别及适用场景 区别:主要区别在于变量自增的时间点不同。对于i++,变量的值会先被赋给表达式,然后再自增;而对于++i,变量会先自增,然后再将增加后的值赋给表达式。...++i的性能影响:相比之下,++i不需要保存原始值,因此它可能会更加高效。它只需一次自增操作。 总结 尽管i++和++i操作符看起来很相似,但它们在变量自增的时间点上有着微妙的区别。

    93220

    Linux中su,sudo,sudo su,sudo -i命令的使用和区别

    sudo 与 su 命令的区别: sudo 命令需要输入当前用户的密码,su 命令需要输入 root 用户的密码。...更多可参考:Linux 命令 su 和 sudo 的区别 su 切换不同的用户的身份: 默认只是切换身份,并没有切换环境变量,环境变量依然是普通用户的。...su root 输入root密码后切换到root用户但是pwd目录不变 su - root 输入root密码后切换到root用户但是pwd目录/root sudo 命令: sudo -i root 与...sudo - root、sudo -i ,sudo - ,sudo root 效果相同 提示输入密码时该密码 为当前账户的密码,要求执行该命令的用户必须在sudoers 中才可以 su 需要的是切换后账户的密码...sudo -i: 为了频繁地执行某些只有超级用户才能执行的权限,而不用每次输入密码,可以使用该命令。提示输入密码时该密码为当前账户的密码。没有时间限制。执行该命令后提示符变为“#”而不是。

    10K20

    短文:用字节码解析i++和++i的区别

    istore_1就是操作数栈出栈,存到本地变量表的第1位置的i,就是代码中的i = 8; iload_1,就是变量表中第一个位置的i压栈到操作数栈顶,此时栈顶为8 iinc 1 by 1,就是变量表中第一个位置的...i加1,那么变量表最终i=9 istore_1,又把栈顶的8存回了变量表中的i,那么i=8; 因为java代码中又赋值给了i。...再看i=++i的字节码指令 ?...0 bipush 8 把8压到操作数栈中 2 istore_1 操作数栈出栈,存到本地变量表的第1位置的i,就是代码中的i = 8; 3 iinc 1 by 1 变量表中第一个位置的i加1,那么变量表最终...i=9 6 iload_1 变量表中第一个位置的i压栈到操作数栈顶,此时栈顶为9 7 istore_1 又把栈顶的9存回了变量表中的i,那么i=9; 8 getstatic #2 <java/lang

    82420

    Linux命令su、sudo、sudo su、sudo -i使用和区别

    sudo 与 su 两个命令的最大区别是: sudo 命令需要输入当前用户的密码,su 命令需要输入 root 用户的密码。另外一个区别是其默认行为。...sudo 一般加的是命令 sudo -i root与sudo - root、sudo -i ,sudo - ,sudo root效果相同 提示输入密码时该密码为当前账户的密码 要求执行该命令的用户必须在...sudo -i: 为了频繁的执行某些只有超级用户才能执行的权限,而不用每次输入密码,可以使用该命令。提示输入密码时该密码为当前账户的密码。没有时间限制。执行该命令后提示符变为“#”而不是“$”。...要求执行该命令的用户必须在sudoers中才可以 ? sudo -i 直接运行sudo命令加-i参数,要求执行该命令的用户必须在sudoers中才可以 ?...要求执行该命令的用户必须在sudoers中才可以。 来自:Linux迷 链接:https://www.linuxmi.com/

    16K10

    从 JVM 层面理解 i++ 和 ++i 的真正区别!

    前言 如果只用普通的知识解释i++和++i的话 i++ 先将i赋值再++ ++i 先++再赋值 但是这简单的回答并不能入吸引面试官的眼球,如果用java字节码指令分析则效果完全不同。...代码实现 public class OperandStackTest { /** 程序员面试过程中, 常见的i++和++i 的区别 */ public static void...1位置的数入栈执行输出操作 所以i2的值为11 总结 由于没有赋值操作,区别不大。...的位置,由于是++i所以先iinc将4位置的值加一,然后将局部变量表4的值入栈,执行赋值操作, 所以i5, i6都是11。...i9,在将8处的i9加一 此时i9=10+1+1为12,然后将8位置的i9入栈,执行add将栈中的两i9相加,得到的值存储到局部变量表9的位置 所以i10=10+12(i9++后还是10,++i9后是12

    29120

    从磁盘I_O的角度理解SQL查询的成本

    数据库存储的基本单位是页,对于一棵 B+ 树的索引来说,是先从根节点找到叶子节点,也就是先查找数据行所在的页,再将页读入到内存中,在内存中对页的记录进行查找,从而得到想要数据,想要查找的,只是一行记录,...但是对于磁盘 I/O 来说却需要加载一页的信息,因为页是最小的存储单位。...数据库缓冲池磁盘 I/O 需要消耗的时间很多,而在内存中进行操作,效率则会高很多,为了能让数据表或者索引中的数据随时被我们所用,DBMS 会申请占用内存来作为数据缓冲池...,这样做的好处是可以让磁盘活动最小化,从而减少与磁盘直接进行 I/O 的时间。...图片顺序读取顺序读取其实是一种批量读取的方式,因为我们请求的数据在磁盘上往往都是相邻存储的,顺序读取可以帮我们批量读取页面,这样的话,一次性加载到缓冲池中就不需要再对其他页面单独进行磁盘 I/O 操作了

    2.5K2940
    领券