linux c 格式(linux用什么软件写程序)
linux下c开发了一个应用程序,它的扩展名是什么
这个貌似涉及到linux文件系统。linux文件系统与windows的不相同,windows系统应该是通过文件后缀来进行文件类型是别的,而linux虽然也会借鉴后缀信息,但好像不完全依赖于文件后缀。
比如,在windows下,讲一个txt的文件后缀改为.doc那么系统会提示更改后缀可能导致文件不可用,并且默认以office将其打开,而不是记事本。而在linux上你更改一个文件后缀,不会有系统提示,比如你将一个txt的文件(其实所谓的txt文件在linux下,默认是没有后缀的)后缀改为.pdf,系统任然是用打开txt文件的程序将其打开而不是PDFreader什么的。
说到底,linux文件系统不依赖后缀名来识别文件类型,而是靠一种什么幻数(magic number)。具体是怎样做到的,我也不知道,查查吧;查到记得告诉我,呵呵。。。
linux下c开发一个应用程序,默认后缀是.out。比如你用gcc编译一段C代码:
gcc文件名.c
gcc将默认产生一个a.out的可执行文件。而一般情况下,我们都会更改产生文件的名称,至于后缀,般没有后缀,或者按个人喜好吧。
如果是跨平台的代码的话,那就看目标系统是怎么样的了。像楼下说的ELF文件,这个貌似是16位可执行二进制文件。在linux上进行交叉编译时见过,就是在linux系统里编译一段别的机器(比如路由,PDA,等能装嵌入式linux系统的东西)上可以执行的代码。
怎么在LINUX系统里修改硬盘格式呢
第一个ide设备是hda,第二个是hdb。依此类推
我们一般主板上有两个IDE接口,一共可以安装四个IDE设备。主IDE上的两个设备分别对应hda和hdb,第二个IDE
口上的两个设备对应hdc和hdd。
一般我们的硬盘安装在主IDE的主接口上,所以是hda,光驱一般安装在第二个IDE的主接口上,所以是hdc(应为
hdb是用来命名主IDE上的从接口),SCSI接口设备是用sd命名的,第一个设备是sda,第二个是sdb。依此类推
分区是用设备名称加数字命名的。例如hda1代表hda这个硬盘设备上的第一个分区。每个硬盘可以最多有四个主
分区,作用是1-4命名硬盘的主分区。逻辑分区是从5开始的,每多一个分区,数字加以就可以。
比如我们一般的系统都有一个主分区用来引导系统,这个分区对应我们常说的C区,在linux下命名是hda1。后面
我们分三个逻辑分区对应常说的D、E、F,在linux下命名是hda5、hda6、hda7
给硬盘分区
在slackware下有两个分区软件fdisk和cfdisk,例如我们已经有一个硬盘了,现在添加另一个硬盘到系统,那么
我们根据命名规则知道这个新添加的硬盘应该是hdb。我们用下面命令给硬盘分区
fdisk/dev/hdb
你也可以用cfdisk来分区,命令如下:
mkfs.ext3/dev/hdb1
格式化成reiserfs的格式
mkfs.reiserfs/dev/hdb1
让硬盘启动自动挂载
例如挂载/dev/hdb1分区到/mnt/hd目录下
用vi编辑/etc/fstab文件,加入如下内容
/dev/dhb1/mnt/hd reiserfs defaults 1 1
以下个人使用过程:
如新增一个新硬盘(hda),进行分区、格式化等
使用fdisk分区
输入:fdisk/dev/hda
Command(m for help):p<--p为显示当前分区状态
Command(m for help):m<--m为命令列表
Command action
a toggle a bootable flag
b edit bsd disklabel
c toggle the dos compatibility flag
d delete a partition(删除分区)
l list known partition types
m print this menu
n add a new partition(新增分区)
o create a new empty DOS partition table
p print the partition table
q quit without saving changes(不保存退出)
s create a new empty Sun disklabel
t change a partition's system id
u change display/entry units
v verify the partition table
w write table to disk and exit(保存并退出)
x extra functionality(experts only)
Command(m for help): n<==选择新增
Command action
e extended(扩展分区)
p primary partition(1-4)(主分区)
输入:p新增主分区Pa
Partition number(1-4):1
First cylinder(1-10240, default 1):<==这里按 Enter即可!用预设值,即从1磁道开始
Using default value 1
Last cylinder or+size or+sizeM or+sizeK(1-10240, default 10240): 10240<--输入磁盘大小
完成分区设定,输入w可保存并退出,必须输入w才生效。
分区后重启,再进行格式化:
格式化命令:mkfs.ext3/dev/hda1
挂载新分区:vi/etc/fstab
添加:/dev/dhb1/game ext3 defaults 0 0
df-h查看挂载分区
fdisk-l查看磁盘状态
linux改变硬盘lable
e2label device [newlabel]创建设备的标签命令
比如我们想把文件系统为ext3的分区/dev/hda5的标签设备为/5,我们应该执行如下的命令:
[root@localhost]# e2label/dev/hda5/5
如果是reiserfs文件系统,我们应该用
[root@localhost]# reiserfstune-l标签设备
举例:比如我为reiserfs文件系统/dev/hda10设置标签为/10;
[root@localhost]# reiserfstune-l/10/dev/hda10
警告:请不要在您的Linux的安装分区(也就是Linux系统/所在的分区)实践,会导致您的Linux系统崩溃;如
果想实践,请在其它分区测试。
通过以上, ext和reiserfs两类linux主流分区格式就已经能够设定label了。
其实mkfs命令也可以设定label,例如:
mkfs-L/1/dev/sda1
不过会将分区给格式化为ext2一遍,再设定label。我一开始不知道,结果导致分区又被格式化了一次,幸亏
没有数据。
label除了跟分区一个昵称,还有什么作用?
其实通过label,我们可以在mount挂载分区时,避免使用/dev/sda这样的设备名,取而代之的是label。有什么
好处呢?有时候新加一块硬盘,硬盘跳线有变化,都可能导致/dev/sda的变化,但label就不会变。
看看mount命令如何用label:
那就应该是:
mount-L/1/mnt/test
(label为/1的分区挂载到/mnt/test)
fstab中根据label来挂载:
LABEL=/1/mnt/test ext3 defaults 1 1
linux查看系统编码格式命令linux查看系统编码
linux有查看支持那些编码的命令吗?
1、连接上相应的linux主机,进入到等待输入shell指令的linux命令行状态下。
2、其次,在linux命令行中输入:echo$LANG。
3、最后,按下回车键执行shell指令,此时会看到该linux的汉字编码是utf-8。
linux怎么看文本的编码格式?
linux下经常遇到的编码问题如果你需要在linux中操作windows下的文件,那么你可能会经常遇到文件编码转换的问题。windows中默认的文件格式是gbk(gb2312),而linux一般都是utf-8。
查看编码的方法
方法一:filefilename
方法二:在vim中可以直接查看文件编码
:setfileencoding
如果你只是想查看其它编码格式的文件或者想解决用vim查看文件乱码的问题,那么你可以在
~/.vimrc文件中添加以下内容:
setencoding=utf-8fileencodings=ucs-bom,utf-8,cp936
这样,就可以让vim自动识别文件编码(可以自动识别utf-8或者gbk编码的文件),其实就是依照fileencodings提供的编码列表尝试,如果没有找到合适的编码,就用latin-1(ascii)编码打开
文件编码转换
多平台方法:
iconv提供标准的程序和api来进行编码转换;
convert_encoding.py基于python的文本文件转换工具;
decodeh.py提供算法和模块来谈测字符的编码;
linux下文件编码转换:
方法一:
在vim中直接进行转换文件编码,比如将一个文件转换成utf-8格式
:setfileencoding=utf-8
或者
11)设置文件集合,即要对哪些文件进行操作,可以使用通配符,比如我通常是对c/c++源程序进行编码转换
:args*.h*.cpp
2)给出要在每个文件上执行的命令,这里是转换编码:
:argdosetfenc=utf-8|update
方法二:
iconv转换
5.案例:
假如说我们将windows下的一个utf-8的文件传到linux环境下,linux环境下的系统编码是gb18030,我们cat的时候就会出现乱码,这个时候就应该想到转码了,下面我们来进行试验:
我们将windows下一个名为utf-8.sh的文件传到linux系统中,其中utf-8.sh的内容如下:
我是中文编码utf-8模式~
而linux系统的系统语言设置为:
#cat/etc/sysconfig/i18n
lang=zh_cn.gb18030
sysfont="latarcyrheb-sun16"
这个时候查看一下文件的内容及编码:
#fileutf-8.sh
utf-8.sh:utf-8unicodetext,withnolineterminators
#catutf-8.sh
锘挎__?腑___镰_tf-8妯″纺~#
#
这个时候我们就需要转换编码了,记得使用iconv
#iconv-futf-8-tgb18030utf-8.sh-ogb18030.sh
#catgb18030.sh
??我是中文编码utf-8模式~#
#filegb18030.sh
gb18030.sh:non-isoextended-asciitext,withnolineterminators
#
convmv就是更改文件名编码方式的一个工具。
比如
sudoconvmv-fgbk-tutf-8-r_notest/home
就是将/home目录下原来文件名是gbk编码方式的全部改为utf-8格式的。这里-f后面为原来的编码方式,-t后面是要更改为的编码方式,-r表示这个目录下面的所有文件,_notest表示马上执行,而不是仅仅测试而已。另外这命令好像要root才能执行,因此要加上sudo。
linux怎么看文件的字符集编码?
可以在命令行执行file命令查看返回信息以便确认文件的字符集编码。
格式:file文件名
例如:
#fileABC.log
ABC.log:UTF-8Unicodetext
从结果看该文件是utf-8格式
#fileword.txtword.txt:ASCIItext
从结果看该文件是gbk格式
如果不符合要求,可以通过iconv命令更改文件格式。
linux下怎么改变文件的编码格式?
查看文件编码在Linux中查看文件编码可以通过以下几种方式:1.在Vim中可以直接查看文件编码:setfileencoding即可显示文件编码格式。如果你只是想查看其它编码格式的文件或者想解决用Vim查看文件乱码的问题,那么你可以在~/.vimrc文件中添加以下内容:setencoding=utf-8fileencodings=ucs-bom,utf-8,cp936这样,就可以让vim自动识别文件编码(可以自动识别UTF-8或者GBK编码的文件),其实就是依照fileencodings提供的编码列表尝试,如果没有找到合适的编码,就用latin-1(ASCII)编码打开。2.enca(如果你的系统中没有安装这个命令,可以用sudoyuminstall-yenca安装)查看文件编码$encafilenamefilename:Universaltransformationformat8bits;UTF-8CRLFlineterminators需要说明一点的是,enca对某些GBK编码的文件识别的不是很好,识别时会出现:Unrecognizedencoding文件编码转换1.在Vim中直接进行转换文件编码,比如将一个文件转换成utf-8格式:setfileencoding=utf-82.enconv转换文件编码,比如要将一个GBK编码的文件转换成UTF-8编码,操作如下enconv-Lzh_CN-xUTF-8filename3.iconv转换,iconv的命令格式如下:iconv-fencoding-tencodinginputfile比如将一个UTF-8编码的文件转换成GBK编码iconv-fUTF-8-tGBKfile1-ofile2查看文件编码file命令fileip.txtip.txt:UTF-8Unicodetext,withescapesequences一、利用iconv命令进行编码转换文件内容编码转换iconv命令用于转换指定文件的编码,默认输出到标准输出设备,亦可指定输出文件。用法:iconv有如下选项可用:输入/输出格式规范:-f,--from-code=名称原始文本编码-t,--to-code=名称输出编码信息:-l,--list列举所有已知的字符集输出控制:-c从输出中忽略无效的字符-o,--output=FILE输出文件-s,--silent关闭警告--verbose打印进度信息-?,--help给出该系统求助列表--usage给出简要的用法信息-V,--version打印程序版本号例子:iconv-futf-8-tgb2312aaa.txt>bbb.txt这个命令读取aaa.txt文件,从utf-8编码转换为gb2312编码,其输出定向到bbb.txt文件。二、文件名编码转换因为现在用linux,原来在windows里的文件都是用GBK编码的。所以copy到linux下是乱码,文件内容可以用iconv来转换可是好多中文的文件名还是乱码,找到个可以转换文件名编码的命令,就是convmv。convmv命令详细参数例如convmv-fGBK-tUTF-8*.mp3不过这个命令不会直正的转换,你可以看到转换前后的对比。如果要直正的转换要加上参数--notestconvmv-fGBK-tUTF-8--notest*.mp3-f参数是指出转换前的编码,-t是转换后的编码。这个千万不要弄错了。不然可能还是乱码哦。还有一个参数很有用。就是-r这个表示递归转换当前目录下的所有子目录。*需要安装convmv-1.10-1.el5.noarch.rpm三、更好的傻瓜型命令行工具enca,它不但能智能的识别文件的编码,而且还支持成批转换。1.安装$sudoapt-getinstallenca2.查看当前文件编码enca-Lzh_CNip.txtSimplifiedChineseNationalStandard;GB2312Surroundedby/intermixedwithnon-textdata3.转换命令格式如下$enca-L当前语言-x目标编码文件名例如要把当前目录下的所有文件都转成utf-8enca-Lzh_CN-xutf-8*检查文件的编码enca-Lzh_CNfile将文件编码转换为"UTF-8"编码enca-Lzh_CN-xUTF-8file如果不想覆盖原文件可以这样enca-Lzh_CN-xUTF-8file1>file2
linux文件一般是什么编码格式?
查看文件编码在Linux中查看文件编码可以通过以下几种方式:
1.在Vim中可以直接查看文件编码:setfileencoding即可显示文件编码格式。如果你只是想查看其它编码格式的文件或者想解决用Vim查看文件乱码的问题,那么你可以在~/.vimrc文件中添加以下内容:setencoding=utf-8fileencodings=ucs-bom,utf-8,cp936这样,就可以让vim自动识别文件编码(可以自动识别UTF-8或者GBK编码的文件),其实就是依照fileencodings提供的编码列表尝试,如果没有找到合适的编码,就用latin-1(ASCII)编码打开。
2.enca(如果你的系统中没有安装这个命令,可以用sudoyuminstall-yenca安装)查看文件编码$encafilenamefilename:Universaltransformationformat8bits;UTF-8CRLFlineterminators需要说明一点的是,enca对某些GBK编码的文件识别的不是很好,识别时会出现:Unrecognizedencoding