oracle9i for linux A3安装指南 by tangyi 警告:如果修改unix 参数文件或者oracle 参数文件,切忌备份并且确认后才能修改,否则可能发生无法挽回的错误。...正式安装 一、oracle9i 安装盘和oracle9i 补丁 ship_9204_linux_disk1.cpio p3006854_9204_LINUX.zip ship_9204_linux_disk2....cpio p2617419_210_GENERIC.zip ship_9204_linux_disk3.cpio p3238244_9204_LINUX.zip 二、安装步骤 1、以根用户登录系统,添加安装过程中需要用到的用户和组....i386 #rpm -qa|grep openmotif21 openmotif21-2.1.30-8.i386 #rpm -qa|grep setarch setarch-1.3-1.i386....cpio cpio -idmv <ship_9204_linux_disk2.cpio cpio -idmv <ship_9204_linux_disk3.cpio 这样的命令来生成三个目录 进入Disk1
Day2-i召唤linux登录云服务器的linuxwindows用户下载xshell软件进行登陆linux操作1.pwd: print working directory,显示当前路径2.mkdir :...cdcd接一个目录名,表示进入该目录cd -返回刚才的目录touch doodle.txt #touch是正经的新建命令,但是不如vi好使,vi是直接新建并打开编辑6.vi 新建脚本或者文本文档(vi是linux...中的文本编辑器)cd tmpvi hello_world.txt#先保证电脑切换到了英文输入法→敲i键,就可以输入了#随便写任何内容# 按Esc键 #退出编辑模式:x #在左下角输入,意思是保存并退出
在linux里面,我们经常会遇到i386 i686 i486 I586 这些代码,例如查看内核版本: [root@localhost logs]# uname -a Linux localhost.localdomain...2.6.18-164.el5PAE #1 SMP Thu Sep 3 04:10:44 EDT 2009 i686 i686 i386 GNU/Linux You have new mail in /...var/spool/mail/root [root@localhost logs]# 还有下载一些软件编译的时候也会遇到,例如我们熟悉的zend: ZendOptimizer-3.2.8-linux-glibc21...-i386.tar.gz ZendOptimizer-3.3.3-linux-glibc23-x86_64.tar.gz 那么linux 中的 i386 i686 i486 i586 究竟是什么含义呢?...那个 i 指的是 Intel 兼容的 CPU 的意思,至于 386 不用说,就是 CPU 的等级啦! i586 就是 586 等级的计算机,那是哪些呢?
= 1; i = i++; int j = i++; int k = i + ++i * i++; System.out.println(...值为1,并且将 i 的值返回给 j,即此条语句以后,i = 2,j = 1 ` 2.4、第四步 int k = i + ++i * i++ [6798b125-1fec-45d1-9627-5ba8251e0aa6...,再来分析 i = ++i,就很简单了。...我们的 i 变量先在局部变量表中进行自增,然后再将 i 进栈,然后再把栈中的数据返回给我们的变量 i 。...~ 回复手册获取博主15万字Java面试通关手册&2万字Linux命令实战书册~
我想大部分都知道 i++ 和 ++i的区别,i++ 就是先拿i来使用,之后再自增加1,而++i则是先自增加1,在拿i来使用,例如对于下面这两个语句,我敢保证大部分人都会做: int i = 1; System.out.println...不过 i++ 和 ++i 这两个操作,在内部是如何实现的呢?...所以虽然i已经等于2了,但此时栈顶的元素却是i之前的值 1 ,所以打印的是1。 这下关于 i ++ 的懂了吧? 那我们来看看 ++ i 与 i ++ 的汇编指令有什么不同。...接下来我们来分析这个程序 int i = 1; System.out.println(i+++i++); System.out.println(i); 这里先说一下,按照运算符号的优先顺序,i+++i+...+等价于 (i++) + (i++)。
本文字数:2355字 阅读本文大概需要:6 分钟 我想大部分都知道 i++ 和 ++i的区别,i++ 就是先拿i来使用,之后再自增加1,而++i则是先自增加1,在拿i来使用,例如对于下面这两个语句,...不过 i++ 和 ++i 这两个操作,在内部是如何实现的呢?...所以虽然i已经等于2了,但此时栈顶的元素却是i之前的值 1 ,所以打印的是1。 这下关于 i ++ 的懂了吧? 那我们来看看 ++ i 与 i ++ 的汇编指令有什么不同。...接下来我们来分析这个程序 int i = 1; System.out.println(i+++i++); System.out.println(i); 这里先说一下,按照运算符号的优先顺序,i+++i+...+等价于 (i++) + (i++)。
i2c-tools的相关命令常用于linux系统读写i2c设备寄存器的在线调试。...安装命令: apt-get update apt-get install i2c-tools linux版本代码下载路径: https://mirrors.edge.kernel.org/pub/software...Usage: i2cdetect [-y] [-a] [-q|-r] I2CBUS [FIRST LAST] i2cdetect -F I2CBUS i2cdetect -l...## 列出i2c总线 root@linaro-alip:/# i2cdetect -l i2c-0 i2c rk3x-i2c ...I2C adapter i2c-1 i2c rk3x-i2c I2C adapter i2c-9 i2c
= 1; i = i++; int j = i++; int k = i + ++i * i++; System.out.println(...结果: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 。
2、对后缀*.i386.rpm及*.i686.rpm的说明 现在可以直接安装的rpm软件包有这么几种(后缀):*.i386.rpm,*.i486.rpm,*.i586.rpm,*.i686.rpm,这是与...据许多资料介绍,在一般情况下,同样是在i686的电脑上执行i386与i686的软件在性能上基本没有大的区别。 3、rpm的i386、i586和i686等不同版本有什么不同?...有的rpm有分i386、i586和i686等不同版本,如: abc-1.2.3-4.i386.rpm abc-1.2.3-4.i586.rpm abc-1.2.3-4.i686.rpm...这里的i386、i586、i686指的是适用于intel i386、 i586、i686 兼容指令集的微处理器。一般来说,等级愈高的机器可接受较低等级的rpm文件。...硬盘接口分为IDE、SATA、SCSI和光纤通道四种 5、linux发行版中的i386/i686/x86-64/有什么区别?
说起这个i++, ++i 入门练习都会搞这个,一如既往,百试不爽。...表达式 a = i++; 它等价于 a = i ; i = i + 1; 表达式 a = ++i 它等价于 i = i + 1; a = i; 1、 首先两者的区别是:前者是先赋值,然后再自增;...但是要注意其生存周期,我们要注意i值在程序流中的变化,如果是for、while循环判断中要特别注意++i的值比i++值要提前。...3、i=1 ; j=(++i)+(++i)+(++i); printf("j= %d/n",j); 这个结果是什么?...i += 2; 这个是 i = i + 2; 自身值加上2后赋值给自己。这个没有争议。 来骚年练习一下 i += (++i)+(++i)+(++i); 呵呵!!!
而这时让我想到了那蛋疼的++ -- 问题,,所以进行了一个实验,,代码如下: #include int main() { volatile int i=0; //用...volatile 修饰i volatile int j=1; // 用volatile 修饰 j int sum=0; sum=(i++)+(++i)+(++i)+(++j
资料下载 coding无法使用浏览器打开,必须用git工具下载: git clone https://e.coding.net/weidongshan/linux/doc_and_source_for_drivers.git...视频观看 百问网驱动大全 I2C协议 参考资料: i2c_spec.pdf 1....硬件连接 I2C在硬件上的接法如下所示,主控芯片引出两条线SCL,SDA线,在一条I2C总线上可以接很多I2C设备,我们还会放一个上拉电阻(放一个上拉电阻的原因以后我们再说)。 2....传输数据类比 怎么通过I2C传输数据,我们需要把数据从主设备发送到从设备上去,也需要把数据从从设备传送到主设备上去,数据涉及到双向传输。...下图:白色背景表示"主→从",灰色背景表示"从→主" 3.3 I2C信号 I2C协议中数据传输的单位是字节,也就是8位。但是要用到9个时钟:前面8个时钟用来传输8数据,第9个时钟用来传输回应信号。
第一时间看干货文章 1 Linux内核将 I2C 驱动分为两部分: I2C 总线驱动, I2C总线驱动就是SOC的 I2C控制器驱动,也叫做 I2C适配器驱动。...I2C驱动 i2c_driver 类似 platform_driver,是我们编写 I2C 设备驱动重点要处理的内容, i2c_driver 结构体定义在 include/linux/i2c.h 文件中...I2C设备 I2C设备结构体i2c_client 结构体定义在 include/linux/i2c.h 文件中,内容如下: struct i2c_client { unsigned short...Linux 内核将 SOC 的 I2C 适配器(控制器)抽象成 i2c_adapter, i2c_adapter 结构体定义在 include/linux/i2c.h 文件中,结构体内容如下: /*...对于我们 I2C 设备驱动编写人来说,重点工作就是构建i2c_driver,构建完成以后需要向Linux内核注册这个i2c_driver。 那么如何注册呢?
Linux总线设备框架的工作原理 如果想要弄清楚I2C驱动框架,必须深刻的理解Linux的总线设备框架。之所以会形成这样的框架,很重要的原因是为了代码的复用性。...为了提高驱动的可移植性,Linux抽象出一套管理资源的函数。设备是存在的硬件,在设备里包含自己的属性,也包含需要用到的资源。...3.Linux下I2C驱动程序的体系结构 ---- 对于Linux下的I2C驱动,其体系结构的组成主要分为三个部分 (1)I2C核心:I2C核心提供了I2C总线驱动和设备驱动的注册,注销方法,I2C通信方法...,也就是注册了一个字符设备驱动程序,可以通过/dev/i2c-0(i2c-0, i2c-1,…, i2c-10,…)找到具体的I2C适配器,这个I2C设备的主设备号为89,次设备号0~255。...i2c_adpater 用来匹配i2c_driver与i2c_client。即 i2c_client 依附于 i2c_adpater。
问题 为什么 2 * (i * i) 比 2 * i * i 效率高?...= 0; i < 1000000000; i++) { n += 2 * (i * i); } System.out.println((double) (System.nanoTime...* i 版本的代码最快完成时间都要比 2 * (i * i) 版本最慢完成时间慢上很多。...因此,问题迎刃而解,2 * (i * i) 之所以比 2 * i * i 效率高,是因为 JIT 为 2 * (i * i) 生成了更佳的汇编代码。...出处 文章翻译自 Stack Overflow:Why is 2 * (i * i) faster than 2 * i * i in Java?
代码 int i = 6; i += i - 1;,我们来逐步分析:初始赋值:int i = 6;,即变量 i 的值初始化为 6。...表达式解析:i += i - 1; 这一行等价于 i = i + (i - 1);。i - 1:当前 i 的值是 6,因此 i - 1 计算结果为 6 - 1 = 5。...i + (i - 1):此时 i 的值仍然是 6,因此 6 + 5 = 11。赋值:最终,i 被赋值为 11。因此,在这段代码执行完毕后,i 等于 11。...具体来说,i - 1 的值是基于 i 的当前值来计算的,而这个计算过程不会影响当前 i 的值。详细过程:第一步:i 的初始值为 6。第二步:先计算 i - 1。...延迟赋值:在表达式 i += i - 1 中,只有在 i + (i - 1) 的所有计算完成之后,结果 11 才会被赋值给 i。
Linux内核将 I2C 驱动分为两部分: I2C 总线驱动, I2C总线驱动就是SOC的 I2C控制器驱动,也叫做 I2C适配器驱动。...I2C驱动 i2c_driver 类似 platform_driver,是我们编写 I2C 设备驱动重点要处理的内容, i2c_driver 结构体定义在 include/linux/i2c.h 文件中...I2C设备 I2C设备结构体i2c_client 结构体定义在 include/linux/i2c.h 文件中,内容如下: struct i2c_client { unsigned short...Linux 内核将 SOC 的 I2C 适配器(控制器)抽象成 i2c_adapter, i2c_adapter 结构体定义在 include/linux/i2c.h 文件中,结构体内容如下: /*...对于我们 I2C 设备驱动编写人来说,重点工作就是构建i2c_driver,构建完成以后需要向Linux内核注册这个i2c_driver。 那么如何注册呢?
如果它显示为i386,它将是32位和amd64,它将是64位,但我得到了这个结果: Linux mukund-ThinkPad-Edge-E431 3.8.0-35-generic #50-Ubuntu...SMP Tue Dec 3 01:25:33 UTC 2013 i686 i686 i686 GNU/Linux 这是什么i686?...Linux Server 2.6.15-23-386 #1 SMP Tue Mar 1 13:49:40 UTC 2011 i686 GNU/Linux Notice the i686 in the code...然而,i686的含义值得更多解释。 在编译Linux内核时(end-users目前通常不需要做的事情 – Ubuntu背后的好人提供内核就绪编译),你可以调整各种选项。...但是,现代CPU具有许多附加功能(集成浮点单元,MMX等),如果配置为Linux,Linux可以使用这些功能。
= 1; i = i++; int j = i++; int k = i + ++i * i++; System.out.println(...其中一个方法对应一个栈帧 此题目我们只需要用到栈帧里面的局部变量表和操作数栈 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 。
(比如E2PROM驱动) I2C核心层: drivers/i2c/i2c-coere.c I2C总线驱动层(主机控制器驱动层):drivers/i2c/busses/i2c-s3c2410.c I2C设备驱动层...I2C核心层 注册I2C总线 由内核开发人员编写的,不涉及具体硬件 给驱动编程人员提供编程接口 I2C总线驱动层 是I2C主机适配器的驱动程序 初始化I2C适配器(控制器) 实现操作方法:根据I2C操作时序进行操作...笔者会大体上对I2C子系统的源码进行分析,如若分析的有出入,还望指出。 I2C核心层 I2C核心层的实现位于drivers/i2c/i2c-core.c中,笔者从i2c_init函数开始分析。...= i2c_device_shutdown, .pm = &i2c_device_pm_ops, }; 根据Linux设备驱动模型的原理,I2C总线下会挂载两条链表,分别为设备链和驱动链...进行赋值,从上文在I2C核心层分析可知,I2C总线是根据id_table进行匹配,所以这里并不会按照常规的Linux驱动模型进行match后probe,况且这个驱动里也没有probe方法。
领取专属 10元无门槛券
手把手带您无忧上云