包含javaelif的词条
今天给各位分享javaelif的知识,其中也会对进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
本文目录一览:
- 1、java程序在linux下无法显示图片
- 2、JAVA 查询数据库 out of memory报错问题
- 3、请问java里有 elseif吗?
- 4、ubuntu14.04怎样安装pycharm
- 5、请问c++和c#以及java之间有什么相同点、不同点。c#吸收了java和c++语言的哪些优点?
- 6、java编程中出现的错误“非法字符:\56288”是什么意思?
java程序在linux下无法显示图片
1.调用"images"文件夹里的文件放在ImageIcon里显示
2.在windows下面显示正常Java在图形处理时调用了本地的图形处理库。在利用Java作图形处理(比如:图片缩放,图片签名,生成报表)时,如果运行在windows上不会出问题。如果将程序移植到Linux/Unix上的时候有可能出现图形不能显示的错误。
3.提示信息:"Can't connect to X11 window server"这是由于Linux的图形处理需要一个X Server服务器。(关于Linux的图形处理模式参考htt p://)
解决办法:
1.如果服务器上安装有图形界面,可以通过设置环境变量:DISPALY=127.0.0.1:0.0解决。
2. 如果没有安装图形界面,可以在Java运行时加上参数:-Djava.awt.headless=true。
3. 使用PJA库来代替本地图形处理库。
参考: Tomcat的修改如下:
打开 %Tomcat_home%/bin/catalina.sh 文件在文件的86%处,启动Tomcat的脚本中加上:-Djava.awt.headless=true /
参考:
"$_RUNJAVA" $JAVA_OPTS $CATALINA_OPTS /
-Djava.endorsed.dirs="$JAVA_ENDORSED_DIRS"
-classpath "$CLASSPATH" /
-Dcatalina.base="$CATALINA_BASE" /
-Dcatalina.home="$CATALINA_HOME" /
-Djava.io.tmpdir="$CATALINA_TMPDIR" /
-Djava.awt.headless=true /
org.apache.catalina.startup.Bootstrap "$@" start /
"$CATALINA_BASE"/logs/catalina.out 21
if [ ! -z "$CATALINA_PID" ]; then
echo $! $CATALINA_PID fi
fielif [ "$1" = "stop" ] ; then
保存后,重新启动就可以处理图形了。
JAVA 查询数据库 out of memory报错问题
jvm与tomcat内存设置
linix系统平台大并发量下tomcat5.5优化策略(2009-03-11 12:45:24)
标签:linux tomcat5.5 优化策略 it 分类:java
在部署系统后,为了增加系统并发量,系统响应速度,做了一些工作;遂整理如下。
1、修改server.xml文件
Connector port="80" protocol="HTTP/1.1"
maxHttpHeaderSize="8192"
maxThreads="1000" minSpareThreads="75" maxSpareThreads="300"
enableLookups="false" redirectPort="8443" acceptCount="200"
connectionTimeout="50000" disableUploadTimeout="true"/
主要修改了maxThreads、acceptCount。
引用
Google资料说“如果要加大并发连接数,应同时加大这两个参数。web server允许的最大连接数还受制于操作系统的内核参数设置,通常Windows是2000个左右,Linux是1000个左右。”
2、增加tomcat启动初始内存设置;catalina.sh – 增加了参数内存设置
内存为2G情况:
JAVA_OPTS="-server -Xms1500M -Xmx1500M -Xss256K -Djava.awt.headless=true -XX:PermSize=64M -XX:MaxPermSize=128m"
(补充:-Dfile.encoding=utf8 加入这个,是设置文件写入的编码方式)
引用
Heap Size 最大不要超过可用物理内存的80%,一般的要将-Xms和-Xmx选项设置为相同
堆内存分配
JVM初始分配的内存由-Xms指定,默认是物理内存的1/64;JVM最大分配的内存由-Xmx指定,默认是物理内存的1/4。默认空余堆内存小于40%时,JVM就会增大堆直到-Xmx的最大限制;空余堆内存大于70%时,JVM会减少堆直到-Xms的最小限制。因此服务器一般设置-Xms、-Xmx相等以避免在每次GC 后调整堆的大小。
非堆内存分配
JVM使用-XX:PermSize设置非堆内存初始值,默认是物理内存的1/64;由XX:MaxPermSize设置最大非堆内存的大小,默认是物理内存的1/4。
JVM内存限制(最大值)
首先JVM内存限制于实际的最大物理内存,假设物理内存无限大的话,JVM内存的最大值跟操作系统有很大的关系。简单的说就32位处理器虽然可控内存空间有4GB,但是具体的操作系统会给一个限制,这个限制一般是2GB-3GB(一般来说Windows系统下为1.5G-2G,Linux系统下为2G-3G),而64bit以上的处理器就不会有限制了。
-Djava.awt.headless=true
Java在图形处理时调用了本地的图形处理库。在利用Java作图形处理(比如:图片缩放,图片签名,生成报表)时,如果运行在windows上不会出问题。如果将程序移植到Linux/Unix上的时候有可能出现图形不能显示的错误。提示信息:"Can't connect to X11 window server"这是由于Linux的图形处理需要一个X Server服务器。解决办法就是设置参数。
Xss:每个线程的Stack大小。Stack的大小限制着线程的数量。如果Stack过大就好导致内存溢漏。-Xss参数决定Stack大小,例如-Xss1024K。如果Stack太小,也会导致Stack溢漏。
Tomcat 怎么增加内存?
转载修改方法开始
打开bin目录,找到catalina.bat(windows系统)或catalina.sh(linux系统),在前边一堆的#号注释结束之后增加如下配置
windows的:
set CATALINA_OPTS="-server -Xms256m -Xmx256m -XX:PermSize=64M -XX:MaxNewSize=256m -XX:MaxPermSize=128m"
linux的:
JAVA_OPTS=='-server -Xms256m -Xmx256m -XX:PermSize=64M -XX:MaxNewSize=256m -XX:MaxPermSize=128m'
转载修改方法 结束
悬赏:3 发布时间:2008-08-14 提问人:rihoonet (初级程序员)
猎头职位: 北京: 北京知名手机网站诚聘java高级程序员
报错:java.lang.OutOfMemoryError: Java heap space
TOMCAT版本 5.5.23
曾试过的方法。
/tomcat/bin/catalina.bat 加上下面的命令:
set JAVA_OPTS=-Xms32m -Xmx1024m --这样启动不了了。。奇怪。
采纳的答案
2008-08-14 小疯子 (资深程序员)
Java代码
set JAVA_OPTS=-Xms32m -Xmx1024m %JAVA_OPTS%
set JAVA_OPTS=-Xms32m -Xmx1024m %JAVA_OPTS%, 要引用原来的JAVA_OPTS, 不然把原来的覆盖了.
增加Tomcat虚拟内存大小
--------------------------------------------------------------------------------
JVM的大小设置(unix平台tomcat):调整 $ CATALINA _HOME \bin\catalina.sh文件。
elif [ "$1" = "start" ] ; then
shift
touch "$CATALINA_BASE"/logs/catalina.out
if [ "$1" = "-security" ] ; then
echo "Using Security Manager"
shift
"$_RUNJAVA" $JAVA_OPTS $CATALINA_OPTS \
-Djava.endorsed.dirs="$JAVA_ENDORSED_DIRS" -classpath "$CLASSPATH" \
-Djava.security.manager \
-Djava.security.policy=="$CATALINA_BASE"/conf/catalina.policy \
-Dcatalina.base="$CATALINA_BASE" \
-Dcatalina.home="$CATALINA_HOME" \
-Djava.io.tmpdir="$CATALINA_TMPDIR" \
org.apache.catalina.startup.Bootstrap "$@" start \
"$CATALINA_BASE"/logs/catalina.out 21
else
"$_RUNJAVA" $JAVA_OPTS -Xms1024m -Xmx1024m $CATALINA_OPTS \
-Djava.endorsed.dirs="$JAVA_ENDORSED_DIRS" -classpath "$CLASSPATH" \
-Dcatalina.base="$CATALINA_BASE" \
-Dcatalina.home="$CATALINA_HOME" \
-Djava.io.tmpdir="$CATALINA_TMPDIR" \
org.apache.catalina.startup.Bootstrap "$@" start \
"$CATALINA_BASE"/logs/catalina.out 21
fi
注意红色部分–Xms1024m –Xmx1024m,这句话表示jvm的最小值为1024M,最大1024M,这个部分的调优需要根据web服务器主机硬件配置不同而调整,初始化堆的大小执行了虚拟机在启动时向系统申请的内存的大小。一般而言,这个参数不重要。但是有的应用程序在大负载的情况下会急剧地占用更多的内存,此时这个参数就是显得非常重要,如果虚拟机启动时设置使用的内存比较小而在这种情况下有许多对象进行初始化,虚拟机就必须重复地增加内存来满足使用。由于这种原因,我们一般把-Xms和-Xmx设为一样大,而堆的最大值受限于系统使用的物理内存。一般使用数据量较大的应用程序会使用持久对象,内存使用有可能迅速地增长。当应用程序需要的内存超出堆的最大值时虚拟机就会提示内存溢出,并且导致应用服务崩溃。因此一般建议堆的最大值设置为可用内存的最大值的80%。
JVM的大小设置(windows平台tomcat):
1)停掉现在的Tomcat服务(假设已经启动)
net stop "Apache Tomcat 4.1"
2)卸载Tomcat服务
tomcat.exe -uninstall "Apache Tomcat 4.1"
3)重新配置启动参数
tomcat.exe -install "Apache Tomcat 4.1" "%JAVA_HOME%\jre\bin\server\jvm.dll" -Djava.class.path="%CATALINA_HOME%\bin\bootstrap.jar;%JAVA_HOME%\lib\tools.jar" -Dcatalina.home="%CATALINA_HOME%" -Xrs -Xmx512m -Xms512m -start org.apache.catalina.startup.Bootstrap -params start -stop org.apache.catalina.startup.Bootstrap -params stop -out "%CATALINA_HOME%\logs\stderr.log"
4)在服务中重新启动Tomcat服务,完成配置。
其中红色部分也是调整jvm的大小的地方。调整原则同上。
另外:查看jvm的方法:$webapp\cache.jsp。需要提醒的是,通过这个页面能看出大概的jvm使用数量大小,通常实际的jvm大小要比页面显示的偏大些。
-----------------------------------------------------------------------------------
秦敏:rem Set JVM Memery Size
set JAVA_OPTS=-Xms800m -Xmx1024m
-----------------------------------------------------------------------------------
windows中大家都知道,JAVA程序启动时都会JVM都会分配一个初始内存和最大内存给这个应用程序。这个初始内存和最大内存在一定程度都会影响程序的性能。比如说在应用程序用到最大内存的时候,JVM是要先去做垃圾回收的动作,释放被占用的一些内存。
所以想调整Tomcat的启动时初始内存和最大内存就需要向JVM声明,一般的JAVA程序在运行都可以通过中-Xms -Xmx来调整应用程序的初始内存和最大内存:
如:java -Xms64m -Xmx128m a.jar.
tomcat的启动程序是包装过的,不能直接使用java -X..... tomcat.*来改变内存的设置。在Tomcat在改变这个设置
有两种方法:
1. 就需要在环境变量中加上TOMCAT_OPTS, CATALINA_OPTS两个属性,
如 SET CATALINA_OPTS= -Xms64m -Xmx512m;
ms是最小的,mx是最大,64m, 512m分别是指内存的容量.
2. 修改Catalina.bat文件
在166行“rem Execute Java with the applicable properties ”以下每行
%_EXECJAVA% %JAVA_OPTS% %CATALINA_OPTS% %DEBUG_OPTS% -Djava.endorsed.dirs="%JAVA_ENDORSED_DIRS%" -classpath "%CLASSPATH%" -Dcatalina.base="%CATALINA_BASE%" -Dcatalina.home="%CATALINA_HOME%" -Djava.io.tmpdir="%CATALINA_TMPDIR%" %MAINCLASS% %CMD_LINE_ARGS% %ACTION% 中的%CATALINA_OPTS% 替换成-Xms64m -Xmx512m(把四行内的%CATALINA_OPTS%都替换掉,包括两边的%)
___________________________________________________________________________________________
Tomcat本身不能直接在计算机上运行,需要依赖于硬件基础之上的操作系统和一个java虚拟机。您可以选择自己的需要选择不同的操作系统和对应的JDK的版本(只要是符合Sun发布的Java规范的),但我们推荐您使用Sun公司发布的JDK。确保您所使用的版本是最新的,因为Sun公司和其它一些公司一直在为提高性能而对java虚拟机做一些升级改进。一些报告显示JDK1.4在性能上比JDK1.3提高了将近10%到20%。
可以给Java虚拟机设置使用的内存,但是如果你的选择不对的话,虚拟机不会补偿。可通过命令行的方式改变虚拟机使用内存的大小。如下表所示有两个参数用来设置虚拟机使用内存的大小。
参数
描述
-Xms
JVM初始化堆的大小
-Xmx
JVM堆的最大值
这两个值的大小一般根据需要进行设置。初始化堆的大小执行了虚拟机在启动时向系统申请的内存的大小。一般而言,这个参数不重要。但是有的应用程序在大负载的情况下会急剧地占用更多的内存,此时这个参数就是显得非常重要,如果虚拟机启动时设置使用的内存比较小而在这种情况下有许多对象进行初始化,虚拟机就必须重复地增加内存来满足使用。由于这种原因,我们一般把-Xms和-Xmx设为一样大,而堆的最大值受限于系统使用的物理内存。一般使用数据量较大的应用程序会使用持久对象,内存使用有可能迅速地增长。当应用程序需要的内存超出堆的最大值时虚拟机就会提示内存溢出,并且导致应用服务崩溃。因此一般建议堆的最大值设置为可用内存的最大值的80%。
Tomcat默认可以使用的内存为128MB,在较大型的应用项目中,这点内存是不够的,需要调大。
Windows下,在文件/bin/catalina.bat,Unix下,在文件/bin/catalina.sh的前面,增加如下设置:
JAVA_OPTS='-Xms【初始化内存大小】 -Xmx【可以使用的最大内存】'
需要把这个两个参数值调大。例如:
JAVA_OPTS='-Xms256m -Xmx512m'
表示初始化内存为256MB,可以使用的最大内存为512MB。
另外需要考虑的是Java提供的垃圾回收机制。虚拟机的堆大小决定了虚拟机花费在收集垃圾上的时间和频度。收集垃圾可以接受的速度与应用有关,应该通过分析实际的垃圾收集的时间和频率来调整。如果堆的大小很大,那么完全垃圾收集就会很慢,但是频度会降低。如果你把堆的大小和内存的需要一致,完全收集就很快,但是会更加频繁。调整堆大小的的目的是最小化垃圾收集的时间,以在特定的时间内最大化处理客户的请求。在基准测试的时候,为保证最好的性能,要把堆的大小设大,保证垃圾收集不在整个基准测试的过程中出现。
如果系统花费很多的时间收集垃圾,请减小堆大小。一次完全的垃圾收集应该不超过 3-5 秒。如果垃圾收集成为瓶颈,那么需要指定代的大小,检查垃圾收集的详细输出,研究 垃圾收集参数对性能的影响。一般说来,你应该使用物理内存的 80% 作为堆大小。当增加处理器时,记得增加内存,因为分配可以并行进行,而垃圾收集不是并行的。
Tomcat 5常用优化和配置
1、JDK内存优化:
Tomcat默认可以使用的内存为128MB,Windows下,在文件{tomcat_home}/bin/catalina.bat,Unix下,在文件{tomcat_home}/bin/catalina.sh的前面,增加如下设置:
JAVA_OPTS='-Xms[初始化内存大小] -Xmx[可以使用的最大内存]
一般说来,你应该使用物理内存的 80% 作为堆大小。
2、连接器优化:
在tomcat配置文件server.xml中的配置中,和连接数相关的参数有:
maxThreads:
Tomcat使用线程来处理接收的每个请求。这个值表示Tomcat可创建的最大的线程数。默认值200。
acceptCount:
指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理。默认值10。
minSpareThreads:
Tomcat初始化时创建的线程数。默认值4。
maxSpareThreads:
一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程。默认值50。
enableLookups:
是否反查域名,默认值为true。为了提高处理能力,应设置为false
connnectionTimeout:
网络连接超时,默认值60000,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。
maxKeepAliveRequests:
保持请求数量,默认值100。
bufferSize:
输入流缓冲大小,默认值2048 bytes。
compression:
压缩传输,取值on/off/force,默认值off。
其中和最大连接数相关的参数为maxThreads和acceptCount。如果要加大并发连接数,应同时加大这两个参数。web server允许的最大连接数还受制于操作系统的内核参数设置,通常Windows是2000个左右,Linux是1000个左右。
3、tomcat中如何禁止和允许列目录下的文件
在{tomcat_home}/conf/web.xml中,把listings参数设置成false即可,如下:
...
listings
false
...
4、tomcat中如何禁止和允许主机或IP地址访问
...
allow="*.mycompany.com,"/
deny="192.168.1.*"/
...
这是我们服务器的配置,具体文件不能给你,因为涉及到公司机密,所以那一行我给你,我拷贝下来了
JAVA_OPTS='-server -Xms512m -Xmx768m -XX:NewSize=128m -XX:MaxNewSize=192m -XX:SurvivorRatio=8'
请问java里有 elseif吗?
有呀,再else 和 if中间加个空格就可以
if ()
{
}
else if()
{
}
ubuntu14.04怎样安装pycharm
1. 下载
选择Linux Tab,选择下载免费的Community Edition【1】。当前版本是3.4
2. 安装PyCharm
按照官网给出的安装指导【2】进行安装。
(1) Copy the pycharm-*.tar.gz to the desired installation location (make sure you have rw permissions for that directory)
$ cd Downloads/
(2)Unpack the pycharm-*.tar.gz using the following command: tar xfz pycharm-*.tar.gz
$ tar xfz pycharm-*.tar.gz
(3)Remove the pycharm-*.tar.gz to save disk space (optional)
$ rm pycharm-*.tar.gz
(4)Run pycharm.sh from the bin subdirectory
$ cd pycharm-community-3.4.1/bin/
$ ./pycharm.sh
但是安装开始,出现如下错误:
ERROR: Cannot start PyCharm
No JDK found. Please validate either PYCHARM_JDK, JDK_HOME or JAVA_HOME environment variable points to valid JDK installation.
打开pycharm.ch文件查看,发现报错的地方在:
复制代码
message()
{
TITLE
="Cannot start PyCharm"
if [ -t 1 ]; then
echo "ERROR: $TITLE\n$1"
elif [ -n `which zenity` ]; then
zenity --error --title="$TITLE" --text="$1"
elif [ -n `which kdialog` ]; then
kdialog --error --title "$TITLE" "$1"
elif [ -n `which xmessage` ]; then
xmessage -center "ERROR: $TITLE: $1"
elif [ -n `which notify-send` ]; then
notify-send "ERROR: $TITLE: $1"
else
echo "ERROR: $TITLE\n$1"
fi
}
# ---------------------------------------------------------------------
# Locate a JDK installation directory which will be used to run the IDE.
# Try (in order): PYCHARM_JDK, JDK_HOME, JAVA_HOME, "java" in PATH.
# ---------------------------------------------------------------------
if [ -n "$PYCHARM_JDK" -a -x "$PYCHARM_JDK/bin/java" ]; then
JDK="$PYCHARM_JDK"
elif [ -n "$JDK_HOME" -a -x "$JDK_HOME/bin/java" ]; then
JDK="$JDK_HOME"
elif [ -n "$JAVA_HOME" -a -x "$JAVA_HOME/bin/java" ]; then
JDK="$JAVA_HOME"
else
JAVA_BIN_PATH=`which java`
if [ -n "$JAVA_BIN_PATH" ]; then
if [ "$OS_TYPE" = "FreeBSD" -o "$OS_TYPE" = "MidnightBSD" ]; then
JAVA_LOCATION=`JAVAVM_DRYRUN=yes java | "$GREP" '^JAVA_HOME' | "$CUT" -c11-`
if [ -x "$JAVA_LOCATION/bin/java" ]; then
JDK="$JAVA_LOCATION"
fi
elif [ "$OS_TYPE" = "SunOS" ]; then
JAVA_LOCATION="/usr/jdk/latest"
if [ -x "$JAVA_LOCATION/bin/java" ]; then
JDK="$JAVA_LOCATION"
fi
elif [ "$OS_TYPE" = "Darwin" ]; then
JAVA_LOCATION=`/usr/libexec/java_home`
if [ -x "$JAVA_LOCATION/bin/java" ]; then
JDK="$JAVA_LOCATION"
fi
fi
if [ -z "$JDK" -a -x "$READLINK" -a -x "$XARGS" -a -x "$DIRNAME" ]; then
JAVA_LOCATION=`"$READLINK" -f "$JAVA_BIN_PATH"`
case "$JAVA_LOCATION" in
*/jre/bin/java)
JAVA_LOCATION=`echo "$JAVA_LOCATION" | "$XARGS" "$DIRNAME" | "$XARGS" "$DIRNAME" | "$XARGS" "$DIRNAME"`
if [ ! -d "$JAVA_LOCATION/bin" ]; then
JAVA_LOCATION="$JAVA_LOCATION/jre"
fi
;;
*)
JAVA_LOCATION=`echo "$JAVA_LOCATION" | "$XARGS" "$DIRNAME" | "$XARGS" "$DIRNAME"`
;;
esac
if [ -x "$JAVA_LOCATION/bin/java" ]; then
JDK="$JAVA_LOCATION"
fi
fi
fi
fi
if [
-z "$JDK"
]; then
message
"No JDK found. Please validate either PYCHARM_JDK, JDK_HOME or JAVA_HOME environment variable points to valid JDK installation."
exit 1
fi
复制代码
说明没有找到JDK location path。需要安装并配置JDK了。
3. 安装JDK
首先查了一下Ubuntu12.04是否支持JDK8,发现还是支持的。那就放心安装吧。
参照【3】的方法,通过设置源仓库的方式安装。(如果想手动安装,请参考【5】【6】)
Important: This PPA supports Ubuntu 14.04, 13.10, 12.04 and 10.04 as well as the corresponding Linux Mint versions. Ubuntu 13.04 and 12.10 are no longer supported by Canonical
(1)返回到Home目录:“~”,然后依次执行一下几条command
sudo add-apt-repository ppa:webupd8team/java
sudo apt-get update
sudo apt-get install oracle-java8-installer
安装过程中会跳出Oracle license对话框,选择接受就是了。
(2)安装完成后,运行"java -version"或者"javac -version"查看是否安装成功。如果得到类似如下的输出,表明安装成功了。
$ java -version
java version "1.8.0_20"
Java(TM) SE Runtime Environment (build 1.8.0_20-b26)
Java HotSpot(TM) 64-Bit Server VM (build 25.20-b23, mixed mode)
$ javac -version
javac 1.8.0_20
(3) 在【3】中说道,如果想automatically set up the Java 8 environment variables,可以使用下面的command:
sudo apt-get install oracle-java8-set-default
我使用该command后,在Terminal中运行 echo $JAVA_HOME,没有任何输出。看来是没起什么作用。有可能是在一开始配置完repository后,安装时使用该条命令,可以以后尝试一下。
UPDATED: 使用 sudo apt-get install oracle-java8-set-default,测试echo $JAVA_HOME,仍然是没有$JAVA_HOME环境变量的。还是需要手动设置。
由于一些程序在运行时可能默认需要 $JAVA_HOME 环境变量,因此还是需要设置一下环境变量的。
4. 配置$JAVA_HOME 环境变量
参考【4】中 Setting the "JAVA_HOME" environment variable 一节进行设置。
(1)Find out the path of your Java installation:
sudo update-alternatives --config java
它将返回类似如下的结果,列出了本机所安装的所有Java运行时环境JRE。(共有2个:JDK7和OpenJDK6,0和2是同一个,auto mode和manual mode的差别)
复制代码
There are 2 choices for the alternative java (providing /usr/bin/java).
Selection Path Priority Status
------------------------------------------------------------
* 0 /usr/lib/jvm/java-7-oracle/jre/bin/java 1062 auto mode
1 /usr/lib/jvm/java-6-openjdk-amd64/jre/bin/java 1061 manual mode
2 /usr/lib/jvm/java-7-oracle/jre/bin/java 1062 manual mode
Press enter to keep the current choice[*], or type selection number:
复制代码
对应的各个JRE的 安装路径分别为:
0. /usr/lib/jvm/java-7-oracle
1. /usr/lib/jvm/java-6-openjdk-amd64
2. /usr/lib/jvm/java-7-oracle
在我本机 执行 sudo update-alternatives --config java 的结果为:
Selection Path Priority Status
------------------------------------------------------------
0 /usr/lib/jvm/java-8-oracle/jre/bin/java 1 auto mode
* 1 /usr/lib/jvm/java-8-oracle/jre/bin/java 1 manual mode
Press enter to keep the current choice[*], or type selection number:
可见只安装了一个Java环境: JDK8。它对应的安装路径为:
/usr/lib/jvm/java-8-oracle
(2)编辑/etc/environment文件
sudo nano /etc/environment
复制上面的路径 /usr/lib/jvm/java-8-oracle,添加如下一行
JAVA_HOME="/usr/lib/jvm/java-8-oracle"
(3) Reload该文件,使之立即生效,而不必注销并重新登录
source /etc/environment
(4)使用下面的命令测试
echo $JAVA_HOME
会输出刚才所设置的路径 /usr/lib/jvm/java-8-oracle。
5. 再次安装PyCharm
(1)cd到Downloads/pycharm-community-3.4.1/bin/目录,执行./pycharm.sh。询问是否导入settings,选择不导入-OK.
image
(2) 初始设置,保持默认-OK.
575D0ZC`9]VL5A8A@C)%)U8
(3) 创建一个Launcher脚本,需要输入密码。
image
(4)出现下面的画面,表明安装成功了。
]0RBN}ANEVT{8(BEG]Z{P0I
(5) Create New Project,创建一个测试工程,解释器默认选择了Python2.7。
`H2I[1FUMP~A`J}UQ``]%GG
然后在新创建的工程上:点右键-New-Python File, 创建一个新的文件Py01,写代码,点Run按钮-Run Py01运行。
6. 设置Ubuntu下Pycharm的快捷启动方式
在Ubuntu下,每次都要找到 pycharm.sh所在的文件夹,执行./pycharm.sh,非常麻烦。最好能创建一个快捷方式。【7】
Ubuntu的快捷方式都放在/usr/share/applications,首先在该目录下创建一个Pycharm.desktop
$ sudo gedit /usr/share/applications/Pycharm.desktop
然后输入以下内容,注意Exec和Icon需要找到正确的路径
[Desktop Entry]
Type=Application
Name=Pycharm
GenericName=Pycharm3
Comment=Pycharm3:The Python IDE
Exec="/XXX/pycharm-community-3.4.1/bin/pycharm.sh" %f
Icon=/XXX/pycharm-community-3.4.1/bin/pycharm.png
Terminal=pycharm
Categories=Pycharm;
然后双击打开,再锁定到启动器就好了.
请问c++和c#以及java之间有什么相同点、不同点。c#吸收了java和c++语言的哪些优点?
简单地说,它们不是一种语言,语法有差别,编程时具体用到的类库或者函数库也不一样。
虽然它们不是一种语言,不过它们却也有所联系。广泛地说,C可以看作其他三种语言的源语言,因为其他三种语言几乎都是从C而来的,无论从数据类型还是控制语句看,其他三种语言都有从C得来的迹象。
其中C++则一般看作是对C语言的扩展。因为C语言没有面向对象的语法结构,而当时业界又迫切需要面向对象的编程特性,所以贝尔实验室的开发者就为C添加了面向对象的结构。现在C++已经不只是C的扩展了,它已经完全可以被看作一种新的编程语言。虽然C的特性以及库函数仍然被C++支持,不过C++拥有自己的独立的类库体系,功能相当强大。
Java语言是一种完全的面向对象语言,虽然它的底层(运行时库)是用C语言开发的,可是并不依赖于C。因为Java的运行是在运行时库的支持下进行的,所以运行效率比起可以更接近底层的C/C++来说效率会有所影响,不过Java的类库采用很好的设计理念设计,非常好用,也非常实用,已经成为业界的一种标准开发语言。它的跨平台的特性尤其让很多开发者欢迎,你只需要开发一次就能在所有安装了Java运行时库的系统上运行。Java发展了十几年了,可以应用领域非常之广泛,Web开发有JSP,J2EE,桌面领域现在有JavaFX。
C#是微软开发的一种编程语言,语法类似Java,几乎就是从Java的翻版。运行原理和Java也类似,也是通过运行时库的支持运行。不过支持的平台还很有限。JAVA几乎被所有平台支持,而C#目前只被Windows和Linux支持,Windows下的支持当然是由微软自己开发的,而Linux下的支持则有MONO支持。实际上,MONO也是把C#应用转化为JAVA应用而已,所以本质上,C#仍然只是被微软自己的操作系统支持。应用平台受到限制,是它最大的缺点。
C/C++的优点在于与底层比较接近,可以控制的粒度更加精细,是开发系统级应用的最佳选择。关于缺点,我想正是源于其优点,因为它们能控制的编程元素粒度精细,所以编程比较困难,烦琐,容易出错。
Java和C#都比较高级,可以看作高级语言的高级语言,优点是开发容易,但运行效率不如更为底层的C/C++。
具体选择使用的时候,可以根据实际的项目需要选择。运行效率要求高的,底层控制要求高的用C/C++,否则可以选择Java或C#;跨平台的要求高的可以用Java。
关于跨平台,C/C++也是很好的语言,因为所有平台都支持,不同的是,不同平台支持的实现不同,类库不同,要编写跨平台的程序,需要选择跨平台的类库,如标准类库,如果标准类库的支持不够也只需要附加编写一个跨平台的支持类库。
几种语言内容都很多,在这里就不详细列举了,要学好每一种都需要花费相当大的精力,祝你能有所成就!
要说区别,首先就得说联系,我不记得在哪儿看过这么一句话:C是爷爷,C++是爸爸, C#是c的外孙。这形象说明了三者的关系。
从时间先后上说,他们之间最早出现的是C,然后是c++,最后是c#。c++是为了解决软件危机而引入面向对象,c#为了实现平台统一和java争夺市场下的产物。
从性能上说, c的效率最高,c++次之,c#最低。C是面向过程的结构化编程语言,他的特点是语言体积小,效率高, 语言灵活,给程序的限制小,而且可以方便的对低层进行操作,所以它非常适合于开发操作系统,驱动程序,嵌入式等对速度要求较高的程序。 C++使向下完全兼容C的, C++与C相比最显著的变化就是增加了面向对象的成分,也就是增加了类的概念,因为它的增加使软件开发可以比较容易的描述人类的思维,使得软件的开发和维护变得相对简单,直接降低了软件的成本, 但因为C++是面向对象的语言,这本身就制约他的速度,所以C++适合开发那些大型项目,现代的大部分语言都或多或少的借鉴了C++和C的某些特性. C#被包括在.net平台下,是一个面向对象面向网络面向组件的语言, 有很多地方与java非常相似,擅长于开发网络方面的程序. 因此,更确切的说,c#是一个需.net平台支持的开发语言,单纯看c#没有意义,需要了解.net平台的开发知识。
从编译角度看,C/C++编译生成目标文件都是可被CPU直接理解的机器码, 而C#编译后生成的是MSIL(Microsoft Intermediate Language)这种语言不能直接被CPU执行,而是依靠.net framework翻译(Just-in-time compiling)成opcode后再送到CPU执行的。因此,这也是上面为什么说c#运行效率最低的缘故。(但是这种效率低,是说平均意义上的,不是绝对的)
嗯,不知道有没有什么错误,欢迎大家排砖。
他们之间最早出现的是C, C是面向过程的结构化编程语言,他的特点是语言体积小,效率高(可执行文件的效率在除了图象编程方面外只比汇编低20%左右), 语言灵活,给程序的限制小,而且可以方便的对低层进行操作,所以它非常适合于开发,操作系统,驱动程序,嵌入式等对速度要求较高的程序, 后来随着软件危机的出现,人们意识到
面向过程的语言不容易描述人类的思维,在做大型程序的
时候会增加软件难以调试和维护,这无形中增加了软件的成本,由此C++应运而生, C++使向下完全兼容C的, C++与C相比最显著的变化就是增加了面向对象的成分,也就是增加了类的概念,因为它的增加使软件开发可以比较容易的描述人类的思维,使得软件的开发和维护变得相对简单,直接降低了软件的成本, 但因为C++是面向对象的语言,这本身就制约他的速度,所以C++适合开发那些大型项目,现代的大部分语言都或多或少的借鉴了C++和C的某些特性.
C#是Microsoft为了实现平台统一和与java争夺市场下的产物,它被包括在.net平台下,是一个面向对象面向网络面向组件的语言, 有很多地方与java非常相似,擅长于开发网络方面的程序.
总的来说C是爷爷,C++是爸爸, C#是外孙
java编程中出现的错误“非法字符:\56288”是什么意思?
如果VC编译器出现如此错误提示"stray '\161'in progtam",说明你用了全角符号的空格。
直接从网上拷贝代码贴到Dev C++中会经常遇到 stray '\161' in program 错误,其实问题出在代码中掺入了一些不合法的空格(全角空格),把每行代码后的空格删掉即OK了!
C语言错误对照表:
1. Ambiguous operators need parentheses — 不明确的运算需要用括号括起
2. Ambiguous symbol 'xxx' — 不明确的符号
3. Argument list syntax error — 参数表语法错误
4. Array bounds missing — 丢失数组界限符
5. Array size toolarge — 数组尺寸太大
6. Bad character in paramenters — 参数中有不适当的字符
7. Bad file name format in include directive — 包含命令中文件名格式不正确
8. Bad ifdef directive synatax — 编译预处理ifdef有语法错
9. Bad undef directive syntax — 编译预处理undef有语法错
10. Bit field too large — 位字段太长
11. Call of non-function — 调用未定义的函数
12. Call to function with no prototype — 调用函数时没有函数的说明
13. Cannot modify a const object — 不允许修改常量对象
14. Case outside of switch — 漏掉了case 语句
15. Case syntax error — Case 语法错误
16. Code has no effect — 代码不可能执行到
17. Compound statement missing{ — 分程序漏掉"{"
18. Conflicting type modifiers — 不明确的类型说明符
19. Constant expression required — 要求常量表达式
20. Constant out of range in comparison — 在比较中常量超出范围
21. Conversion may lose significant digits — 转换时会丢失意义的数字
22. Conversion of near pointer not allowed — 不允许转换近指针
23. Could not find file 'xxx' — 找不到XXX文件
24. Declaration missing ; — 说明缺少";"
25. Declaration syntax error — 说明中出现语法错误
26. Default outside of switch — Default 出现在switch语句之外
27. Define directive needs an identifier — 定义编译预处理需要标识符
28. Division by zero — 用零作除数
29. Do statement must have while — Do-while语句中缺少while部分
30. Enum syntax error — 枚举类型语法错误
31. Enumeration constant syntax error — 枚举常数语法错误
32. Error directive :xxx — 错误的编译预处理命令
33. Error writing output file — 写输出文件错误
34. Expression syntax error — 表达式语法错误
35. Extra parameter in call — 调用时出现多余错误
36. File name too long — 文件名太长
37. Function call missing ) — 函数调用缺少右括号
38. Fuction definition out of place — 函数定义位置错误
39. Fuction should return a value — 函数必需返回一个值
40. Goto statement missing label — Goto语句没有标号
41. Hexadecimal or octal constant too large — 16进制或8进制常数太大
42. Illegal character 'x' — 非法字符x
43. Illegal initialization — 非法的初始化
44. Illegal octal digit — 非法的8进制数字
45. Illegal pointer subtraction — 非法的指针相减
46. Illegal structure operation — 非法的结构体操作
47. Illegal use of floating point — 非法的浮点运算
48. Illegal use of pointer — 指针使用非法
49. Improper use of a typedefsymbol — 类型定义符号使用不恰当
50. In-line assembly not allowed — 不允许使用行间汇编
51. Incompatible storage class — 存储类别不相容
52. Incompatible type conversion — 不相容的类型转换
53. Incorrect number format — 错误的数据格式
54. Incorrect use of default — Default使用不当
55. Invalid indirection — 无效的间接运算
56. Invalid pointer addition — 指针相加无效
57. Irreducible expression tree — 无法执行的表达式运算
58. Lvalue required — 需要逻辑值0或非0值
59. Macro argument syntax error — 宏参数语法错误
60. Macro expansion too long — 宏的扩展以后太长
61. Mismatched number of parameters in definition — 定义中参数个数不匹配
62. Misplaced break — 此处不应出现break语句
63. Misplaced continue — 此处不应出现continue语句
64. Misplaced decimal point — 此处不应出现小数点
65. Misplaced elif directive — 不应编译预处理elif
66. Misplaced else — 此处不应出现else
67. Misplaced else directive — 此处不应出现编译预处理else
68. Misplaced endif directive — 此处不应出现编译预处理endif
69. Must be addressable — 必须是可以编址的
70. Must take address of memory location — 必须存储定位的地址
71. No declaration for function 'xxx' — 没有函数xxx的说明
72. No stack — 缺少堆栈
73. No type information — 没有类型信息
74. Non-portable pointer assignment — 不可移动的指针(地址常数)赋值
75. Non-portable pointer comparison — 不可移动的指针(地址常数)比较
76. Non-portable pointer conversion — 不可移动的指针(地址常数)转换
77. Not a valid expression format type — 不合法的表达式格式
78. Not an allowed type — 不允许使用的类型
79. Numeric constant too large — 数值常太大
80. Out of memory — 内存不够用
81. Parameter 'xxx' is never used — 能数xxx没有用到
82. Pointer required on left side of - — 符号-的左边必须是指针
83. Possible use of 'xxx' before definition — 在定义之前就使用了xxx(警告)
84. Possibly incorrect assignment — 赋值可能不正确
85. Redeclaration of 'xxx' — 重复定义了xxx
86. Redefinition of 'xxx' is not identical — xxx的两次定义不一致
87. Register allocation failure — 寄存器定址失败
88. Repeat count needs an lvalue — 重复计数需要逻辑值
89. Size of structure or array not known — 结构体或数给大小不确定
90. Statement missing ; — 语句后缺少";"
91. Structure or union syntax error — 结构体或联合体语法错误
92. Structure size too large — 结构体尺寸太大
93. Sub scripting missing ] — 下标缺少右方括号
94. Superfluous with function or array — 函数或数组中有多余的""
95. Suspicious pointer conversion — 可疑的指针转换
96. Symbol limit exceeded — 符号超限
97. Too few parameters in call — 函数调用时的实参少于函数的参数不
98. Too many default cases — Default太多(switch语句中一个)
99. Too many error or warning messages — 错误或警告信息太多
100. Too many type in declaration — 说明中类型太多
101. Too much auto memory in function — 函数用到的局部存储太多
102. Too much global data defined in file — 文件中全局数据太多
103. Two consecutive dots — 两个连续的句点
104. Type mismatch in parameter xxx — 参数xxx类型不匹配
105. Type mismatch in redeclaration of 'xxx' — xxx重定义的类型不匹配
106. Unable to create output file 'xxx' — 无法建立输出文件xxx
107. Unable to open include file 'xxx' — 无法打开被包含的文件xxx
108. Unable to open input file 'xxx' — 无法打开输入文件xxx
109. Undefined label 'xxx' — 没有定义的标号xxx
110. Undefined structure 'xxx' — 没有定义的结构xxx
111. Undefined symbol 'xxx' — 没有定义的符号xxx
112. Unexpected end of file in comment started on line xxx — 从xxx行开始的注解尚未结束文件不能结束
113. Unexpected end of file in conditional started on line xxx — 从xxx 开始的条件语句尚未结束文件不能结束
114. Unknown assemble instruction — 未知的汇编结构
115. Unknown option — 未知的操作
116. Unknown preprocessor directive: 'xxx' — 不认识的预处理命令xxx
117. Unreachable code — 无路可达的代码
118. Unterminated string or character constant — 字符串缺少引号
119. User break — 用户强行中断了程序
120. Void functions may not return a value — Void类型的函数不应有返回值
121. Wrong number of arguments — 调用函数的参数数目错
122. 'xxx' not an argument — xxx不是参数
123. 'xxx' not part of structure — xxx不是结构体的一部分
124. xxx statement missing ( — xxx语句缺少左括号
125. xxx statement missing ) — xxx语句缺少右括号
126. xxx statement missing ; — xxx缺少分号
127. xxx' declared but never used — 说明了xxx但没有使用
128. xxx' is assigned a value which is never used — 给xxx赋了值但未用过
javaelif的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于、javaelif的信息别忘了在本站进行查找喔。
发布于:2022-11-30,除非注明,否则均为
原创文章,转载请注明出处。